Microsoft MVP성태의 닷넷 이야기
.NET Framework: 170. PerformanceCounter의 RawValue/NextValue()에서 멈춤 현상 [링크 복사], [링크+제목 복사],
조회: 29071
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
PerformanceCounter의 RawValue/NextValue()에서 멈춤 현상


제법 힘겨운 현상이 하나 발생했습니다. ASP.NET 응용 프로그램에 성능 카운터(PerformanceCounter)를 이용하여 값을 얻어오는 코드를 넣어두었는데,

perfCounter = new PerformanceCounter(); // How expensive is it to create a Windows performance counter?
perfCounter.CategoryName = perfProviderName;
perfCounter.CounterName = s;
perfCounter.InstanceName = instanceName;

long value1 = perfCounter.RawValue; 
/*
또는
float value = perfCounters[i].NextValue();
*/

평상 시에는 정상적으로 값을 가져오다가, 작업자 프로세스(Worker Process)가 재시작(Recycle)되어 새로 시작된 프로세스에서 실행될 때는 RawValue / NextValue()에서 멈춤(hang)현상이 발생했습니다. 약 4분 정도 스레드가 멈추는데... 꽤나 치명적이죠!

관련해서 해결책이 있는지 구글링을 해보았는데,

PerformanceCounter Constructor Horribly Slow
; http://www.pluralsight.com/community/blogs/craig/archive/2005/06/21/11596.aspx

위의 글은 PerformanceCounter의 생성자에서 대기 시간이 길다는 거였지만 나름 의미있는 정보가 있었습니다.


I can shed some light on these issues. PerformanceCounters use a machine wide memory mapped file to publish perf counter data. That file contains an object graph and various places we use as spinlocks.
The problem comes in when processes get killed unexpectedly. A process which dies while holding a spinlock won't release it, meaning the next process gets blocked. After spinning 10000 times, we assume some process died and continue on, so we won't block forever - 4 minutes on your machine. My guess is that IIS is terminating your app when it resets it



즉, asp.net에서 재시작하면 기존 프로세스에서 해제되지 않은 성능 카운터 리소스가 문제가 될수 있다는 것인데요. 위의 댓글에 보면 Whidbey 정식 버전에서는 고쳤다고 되어 있지만, 다시 이후의 댓글에 보면 현상이 여전하다고 합니다.

그다음 검색된 글에서는,

PerformanceCounter causes all application threads to hang 
; http://connect.microsoft.com/VisualStudio/feedback/ViewFeedback.aspx?FeedbackID=94605

지연 시간이 저 같은 경우에는 4분 정도였는데, 위의 글에서는 2분 정도라고 합니다. 어쨌든 해결책은 없군요.

더 이상의 검색은 포기하고, 다시 원점으로 돌아와서 PerformanceCounter를 세세하게 뜯어보기 시작했습니다. 오호... 그런데, InstanceLifetime이라는 속성이 있습니다.

// Summary:
//     Specifies the lifetime of a performance counter instance.
public enum PerformanceCounterInstanceLifetime
{
    // Summary:
    //     Remove the performance counter instance when no counters are using the process
    //     category.
    Global = 0,
    //
    // Summary:
    //     Remove the performance counter instance when the process is closed.
    Process = 1,
}

이 속성을 Process로 하면, ReadOnly 속성은 반드시 false로 해야 합니다. (사실, "쓰기" 작업이 필요없지만.) 그래서 다음과 같이 코딩을 하니 문제가 해결되었습니다.

perfCounters = new PerformanceCounter();
perfCounters.CategoryName = perfProviderName;
perfCounters.InstanceName = instanceName;
perfCounters.CounterName = s;

perfCounters.InstanceLifetime = PerformanceCounterInstanceLifetime.Process;
perfCounters.ReadOnly = false;

