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

정말이지, 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

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  68  69  70  71  [72]  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12136정성태2/6/202017269Windows: 168. Windows + S(또는 Q)로 뜨는 작업 표시줄의 검색 바가 동작하지 않는 경우
12135정성태2/6/202022536개발 환경 구성: 468. Nuget 패키지의 로컬 보관 폴더를 옮기는 방법 [2]
12134정성태2/5/202020944.NET Framework: 884. eBEST XingAPI의 C# 래퍼 버전 - XingAPINet Nuget 패키지 [5]파일 다운로드1
12133정성태2/5/202018365디버깅 기술: 161. Windbg 환경에서 확인해 본 .NET 메서드 JIT 컴파일 전과 후 - 두 번째 이야기
12132정성태1/28/202021213.NET Framework: 883. C#으로 구현하는 Win32 API 후킹(예: Sleep 호출 가로채기) [1]파일 다운로드1
12131정성태1/27/202020205개발 환경 구성: 467. LocaleEmulator를 이용해 유니코드를 지원하지 않는(한글이 깨지는) 프로그램을 실행하는 방법 [1]
12130정성태1/26/202017487VS.NET IDE: 142. Visual Studio에서 windbg의 "Open Executable..."처럼 EXE를 직접 열어 디버깅을 시작하는 방법
12129정성태1/26/202023601.NET Framework: 882. C# - 키움 Open API+ 사용 시 Registry 등록 없이 KHOpenAPI.ocx 사용하는 방법 [3]
12128정성태1/26/202017944오류 유형: 591. The code execution cannot proceed because mfc100.dll was not found. Reinstalling the program may fix this problem.
12127정성태1/25/202017127.NET Framework: 881. C# DLL에서 제공하는 Win32 export 함수의 내부 동작 방식(VT Fix up Table)파일 다운로드1
12126정성태1/25/202018523.NET Framework: 880. C# - PE 파일로부터 IMAGE_COR20_HEADER 및 VTableFixups 테이블 분석파일 다운로드1
12125정성태1/24/202015995VS.NET IDE: 141. IDE0019 - Use pattern matching
12124정성태1/23/202017790VS.NET IDE: 140. IDE1006 - Naming rule violation: These words must begin with upper case characters: ...
12123정성태1/23/202019496웹: 39. Google Analytics - gtag 함수를 이용해 페이지 URL 수정 및 별도의 이벤트 생성 방법 [2]
12122정성태1/20/202015632.NET Framework: 879. C/C++의 UNREFERENCED_PARAMETER 매크로를 C#에서 우회하는 방법(IDE0060 - Remove unused parameter '...')파일 다운로드1
12121정성태1/20/202016324VS.NET IDE: 139. Visual Studio - Error List: "Could not find schema information for the ..."파일 다운로드1
12120정성태1/19/202018717.NET Framework: 878. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 네 번째 이야기(IL 코드로 직접 구현)파일 다운로드1
12119정성태1/17/202018934디버깅 기술: 160. Windbg 확장 DLL 만들기 (3) - C#으로 만드는 방법
12118정성태1/17/202019959개발 환경 구성: 466. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 세 번째 이야기 [1]
12117정성태1/15/202018771디버깅 기술: 159. C# - 디버깅 중인 프로세스를 강제로 다른 디버거에서 연결하는 방법파일 다운로드1
12116정성태1/15/202019441디버깅 기술: 158. Visual Studio로 디버깅 시 sos.dll 확장 명령어를 (비롯한 windbg의 다양한 기능을) 수행하는 방법
12115정성태1/14/202019699디버깅 기술: 157. C# - PEB.ProcessHeap을 이용해 디버깅 중인지 확인하는 방법파일 다운로드1
12114정성태1/13/202021499디버깅 기술: 156. C# - PDB 파일로부터 심벌(Symbol) 및 타입(Type) 정보 열거 [1]파일 다운로드3
12113정성태1/12/202021542오류 유형: 590. Visual C++ 빌드 오류 - fatal error LNK1104: cannot open file 'atls.lib' [1]
12112정성태1/12/202016748오류 유형: 589. PowerShell - 원격 Invoke-Command 실행 시 "WinRM cannot complete the operation" 오류 발생
12111정성태1/12/202020541디버깅 기술: 155. C# - KernelMemoryIO 드라이버를 이용해 실행 프로그램을 숨기는 방법(DKOM: Direct Kernel Object Modification) [16]파일 다운로드1
... 61  62  63  64  65  66  67  68  69  70  71  [72]  73  74  75  ...