Microsoft MVP성태의 닷넷 이야기
제니퍼 .NET: 13. COM+ 서버 모니터링 [링크 복사], [링크+제목 복사],
조회: 22156
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
COM+ 서버 모니터링


당연한 이야기이겠지만, IIS 서버 모니터링이 가능한 것처럼 "제니퍼 닷넷"은 COM+ 서버도 모니터링이 가능합니다.

구성요소 관리자에서 볼 수 있는 COM+ 패키지는 다음과 같이 2가지 유형이 있는데요.

  1. 라이브러리 활성
  2. 서버 활성

1번의 경우에는 해당 DLL이 대상 EXE 프로세스에서 활성화되기 때문에 모니터링이 DLL 단위로 되는 것은 아니고, 호출 측의 EXE 프로세스를 모니터링하는 것으로 자연스럽게 해결됩니다. 즉, IIS 서버의 w3wp.exe에서 라이브러리 활성화 COM+를 사용한다면 w3wp.exe를 모니터링하는 것으로 COM+ 개체에서 실행되는 SQL 쿼리 등이 함께 모니터링이 되는 것입니다.

문제는 2번의 경우인데요. 서버 활성화로 된 경우에는 해당 COM+ 개체가 dllhost.exe라는 Surrogate 프로세스에서 활성화가 되기 때문에 별도로 IIS 서버 모니터링하는 것과 동일한 방식으로 dllhost.exe에 대한 설정을 해줘야 합니다.

일단, 설치는 되었다고 가정하고 동작하는 것을 한번 볼까요? ^^




우선, COM+를 사용하는 측에서의 모니터링은 아래에서 알아봤는데요.

COM+ 호출 모니터링 및 누수 확인
; https://www.sysnet.pe.kr/2/0/881

dllhost.exe를 모니터링하는 것은 일반적인 웹 애플리케이션을 모니터링하는 것과 동일하게 다음과 같은 화면으로 확인할 수 있습니다.

complus_server_monitor_1.png

거의 IIS 웹 애플리케이션을 모니터링하는 것과 별반 다를 바가 없다는 것을 볼 수 있습니다.

다음은 X-View의 상세 화면입니다.

complus_server_monitor_2.png

웹 애플리케이션의 서비스 명은 URL로 나타나지만, COM+ 서버의 서비스 명은 "EntLibServerApp.MyComponentServer.GetApp"와 같이 "EntLibServerApp.MyComponentServer" 네임스페이스를 포함한 클래스 명과 "GetApp"라는 메서드 명으로 이뤄집니다.

여기서 재미있는 것은 "GUID"라는 값인데요. 웹 애플리케이션만을 모니터링하는 화면에서는 이 값을 볼 수 없지만, 이렇게 COM+와 연동하는 경우에는 이 값이 큰 역할을 하게 됩니다. 즉, "호출하는 측"과 "호출되는 측"에 대해 동일한 ID를 부여함으로써 X-View에서 연동 서비스들을 같이 확인하는 것이 가능합니다.

X-View에서 이를 확인해 볼까요?

complus_server_monitor_3.png

위의 화면과 같이 연동된 호출 서비스를 확인하려면 "GUID" 라디오 상자 값을 선택하고 X-View를 봐야 하는데, 위의 경우에는 "점" 하나에 대해서 연동된 호출 수가 5개가 있다는 것을 보여줍니다. 즉, 해당 GUID 값을 타고 호출된 서비스들이 5개가 있다는 것인데요.

해당 점을 마우스로 드래그해서 상세화면에서 확인하면,

complus_server_monitor_4.png

위와 같이 하나의 점에 해당하는 5개의 호출을 확인할 수 있습니다. 예제에서 보여지는 호출 관계는 다음과 같습니다.

1. ComPlusServerTest.aspx에서 SecondEntLibServerApp.MySecondComponent.TestMethod 호출
2. ComPlusServerTest.aspx에서 EntLibServerApp.MyComponentServer.GetApp 호출
3. ComPlusServerTest.aspx에서 EntLibServerApp.MyComponentServer.MethodChainTest 호출
    3.1 EntLibServerApp.MyComponentServer.MethodChainTest에서 SecondEntLibServerApp.MySecondComponent.TestMethod 호출

정리해 보면, aspx 웹 페이지에서 COM+를 사용하는 것과, COM+에서 또 다른 COM+를 호출하는 것까지 모니터링이 되어 전체적으로 하나의 호출 Context에서 실행된 원격 메서드들을 모두 모니터링하는 것이 가능합니다.

