Microsoft MVP성태의 닷넷 이야기
.NET Framework: 372. PerformanceCounter - Category does not exist. [링크 복사], [링크+제목 복사],
조회: 25196
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

PerformanceCounter - Category does not exist.

성능 모니터링 도구를 보면 닷넷 관련해서 다음과 같은 범주의 성능 카운터들이 제공되는 것을 볼 수 있는데요.

admin_perf_counter_1.png

이를 이용하기 위해 실제로 코드를 작성하면,

using System;
using System.Diagnostics;

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            foreach (var item in PerformanceCounterCategory.GetCategories())
            {
                if (item.CategoryName.IndexOf("CLR") != -1)
                {
                    Console.WriteLine(item.CategoryName);
                }
            }

            Console.WriteLine();

            string categoryName = ".NET CLR Memory";
            var category = new PerformanceCounterCategory(categoryName);
            var counters = category.GetInstanceNames(); // 예외 발생: Category does not exist

            string counterName = "Gen 0 heap Size";
            using (PerformanceCounter perfCounter
                = new PerformanceCounter(categoryName, counterName, "......", true)) // 예외 발생: Category does not exist
            {
                // ......
            }
        }
    }
}

위의 2가지 코드에서 예외가 발생하는 것을 볼 수 있습니다. 분명히 ".NET CLR Memory" 범주가 있는데도, 이에 대한 정보를 구하려고 하니 없다고 예외를 뿌리고 있는 것입니다.

System.InvalidOperationException was unhandled
  Message=Category does not exist.
  Source=System
  StackTrace:
       at System.Diagnostics.PerformanceCounterLib.CounterExists(String machine, String category, String counter)
       at System.Diagnostics.PerformanceCounter.Initialize()
       at System.Diagnostics.PerformanceCounter..ctor(String categoryName, String counterName, String instanceName, Boolean readOnly)
       at ConsoleApplication1.Program.Main(String[] args) in d:\...\ConsoleApplication1\Program.cs:line 26
  InnerException: 

다행히 이에 대한 원인은 다음의 글에서 쉽게 찾을 수 있었습니다.

C#: Accessing PerformanceCounters for the “.NET CLR Memory category”
; http://stackoverflow.com/questions/4705698/c-accessing-performancecounters-for-the-net-clr-memory-category

즉, ^^ 관리자 권한으로 실행해야 한다는 군요.

비-관리자 권한일 때는 다음의 CLR 성능 카운터를 구할 수 있는 반면,

  • .NET CLR Networking
  • MSSQL$SQLEXPRESS:CLR
  • .NET CLR Data
  • .NET CLR Networking 4.0.0.0

관리자 권한인 경우 다음의 범주를 모두 다룰 수 있습니다.

  • .NET CLR Exceptions
  • .NET CLR Networking
  • .NET CLR Loading
  • .NET CLR LocksAndThreads
  • .NET CLR Remoting
  • .NET CLR Security
  • .NET CLR Interop
  • .NET CLR Memory
  • .NET CLR Data
  • .NET CLR Networking 4.0.0.0
  • .NET CLR Jit
  • MSSQL$SQLEXPRESS:CLR

그나저나... 이런 것은 성능 카운터의 부작용이라고 봐야 할 것 같습니다. 왜냐하면, 구하려는 성능 카운터의 대상이 자신과 동일한 exe인 경우일지라도 그 정보를 구할 수 없다는 것인데, 자신에 대한 성능 정보를 접근하는 것에 특별한 권한이 필요하다는 것은 좀 아이러니하죠. 다른 프로세스라면 이해할 수 있지만! ^^





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







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

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

비밀번호

댓글 작성자
 



2013-07-17 11시53분
[ing™] 성능 카운트를 통해 얻는 것이기 때문에 그에 맞는 실행 권한 때문이지 않을까 합니다마. 이건 그냥 유추입니다.
[guest]