정확한 내부 작업은 어떻게 된 것인지 확실치는 않지만, 이번엔 여기까지만! ^^



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/15/2023]

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

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  113  114  115  116  117  118  [119]  120  ...
NoWriterDateCnt.TitleFile(s)
10949정성태4/28/201619878.NET Framework: 575. SharedDomain과 JIT 컴파일파일 다운로드1
10948정성태4/28/201623821.NET Framework: 574. .NET - 눈으로 확인하는 SharedDomain의 동작 방식 [3]파일 다운로드1
10947정성태4/27/201621684.NET Framework: 573. .NET CLR4 보안 모델 - 4. CLR4 보안 모델에서의 조건부 APTCA 역할파일 다운로드1
10946정성태4/26/201624510VS.NET IDE: 106. Visual Studio 2015 확장 - INI 파일을 위한 사용자 정의 포맷 기능 (Syntax Highlighting)파일 다운로드1
10945정성태4/26/201618271오류 유형: 327. VSIX 프로젝트 빌드 시 The "VsTemplatePaths" task could not be loaded from the assembly 오류 발생
10944정성태4/22/201619514디버깅 기술: 80. windbg - 풀 덤프 파일로부터 텍스트 파일의 내용을 찾는 방법
10943정성태4/22/201624370디버깅 기술: 79. windbg - 풀 덤프 파일로부터 .NET DLL을 추출/저장하는 방법 [1]
10942정성태4/19/201619672디버깅 기술: 78. windbg 사례 - .NET 예외가 발생한 시점의 오류 분석 [1]
10941정성태4/19/201619583오류 유형: 326. Error MSB8020 - The build tools for v120_xp (Platform Toolset = 'v120_xp') cannot be found.
10940정성태4/18/201622849Windows: 116. 프로세스 풀 덤프 시간을 줄여 주는 Process Reflection [3]
10939정성태4/18/201623878.NET Framework: 572. .NET APM 비동기 호출의 Begin...과 End... 조합 [3]파일 다운로드1
10938정성태4/13/201623445오류 유형: 325. 파일 삭제 시 오류 - Error 0x80070091: The directory is not empty.
10937정성태4/13/201631667Windows: 115. UEFI 모드로 윈도우 10 설치 가능한 USB 디스크 만드는 방법
10936정성태4/8/201642353Windows: 114. 삼성 센스 크로노스 7 노트북의 운영체제를 USB 디스크로 새로 설치하는 방법 [3]
10935정성태4/7/201626652웹: 32. Edge에서 Google Docs 문서 편집 시 한영 전환키가 동작 안하는 문제
10934정성태4/5/201625379디버깅 기술: 77. windbg의 콜스택 함수 인자를 쉽게 확인하는 방법 [1]
10933정성태4/5/201630988.NET Framework: 571. C# - 스레드 선호도(Thread Affinity) 지정하는 방법 [8]파일 다운로드1
10932정성태4/4/201623282VC++: 96. C/C++ 식 평가 - printf("%d %d %d\n", a, a++, a);
10931정성태3/31/201623557개발 환경 구성: 283. Hyper-V 내에 구성한 Active Directory 환경의 시간 구성 방법 [3]
10930정성태3/30/201621511.NET Framework: 570. .NET 4.5부터 추가된 CLR Profiler의 실행 시 Rejit 기능
10929정성태3/29/201631620.NET Framework: 569. ServicePointManager.DefaultConnectionLimit의 역할파일 다운로드1
10928정성태3/28/201637335.NET Framework: 568. ODP.NET의 완전한 닷넷 버전 Oracle ODP.NET, Managed Driver [2]파일 다운로드1
10927정성태3/25/201626543.NET Framework: 567. System.Net.ServicePointManager의 DefaultConnectionLimit 속성 설명
10926정성태3/24/201626083.NET Framework: 566. openssl의 PKCS#1 PEM 개인키 파일을 .NET RSACryptoServiceProvider에서 사용하는 방법 [10]파일 다운로드1
10925정성태3/24/201620386.NET Framework: 565. C# - Rabin-Miller 소수 생성 방법을 이용하여 RSACryptoServiceProvider의 개인키를 직접 채워보자 - 두 번째 이야기파일 다운로드1
10924정성태3/22/201621037오류 유형: 324. Visual Studio에서 Azure 클라우드 서비스 생성 시 Failed to initialize the PowerShell host 에러 발생
... 106  107  108  109  110  111  112  113  114  115  116  117  118  [119]  120  ...