이 정도면, "닷넷 모니터링 솔루션"으로써 손색이 없겠죠! ^^

[연관 글]






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

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

비밀번호

댓글 작성자
 



2010-07-05 09시01분
[누굴까~~요?] 햐... 대단한데요...

손색없네요...

누가 만든거래요?
[guest]
2010-07-05 11시49분
^^
kevin25

... 16  17  18  19  20  21  22  23  24  25  26  [27]  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
12988정성태3/2/20226447오류 유형: 795. CI 환경에서 Docker build 시 csproj의 Link 파일에 대한 빌드 오류
12987정성태3/1/20228053.NET Framework: 1169. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 demuxing_decoding.c 예제 포팅
12986정성태2/28/20228946.NET Framework: 1168. C# -IIncrementalGenerator를 적용한 Version 2 Source Generator 실습 [1]
12985정성태2/28/20228791.NET Framework: 1167. C# -Version 1 Source Generator 실습
12984정성태2/24/20227838.NET Framework: 1166. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 filtering_video.c 예제 포팅
12983정성태2/24/20227880.NET Framework: 1165. .NET Core/5+ 빌드 시 runtimeconfig.json에 설정을 반영하는 방법
12982정성태2/24/20227833.NET Framework: 1164. HTTP Error 500.31 - ANCM Failed to Find Native Dependencies
12981정성태2/23/20227426VC++: 154. C/C++ 언어의 문자열 Literal에 인덱스 적용하는 구문 [1]
12980정성태2/23/20228264.NET Framework: 1163. C# - 윈도우 환경에서 usleep을 호출하는 방법 [2]
12979정성태2/22/202210948.NET Framework: 1162. C# - 인텔 CPU의 P-Core와 E-Core를 구분하는 방법 [1]파일 다운로드2
12978정성태2/21/20228141.NET Framework: 1161. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 resampling_audio.c 예제 포팅
12977정성태2/21/202211921.NET Framework: 1160. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 qsv 디코딩
12976정성태2/21/20227438VS.NET IDE: 174. Visual C++ - "External Dependencies" 노드 비활성화하는 방법
12975정성태2/20/20229047.NET Framework: 1159. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 qsvdec.c 예제 포팅파일 다운로드1
12974정성태2/20/20227165.NET Framework: 1158. C# - SqlConnection의 최소 Pooling 수를 초과한 DB 연결은 언제 해제될까요?
12973정성태2/16/20229617개발 환경 구성: 639. ffmpeg.exe - Intel Quick Sync Video(qsv)를 이용한 인코딩 [3]
12972정성태2/16/20228929Windows: 200. Intel CPU의 내장 그래픽 GPU가 작업 관리자에 없다면? [4]
12971정성태2/15/202210659.NET Framework: 1157. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 muxing.c 예제 포팅 [7]파일 다운로드2
12970정성태2/15/20228629.NET Framework: 1156. C# - ffmpeg(FFmpeg.AutoGen): Bitmap으로부터 h264 형식의 파일로 쓰기 [1]파일 다운로드1
12969정성태2/14/20227096개발 환경 구성: 638. Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구 - 두 번째 이야기파일 다운로드1
12968정성태2/14/20227331오류 유형: 794. msbuild 에러 - error NETSDK1005: Assets file '...\project.assets.json' doesn't have a target for '...'.
12967정성태2/14/20227799VC++: 153. Visual C++ - C99 표준의 Compund Literals 빌드 방법 [4]
12966정성태2/13/20227492.NET Framework: 1155. C# - ffmpeg(FFmpeg.AutoGen): Bitmap으로부터 yuv420p + rawvideo 형식의 파일로 쓰기파일 다운로드1
12965정성태2/13/20227557.NET Framework: 1154. "Hanja Hangul Project v1.01 (파이썬)"의 C# 버전
12964정성태2/11/20227855.NET Framework: 1153. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 avio_reading.c 예제 포팅파일 다운로드1
12963정성태2/11/20228659.NET Framework: 1152. C# - 화면 캡처한 이미지를 ffmpeg(FFmpeg.AutoGen)로 동영상 처리 (저해상도 현상 해결)파일 다운로드1
... 16  17  18  19  20  21  22  23  24  25  26  [27]  28  29  30  ...