... 151  152  153  [154]  155  156  157  158  159  160  161  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1202정성태12/21/201126048오류 유형: 144. The database '...' cannot be opened because it is version 661.
1201정성태12/14/201141115디버깅 기술: 47. .NET Reflector를 이용한 "소스 코드가 없는" 어셈블리 디버깅 [4]
1200정성태12/11/201126953디버깅 기술: 46. Windbg 확장 DLL 만들기 (2) - Debugger Extension API 사용파일 다운로드1
1199정성태12/11/201128372VC++: 55. JNI DLL 컴파일 시 x86과 x64의 Export된 함수의 이름이 왜 다를까요? [2]파일 다운로드1
1198정성태12/9/201132182디버깅 기술: 45. Windbg 확장 DLL 만들기 (1) - 스레드를 강제 종료시키는 명령어 [2]파일 다운로드1
1197정성태12/9/201129954.NET Framework: 282. Shader 강좌와 함께 배워보는 XNA Framework (2) - RenderMonkey의 Shader/Model 파일 연동파일 다운로드2
1196정성태12/9/201133144.NET Framework: 281. Shader 강좌와 함께 배워보는 XNA Framework (1) - 기초 프로그램 구조 [3]파일 다운로드2
1195정성태12/8/201147796오류 유형: 143. DXSDK_Jun10.exe 설치 시 "Error Code: S1023" 오류 해결하는 방법 [4]
1194정성태12/8/201135563개발 환경 구성: 137. Visual C++ 런타임 구성요소에 대한 디버그 버전 설치하는 방법
1193정성태12/8/201122597오류 유형: 142. Windows Phone SDK 7.1 설치 시 Expression Blend 제거를 요구하는 경우
1192정성태12/8/201125622개발 환경 구성: 136. Windows 7 SP1의 IIS에서 사용자 프로파일을 로드하는 방법
1191정성태12/6/201126788.NET Framework: 280. MVC3에서 JavaScriptSerializer 재정의하는 방법파일 다운로드1
1190정성태12/6/201129917오류 유형: 141. Visual C++ 컴파일 오류 - error C2275: 'xxxxx' : illegal use of this type as an expression [1]
1189정성태12/6/201137040VS.NET IDE: 70. Visual Studio에서 프로젝트 로드가 안된다면?
1188정성태12/3/201126144개발 환경 구성: 135. 마이크로소프트 TFS 호스팅 서비스 - Preview [3]
1187정성태12/2/201130800개발 환경 구성: 134. Robocopy 오류 및 종료 코드
1186정성태12/1/201132646.NET Framework: 279. WPF - 그리기 성능 및 Blurring 문제파일 다운로드1
1185정성태11/29/201123399.NET Framework: 278. WPF - Content의 Changed 이벤트에 해당하는게 뭔가요?파일 다운로드1
1184정성태11/29/201126200.NET Framework: 277. F#과 WPF가 어울리지 못하는 근본적인 이유 [2]
1183정성태11/26/201121676오류 유형: 140. Visual Studio 2010 - Floating된 에디트 윈도우가 사라지지 않는 경우 [2]
1182정성태11/25/201157423.NET Framework: 276. 중복 없는 숫자를 랜덤으로 배열하는 방법 [5]파일 다운로드1
1181정성태11/24/201127910디버깅 기술: 44. windbg의 mscordacwks DLL 로드 문제
1180정성태11/23/201137693.NET Framework: 275. 레지스트리 등록 및 Interop DLL 없이 COM 개체 사용하는 방법 [2]파일 다운로드1
1179정성태11/22/201128283.NET Framework: 274. ReaderWriterLockSlim은 언제 쓰는 걸까요? [4]파일 다운로드1
1178정성태11/19/201124778.NET Framework: 273. 설치된 .NET 버전에 민감한 코드를 포함하는 경우, 다중으로 어셈블리를 만들어야 할까요?파일 다운로드1
1177정성태11/18/201130024.NET Framework: 272. 소켓 연결 시간 제한 - 두 번째 이야기 [1]파일 다운로드1
... 151  152  153  [154]  155  156  157  158  159  160  161  162  163  164  165  ...