Microsoft MVP성태의 닷넷 이야기
.NET Framework: 547. PerformanceCounter의 InstanceName 지정 시 주의 사항 [링크 복사], [링크+제목 복사],
조회: 21794
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 2개 있습니다.)
(시리즈 글이 3개 있습니다.)
.NET Framework: 547. PerformanceCounter의 InstanceName 지정 시 주의 사항
; https://www.sysnet.pe.kr/2/0/10898

Windows: 262. PerformanceCounter의 InstanceName에 pid를 추가한 "Process V2"
; https://www.sysnet.pe.kr/2/0/13585

닷넷: 2324. C# - 프로세스의 성능 카운터용 인스턴스 이름을 구하는 방법
; https://www.sysnet.pe.kr/2/0/13891




PerformanceCounter의 InstanceName 지정 시 주의 사항

예를 들어, ".NET CLR Memory" 범주의 "% Time in GC"를 구한다면 다음과 같이 코딩할 수 있습니다.

PerformanceCounter pc = new PerformanceCounter();
pc.CategoryName = ".NET CLR Memory";
pc.CounterName = "% Time in GC";
pc.ReadOnly = true;
pc.InstanceName = "ConsoleApplication1.exe";

보는 바와 같이 InstanceName 속성에 실행 파일 이름이 들어갑니다. 보통의 경우 별 문제없이 사용할 수 있지만, 동일한 실행 파일명이 뜨는 상황이라면 문제가 꽤나 복잡해집니다.

왜냐하면 실행 파일 이름이 같은 2번째 프로세스가 뜨면 인스턴스 이름이 "#2" 접미사를 붙여야 하기 때문입니다.

pc.InstanceName = "ConsoleApplication1.exe#2";

그런데, 만약 2개의 ConsoleApplication1.exe 프로세스 중에서 특정 Process ID를 가진 것만 모니터링하고 싶다고 하면 어떻게 해야 할까요? 주어진 InstanceName으로는 어느 것이 어떤 Prcoess ID를 가진 것인지 알 수 없습니다.

이 때문에 저런 식으로 InstanceName을 명명해야 하는 성능 카운터들은 독자적으로 자신의 성능 카운터 중에 PID와 InstanceName을 매칭하는 성능 카운터를 제공합니다. 그리고 바로 그 방법을 설명하는 것이 다음의 글이고.

Performance Counter by Process ID instead of name?
; http://stackoverflow.com/questions/9115436/performance-counter-by-process-id-instead-of-name

위의 글에 따라, Process ID에 해당하는 InstanceName을 구하는 소스코드는 다음과 같습니다.

private static string GetProcessInstanceName(int pid)
{
    string categoryName = ".NET CLR Memory";
    PerformanceCounterCategory cat = new PerformanceCounterCategory(categoryName);

    string[] instances = cat.GetInstanceNames();
    foreach (string instance in instances)
    {
        using (PerformanceCounter cnt = new PerformanceCounter(categoryName,
                "Process ID", instance, true))
        {
            int val = 0;

            try
            {
                val = (int)cnt.RawValue;
            }
            catch
            {
                continue;
            }

            if (val == pid)
            {
                return instance;
            }
        }
    }
    throw new Exception("Could not find performance counter " +
        "instance name for current process. This is truly strange ...");
}

그런데, 안 좋은 소식이 하나 있는데요. Process ID에 따른 InstanceName은 실행 중 (원치 않게) 변할 수 있다는 점입니다.

예들 들어, 현재 다음의 2가지 인스턴스가 있다고 가정했을 때,

pid == 1000, instanceName == ConsoleApplication1.exe
pid == 2000, instanceName == ConsoleApplication1.exe#2

도중에 pid == 1000인 프로세스가 종료되면 다음과 같은 상황이 되어버리는 것입니다.

pid == 2000, instanceName == ConsoleApplication1.exe

그렇기 때문에 특정 process id에 해당하는 프로세스를 모니터링하려면 주기적으로 pid와 instanceName이 같은 지 확인하는 절차를 넣어두어야 합니다.

이런 문제점을 보완하기 위해 성능 카운터 InstanceName으로 PID를 붙이는 개선이 나왔습니다.

The Process object in Performance Monitor can display Process IDs (PIDs) 
; https://techcommunity.microsoft.com/t5/ask-the-performance-team/perfmon-identifying-processes-by-pid-instead-of-instance/ba-p/374561

키 경로: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\PerfProc\Performance
Name: ProcessNameFormat
타입: DWORD:2

아쉬운 점이라면, 이 좋은 방법이 기본적으로는 꺼져 있다는 것입니다. 따라서, 3rd-party 라이브러리를 제작하는 업체 입장에서는 함부로 저 레지스트리 값을 변경하기가 영 꺼림직합니다. (자칫 잘못하면 기존 성능 카운터를 기반으로 한 업체들의 프로그램 동작에 영향을 줄 수 있기 때문입니다.)

