Microsoft MVP성태의 닷넷 이야기
.NET Framework: 372. PerformanceCounter - Category does not exist. [링크 복사], [링크+제목 복사],
조회: 26538
글쓴 사람
정성태 (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]

... 181  182  183  184  185  186  187  188  189  190  191  [192]  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
174정성태10/31/200519423.NET Framework: 50. app.config 예시 [1]
173정성태10/30/200518110스크립트: 5. 스크립트 호출 관계
172정성태10/25/200526493.NET Framework: 49. ASP.NET 오류 유형 : 액세스가 거부되었습니다. [2]
171정성태11/14/200528271VC++: 19. 다국어 지원: setlocale( LC_TIME, "" ) 관련 [1]
170정성태11/14/200522845VS.NET IDE: 34. Visual SourceSafe 2005: Remote Internet Access over HTTP : 80 이외의 포트를 지정
206정성태2/1/200619326    답변글 VC++: 34.1. [추가]: Internet Access Plug-in 사용 시 유의 사항
168정성태11/14/200520429VS.NET IDE: 33. IIS 6.0 AppPool 설정 - Enable rapid-fail protection
169정성태10/14/200522153    답변글 VS.NET IDE: 33.1. Enable rapid-fail protection 상황 재현 방법
166정성태11/14/200519364.NET Framework: 48. IE를 죽이는 스크립트 소스
165정성태11/14/200520059.NET Framework: 47. MOM (Microsoft Operations Manager) 2005 서버 설치 가이드
164정성태11/14/200517244.NET Framework: 46. 도메인에 속한 컴퓨터의 Local Computer Policy 변경 방법
162정성태10/3/200519812.NET Framework: 45. VS.NET 2005 IDE에서 Web App를 .NET 2.0 (x64) 머신에 배포
161정성태11/14/200522607.NET Framework: 44. IIS 관리자에서 ASP.NET 탭이 없는 경우.
159정성태9/28/200518651VS.NET IDE: 32. Virtual Server 2005 64bit SP1 Beta 테스트 [2]
163정성태10/3/200516636    답변글 VS.NET IDE: 32.1. 왜...?
158정성태11/14/200518988VS.NET IDE: 31. SQL 2005 - A connection was successfully established with the server
157정성태9/21/200518889기타: 10. SQL2000 설치 시, Invalid Product Key 오류
156정성태9/16/200520839.NET Framework: 43. Wisptis.exe 프로세스
155정성태5/31/200517144.NET Framework: 42. .NET Installer Class에서 Install 메서드 - 설정 사항들 알아내는 코드
154정성태5/13/200516100VS.NET IDE: 30. Windows 2003 for x64에 추가된 레지스트리 Run 노드
152정성태5/5/200519511VC++: 18. VC++ 7.0에서부터 ? : 연산자 처리가 바뀌었습니다.
153정성태5/12/200519762    답변글 VC++: 18.1. VC++ 8.0에서부터 바뀐 CRT 소개
151정성태5/5/200522632VC++: 17. DLL에 export 된 C++ 클래스 멤버 함수 파라미터형 정보 알아내는 방법
150정성태5/5/200523734.NET Framework: 41. 태그 사이의 값을 추출하는 정규식
149정성태5/5/200520269.NET Framework: 40. 데이터그리드에서 콤보박스 쓸 수 있는 방법
148정성태5/5/200520774.NET Framework: 39. DataSet 방식을 RecordSet으로 구현하는 방법.
... 181  182  183  184  185  186  187  188  189  190  191  [192]  193  194  195  ...