Microsoft MVP성태의 닷넷 이야기
웹: 3. IIS 6.0 - AppPool을 활용하여 실 서버(운영 서버)에서 디버깅 [링크 복사], [링크+제목 복사],
조회: 16002
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 


정말이지, Microsoft가 IIS 6.0을 설계한 방식에 대해서는 감탄을 자아내게 합니다.
Kernel 단계로 내린 http.sys는 다른 어떤 웹 서버도 따라올 수 없는 경지이죠. 운영체제를 만든 업체로서 시도해 볼 수 있는 커널 드라이버로의 이전은 대단한 성능 개선으로 이뤄집니다.

(32bit 윈도우즈 기준으로 설명하면)
Kernel 드라이버는 그 특성상 2GB ~ 4GB 가상 메모리에 존재하게 됩니다. 그러면서, 프로세스 전역적으로 매핑이 되어지게 되죠. IIS 5.0/5.1 같은 경우에는 inetinfo.exe가 받아들인 요청을, 그것을 처리해야 하는 worker process로 전달하기 위해서 Named Pipe 또는 TCP/IP를 별도로 사용해야 했습니다. 즉, 부하가 심한 프로세스 간 통신(Inter-process Communication)을 사용해야 했지요.

반면에, IIS 6.0에서는 전역적으로 가상 메모리에 매핑되는 커널 단에 존재하기 때문에 결국 받아들인 요청은 w3wp.exe 프로세스 메모리에 매핑되어 있는 효과와 같게 됩니다. 프로세스 간 통신 부하 자체가 없어진 것이죠. 이를 도식화해서 표현한 그림을 아래에 보여주고 있습니다. (2가지 그림 모두 MSDN 사이트에서 가져온 것입니다.)

[그림 1: IIS 5.0 구조]
IIS 5.0

[그림 2: IIS 6.0 구조]
IIS 6.0

이렇게 IIS 6.0에 대해서는 여러 가지 칭찬해 줄 만한 것들이 있긴 하지만, 개인적으로 "최고"로 꼽는 기능이 바로 AppPool을 이용한 실제 서비스의 디버깅 환경 구성입니다.

아시는 것처럼, 디버깅 프로세스를 attach 시킨 후 예외 상황이 발생하면 프로세스 스케쥴링은 완전히 중지하게 됩니다. 현재 서비스 중인 웹 애플리케이션을 디버깅할 수 없는 원인이 바로 여기에 있죠. 해당 예외가 발생한 스레드 뿐만 아니라, 프로세스에 존재하는 모든 스레드가 중지되기 때문에 사용자들이 전혀 사용할 수 없는 상황이 되어버립니다.

VS.NET에 원격 디버깅 기능이 있다고 해도 실제로 많은 효용성이 없는 이유가 바로 여기에 있습니다. 서비스 오픈 하기 전의 운영 장비에서 발생하는 특별한 버그를 잡을 때 정도만이 사용될 수 있을 뿐, 일단 서비스가 시작되면 원격 디버깅은 무용지물이 됩니다. 물론, 사용자들이 접속하지 않는 시간대를 선택하면 가능하겠지요. ^^ 그래도, 그런 상황의 개발자는 안스러울 따름입니다.

그동안 IIS 5.0/5.1에서는 불가능했지만, IIS 6.0의 AppPool을 이용하게 되면 서비스 중인 웹 응용 프로그램에 지장을 주지 않고도 그와 동등한 환경에서 디버깅을 할 수 있습니다. 벌써, 이 말만 듣고도 감을 잡으셨을 분이 계시겠지만, 간단하게 과정을 설명드리겠습니다.


1. 임시로 사용될 "웹 사이트"를 만듭니다. 아래와 같이, IP 및 포트는 동일하게 유지면서, 호스트 헤더값만 달리 합니다.

디버그용 웹 사이트

2. 만들어진 웹 사이트는 다음과 같습니다. 보시는 것처럼 이름은 "디버그 웹 사이트"로 되어 있으며, 루트 디렉터리 또한 "기본 웹 사이트"와 동일한 곳으로 설정을 했습니다.

디버그용 웹 사이트 - 루트 디렉터리

3. 이제 w3wp.exe 프로세스를 달리 설정할 수 있도록 별도의 AppPool을 만들어야 합니다. 최대한 실제 서비스 환경과 동일하게 하기 위해 AppPool 역시 다음 그림과 같이 "기존 응용 프로그램 풀을 템플릿으로 사용"을 선택해서 만듭니다.