암튼... 마이크로소프트가 성능 카운터를 너무 보수적인 입장에서 유지/보수하는 것이 아닌가... 하는 아쉬움이 있습니다. ^^

(첨부한 소스코드는 이를 재현할 수 있는 간단한 프로젝트입니다.)




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 3/29/2024]

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

비밀번호

댓글 작성자
 




... 151  152  153  154  [155]  156  157  158  159  160  161  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1177정성태11/18/201129962.NET Framework: 272. 소켓 연결 시간 제한 - 두 번째 이야기 [1]파일 다운로드1
1176정성태11/17/201129173.NET Framework: 271. C#에서 확인해 보는 관리 힙의 인스턴스 구조 [3]파일 다운로드1
1175정성태11/16/201127182.NET Framework: 270. .NET 참조 개체 인스턴스의 Object Header를 확인하는 방법 [1]파일 다운로드1
1174정성태11/15/201126580.NET Framework: 269. 일반 참조형의 기본 메모리 소비는 얼마나 될까요? [4]
1173정성태11/14/201122777.NET Framework: 268. .NET Array는 왜 12bytes의 기본 메모리를 점유할까? [1]
1172정성태11/13/201119741.NET Framework: 267. windbg - GC Heap에서 .NET 타입에 대한 배열을 찾는 방법
1171정성태11/12/201136444.NET Framework: 266. StringBuilder에서의 OutOfMemoryException 오류 원인 분석 [4]파일 다운로드1
1170정성태11/10/201125665.NET Framework: 265. Named 동기화 개체 생성 시 System.UnauthorizedAccessException 예외 발생하는 경우
1169정성태11/10/201129450.NET Framework: 264. 다중 LAN 카드 환경에서 Dns.GetHostAddresses(local)가 반환해 주는 IP의 우선순위는 어떻게 될까요? [4]
1168정성태11/6/201125330오류 유형: 139. TlbImp : error TI0000 : A single valid machine type compatible with the input type library must be specified
1167정성태11/5/201137129개발 환경 구성: 133. Registry 등록 과정 없이 COM 개체 사용 - 두 번째 이야기 [5]파일 다운로드4
1166정성태11/5/201123176.NET Framework: 263. byte[] pData = new byte[100000]로 인한 성능 차이? [1]파일 다운로드1
1165정성태11/3/201128082개발 환경 구성: 132. "Visual Studio Command Prompt (2010)" 명령행에서 2.0 버전의 MSBuild를 구동하는 방법 [2]파일 다운로드1
1164정성태11/1/201126246.NET Framework: 262. .NET 스레드 콜 스택 덤프 (4) - .NET 4.0을 지원하지 않는 MSE 응용 프로그램 원인 분석
1163정성태10/31/201125742.NET Framework: 261. .NET 스레드 콜 스택 덤프 (3) - MSE 소스 코드 개선파일 다운로드1
1162정성태10/30/201125872.NET Framework: 260. .NET 스레드 콜 스택 덤프 (2) - Managed Stack Explorer 소스 코드를 이용한 스택 덤프 구하는 방법파일 다운로드1
1161정성태10/29/201122676.NET Framework: 259. Type.GetMethod - System.Reflection.AmbiguousMatchException파일 다운로드1
1159정성태10/28/201126112.NET Framework: 258. Roslyn 맛보기 - SyntaxTree 조작 [2]
1158정성태10/24/201125443.NET Framework: 257. Roslyn 맛보기 - Roslyn Symbol / Binding API파일 다운로드1
1157정성태10/23/201129879.NET Framework: 256. Roslyn 맛보기 - Syntax Analysis (Roslyn Syntax API) [2]
1156정성태10/23/201128349.NET Framework: 255. Roslyn 맛보기 - Roslyn Services APIs를 이용한 Code Issue 및 Code Action 기능 소개 [1]
1155정성태10/22/201126405.NET Framework: 254. Roslyn 맛보기 - C# Interactive (2)
1154정성태10/22/201133157.NET Framework: 253. Roslyn 맛보기 - C# Interactive (1)
1153정성태10/21/201142029.NET Framework: 252. Roslyn 맛보기 - C# 소스 코드를 스크립트처럼 다루는 방법 [7]파일 다운로드1
1152정성태10/20/201123703.NET Framework: 251. string.GetHashCode는 hash 값을 cache 할까?
1151정성태10/18/201122629Java: 13. 자바도 64비트에서 (2GB) OutOfMemoryException 예외가 발생할까?
... 151  152  153  154  [155]  156  157  158  159  160  161  162  163  164  165  ...