Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

DebugView로 인한 System.Diagnostics.Trace.WriteLine 멈춤(Hang) 현상

희한한 현상이 발생했습니다. 갑자기 웹 사이트의 모든 요청이 블록킹(blocking)되는 장애가 발생한 것입니다. 그 상태의 스레드 콜스택을 확인해 보니 다음과 같았는데요.

at System.Threading.Monitor.Enter(Object obj)
at System.Diagnostics.TraceInternal.WriteLine(String message)
at WebSiteTest.About.Page_Load(Object sender, EventArgs e) in d:\WebSiteTest\About.aspx.cs:line 23
at System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e)
at System.Web.UI.Control.LoadRecursive()
...[생략]...
at System.Web.Hosting.PipelineRuntime.ProcessRequestNotification(IntPtr managedHttpContext, IntPtr nativeRequestContext, IntPtr moduleData, Int32 flags)

어허... ^^ 살다 보니 Trace.WriteLine 메서드에서 락이 걸리는 것도 보게 되는군요.

현상의 원인은 해당 서버에 문제 해결을 위해 켜두고는 잊어버렸던 DebugView(dbgview.exe)가 문제였습니다. 작업 관리자로 확인해 보니 이 때의 dbgview.exe 메모리는 1.5GB에 육박하고 있었고,

dbg_view_0.png

화면에서는 로그 항목을 추가할 수 없다는 오류가 발생하고 있었습니다.

dbg_view_1.png

Error adding item .... to list view

이로 인해 웹 사이트에서 호출하고 있던 Trace.WriteLine의 모든 스레드가 Monitor.Enter에서 빠져나오지 못하고 데드락 현상에 빠져버린 것입니다. 무심코 띄워놓은 dbgview.exe가 이런 사태를 불러올 줄 누가 알았겠습니까! ^^;

참고로, 이 현상을 미연에 방지하는 차원에서 DebugView 프로그램의 "Optiosn" / "History Depth..."를 적절한 수치로 제한(예를 들어 10,000)해 두는 습관을 들이는 것이 권장됩니다. ^^




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







[최초 등록일: ]
[최종 수정일: 7/17/2021]

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

비밀번호

댓글 작성자
 




... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
265정성태6/1/200625454디버깅 기술: 3. 원격 컴퓨터 디버깅 - VPC 설정
314정성태8/11/200622738    답변글 디버깅 기술: 3.1. Managed 원격 디버깅과 WinDBG 원격 디버깅
264정성태6/1/200631740오류 유형: 6. [VC++ 컴파일] already defined in ntdll.lib(ntdll.dll)
263정성태6/1/200632808디버깅 기술: 2. 커널 구조체 살펴보기 [5]
262정성태6/1/200625295오류 유형: 5. [설치] WinFX Beta2 - 설치시 문제점 해결
261정성태6/1/200621537웹: 3. IIS 6.0 - AppPool을 활용하여 실 서버(운영 서버)에서 디버깅
258정성태6/1/200629468디버깅 기술: 1. 디버깅 방법 - CLR 프로파일러 [1]파일 다운로드1
274정성태6/7/200622515    답변글 디버깅 기술: 1.1. 디버깅 방법 - CLR 프로파일러 ( on Vista )
254정성태6/1/200618850개발 환경 구성: 2. VPC에 Vista 설치하는 방법 [2]
255정성태6/1/200618694    답변글 개발 환경 구성: 2.1. msconfig 설정과 Windows Activation
259정성태6/1/200617640    답변글 개발 환경 구성: 2.2. Vista VPC에 터미널 서비스 - 원격 접속
253정성태6/1/200615803기타: 14. .NET 2.0 이 지원되는 NDoc 2.0 을 배포합니다.
251정성태6/1/200618873오류 유형: 4. [OS 지원 API] SHParseDisplayName과 Windows 2000
252정성태6/1/200618545    답변글 오류 유형: 4.1. NET BCL 에서 제공되는 FolderBrowserDialog [2]
249정성태6/1/200618206.NET Framework: 71. VB.NET 이외의 언어에서 My 네임스페이스 사용
250정성태6/1/200620995    답변글 .NET Framework: 71.1. VB.NET 이외의 언어에서 My 네임스페이스 사용
248정성태6/1/200619290기타: 13. Code Center Premium에서 Win32 API 소스 찾기
245정성태6/1/200626691오류 유형: 3. [C# / VC++] error C2146: syntax error : missing ';' before identifier 'GetType'
247정성태5/3/200623906    답변글 .NET Framework: 3.1. Interface를 사용하면. [1]
242정성태6/1/200624455오류 유형: 2. [COM+] CreateObject 와 HTTP 500 - Internal server error
243정성태6/1/200621843    답변글 오류 유형: 2.1. [COM+] Resolve Partial Assembly failed for Microsoft.VC80.CRT.mui
244정성태6/1/200623287    답변글 오류 유형: 2.2. [COM+] Server object error 'ASP 0178 : 80070005'
240정성태6/1/200621229스크립트: 9. setTimeout 과 jscript/vbscript 혼용 문제
239정성태6/1/200622348COM 개체 관련: 18. Internet Explorer는 Out-of-process COM 개체입니다.
238정성태6/1/200624252개발 환경 구성: 1. batch 파일에서 실행한 exe에서 batch 실행 문맥의 환경 변수 설정 [3]
236정성태6/1/200645006오류 유형: 1. [.NET COM+] UnauthorizedAccessException: 레지스트리 키 HKEY_CLASSES_ROOT\.... 에 대한 액세스가 거부되었습니다
... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...