디버그용 AppPool

4. 자, 이제 적절한 URL(예제의 경우 http://debug.sysnet.pe.kr)로 네비게이션을 하면, 새로운 w3wp.exe가 서버에서 구동되게 됩니다. 원래의 서비스는 또 다른 w3wp.exe에서 변함없이 동작하고 있으므로, VS.NET 원격 디버깅으로 새롭게 생긴 w3wp.exe 프로세스에 대해 디버깅을 시작할 수 있습니다.



별거 아닌 것처럼 보일 수도 있지만, 실제 운영 서버에서만 발생하는 오류들을 디버깅할 수 있다는 것은 다른 여타의 웹 서버와는 비교할 수 없는 장점을 제공해 줍니다.






[최초 등록일: ]
[최종 수정일: 6/25/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...
NoWriterDateCnt.TitleFile(s)
13276정성태3/5/20234797.NET Framework: 2102. C# 11 - ref struct/ref field를 위해 새롭게 도입된 scoped 예약어
13275정성태3/3/20235036.NET Framework: 2101. C# 11의 ref 필드 설명
13274정성태3/2/20234600.NET Framework: 2100. C# - ref 필드로 ref struct 타입을 허용하지 않는 이유
13273정성태2/28/20234364.NET Framework: 2099. C# - 관리 포인터로서의 ref 예약어 의미
13272정성태2/27/20234606오류 유형: 850. SSMS - mdf 파일을 Attach 시킬 때 Operating system error 5: "5(Access is denied.)" 에러
13271정성태2/25/20234589오류 유형: 849. Sql Server Configuration Manager가 시작 메뉴에 없는 경우
13270정성태2/24/20234097.NET Framework: 2098. dotnet build에 /p 옵션을 적용 시 유의점
13269정성태2/23/20234737스크립트: 46. 파이썬 - uvicorn의 콘솔 출력을 UDP로 전송
13268정성태2/22/20235252개발 환경 구성: 667. WSL 2 내부에서 열고 있는 UDP 서버를 호스트 측에서 접속하는 방법
13267정성태2/21/20235142.NET Framework: 2097. C# - 비동기 소켓 사용 시 메모리 해제가 finalizer 단계에서 발생하는 사례파일 다운로드1
13266정성태2/20/20234783오류 유형: 848. .NET Core/5+ - Process terminated. Couldn't find a valid ICU package installed on the system
13265정성태2/18/20234663.NET Framework: 2096. .NET Core/5+ - PublishSingleFile 유형에 대한 runtimeconfig.json 설정
13264정성태2/17/20236256스크립트: 45. 파이썬 - uvicorn 사용자 정의 Logger 작성
13263정성태2/16/20234421개발 환경 구성: 666. 최신 버전의 ilasm.exe/ildasm.exe 사용하는 방법
13262정성태2/15/20235497디버깅 기술: 191. dnSpy를 이용한 (소스 코드가 없는) 닷넷 응용 프로그램 디버깅 방법 [1]
13261정성태2/15/20234867Windows: 224. Visual Studio - 영문 폰트가 Fullwidth Latin Character로 바뀌는 문제
13260정성태2/14/20234607오류 유형: 847. ilasm.exe 컴파일 오류 - error : syntax error at token '-' in ... -inf
13259정성태2/14/20234763.NET Framework: 2095. C# - .NET5부터 도입된 CollectionsMarshal
13258정성태2/13/20234584오류 유형: 846. .NET Framework 4.8 Developer Pack 설치 실패 - 0x81f40001
13257정성태2/13/20234680.NET Framework: 2094. C# - Job에 Process 포함하는 방법 [1]파일 다운로드1
13256정성태2/10/20235430개발 환경 구성: 665. WSL 2의 네트워크 통신 방법 - 두 번째 이야기
13255정성태2/10/20234847오류 유형: 845. gihub - windows2022 이미지에서 .NET Framework 4.5.2 미만의 프로젝트에 대한 빌드 오류
13254정성태2/10/20234765Windows: 223. (WMI 쿼리를 위한) PowerShell 문자열 escape 처리
13253정성태2/9/20235585Windows: 222. C# - 다른 윈도우 프로그램이 실행되었음을 인식하는 방법파일 다운로드1
13252정성태2/9/20234389오류 유형: 844. ssh로 명령어 수행 시 멈춤 현상
13251정성태2/8/20234752스크립트: 44. 파이썬의 3가지 스레드 ID
1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...