성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] Detecting blocking calls using asyn...
[정성태] 아쉽게도, 커뮤니티는 아니고 개인 블로그입니다. ^^
[정성태] 질문이 잘 이해가 안 됩니다. 우선, 해당 소스코드에서 ILis...
[양승조
] var대신 dinamic으로 선언해서 해결은 했습니다. 맞는 해...
[양승조
] 또 막혔습니다. ㅠㅠ var list = props[i].Ge...
[양승조
] 아. 감사합니다. 어제는 안됐던것 같은데....정신을 차려야겠네...
[정성태] "props[i].GetValue(props[i])" 코드에서 ...
[정성태] 저렇게 조각 코드 말고, 실제로 재현이 되는 예제 프로젝트를 압...
[정성태] Modules 창(Ctrl+Shift+U)을 띄워서, 해당 Op...
[정성태] 만드실 수 있습니다. 단지, Unity 엔진 내의 스크립트와 W...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>PerformanceCounter의 InstanceName 지정 시 주의 사항</h1> <p> 예를 들어, ".NET CLR Memory" 범주의 "% Time in GC"를 구한다면 다음과 같이 코딩할 수 있습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > PerformanceCounter pc = new PerformanceCounter(); pc.CategoryName = ".NET CLR Memory"; pc.CounterName = "% Time in GC"; pc.ReadOnly = true; pc.InstanceName = "ConsoleApplication1.exe"; </pre> <br /> 보는 바와 같이 InstanceName 속성에 실행 파일 이름이 들어갑니다. 보통의 경우 별 문제없이 사용할 수 있지만, 동일한 실행 파일명이 뜨는 상황이라면 문제가 꽤나 복잡해집니다.<br /> <br /> 왜냐하면 실행 파일 이름이 같은 2번째 프로세스가 뜨면 인스턴스 이름이 "#2" 접미사를 붙여야 하기 때문입니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > pc.InstanceName = "ConsoleApplication1.exe#2"; </pre> <br /> 그런데, 만약 2개의 ConsoleApplication1.exe 프로세스 중에서 특정 Process ID를 가진 것만 모니터링하고 싶다고 하면 어떻게 해야 할까요? 주어진 InstanceName으로는 어느 것이 어떤 Prcoess ID를 가진 것인지 알 수 없습니다.<br /> <br /> 이 때문에 저런 식으로 InstanceName을 명명해야 하는 성능 카운터들은 독자적으로 자신의 성능 카운터 중에 PID와 InstanceName을 매칭하는 성능 카운터를 제공합니다. 그리고 바로 그 방법을 설명하는 것이 다음의 글이고.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Performance Counter by Process ID instead of name? ; <a target='tab' href='http://stackoverflow.com/questions/9115436/performance-counter-by-process-id-instead-of-name'>http://stackoverflow.com/questions/9115436/performance-counter-by-process-id-instead-of-name</a> </pre> <a name='get_instance_name'></a> <br /> 위의 글에 따라, Process ID에 해당하는 InstanceName을 구하는 소스코드는 다음과 같습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > 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 ..."); } </pre> <br /> 그런데, 안 좋은 소식이 하나 있는데요. Process ID에 따른 InstanceName은 실행 중 (원치 않게) 변할 수 있다는 점입니다.<br /> <br /> 예들 들어, 현재 다음의 2가지 인스턴스가 있다고 가정했을 때,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > pid == 1000, instanceName == ConsoleApplication1.exe pid == 2000, instanceName == <span style='color: blue; font-weight: bold'>ConsoleApplication1.exe#2</span> </pre> <br /> 도중에 pid == 1000인 프로세스가 종료되면 다음과 같은 상황이 되어버리는 것입니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > pid == 2000, instanceName == <span style='color: blue; font-weight: bold'>ConsoleApplication1.exe</span> </pre> <br /> 그렇기 때문에 특정 process id에 해당하는 프로세스를 모니터링하려면 주기적으로 pid와 instanceName이 같은 지 확인하는 절차를 넣어두어야 합니다.<br /> <br /> 이런 문제점을 보완하기 위해 성능 카운터 InstanceName으로 PID를 붙이는 개선이 나왔습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > The Process object in Performance Monitor can display Process IDs (PIDs) ; <a target='tab' href='https://techcommunity.microsoft.com/t5/ask-the-performance-team/perfmon-identifying-processes-by-pid-instead-of-instance/ba-p/374561'>https://techcommunity.microsoft.com/t5/ask-the-performance-team/perfmon-identifying-processes-by-pid-instead-of-instance/ba-p/374561</a> 키 경로: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\PerfProc\Performance Name: ProcessNameFormat 타입: DWORD:2 </pre> <br /> 아쉬운 점이라면, 이 좋은 방법이 기본적으로는 꺼져 있다는 것입니다. 따라서, 3rd-party 라이브러리를 제작하는 업체 입장에서는 함부로 저 레지스트리 값을 변경하기가 영 꺼림직합니다. (자칫 잘못하면 기존 성능 카운터를 기반으로 한 업체들의 프로그램 동작에 영향을 줄 수 있기 때문입니다.)<br /> <br /> 암튼... 마이크로소프트가 성능 카운터를 너무 보수적인 입장에서 유지/보수하는 것이 아닌가... 하는 아쉬움이 있습니다. ^^<br /> <br /> (<a target='tab' href='http://www.sysnet.pe.kr/bbs/DownloadAttachment.aspx?fid=980&boardid=331301885'>첨부한 소스코드는 이를 재현할 수 있는 간단한 프로젝트</a>입니다.)<br /> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
1446
(왼쪽의 숫자를 입력해야 합니다.)