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

비밀번호

댓글 작성자
 




... 166  167  168  169  170  171  172  173  174  175  176  177  178  179  [180]  ...
NoWriterDateCnt.TitleFile(s)
518정성태7/26/200730113오류 유형: 43. System.ComponentModel.LicenseException [1]
517정성태7/19/200718349개발 환경 구성: 26. VPC - 일반 사용자 계정으로 구동
516정성태7/19/200721579오류 유형: 42. TFS - Error loading menu: Index was outside the bounds of the array [2]
515정성태7/18/200729468오류 유형: 41. SSL 서버 자격 증명을 만드는 동안 심각한 오류가 발생했습니다.
514정성태7/14/200722026Team Foundation Server: 19. Orcas에서 개선되는 TFS 기능들
513정성태7/4/200733217.NET Framework: 91. Foreground Thread / Background Thread [1]
512정성태6/27/200722811오류 유형: 40. error PRJ0050: Failed to register output.
511정성태6/25/200730970.NET Framework: 90. XmlSerializer 생성자의 실행 속도를 올리는 방법 [2]
510정성태6/25/200746147디버깅 기술: 15. First-Chance Exception
508정성태6/21/200729027Team Foundation Server: 18. Team Build에 사용되는 각종 Property 값 [4]
507정성태6/11/200726605VS.NET IDE: 50. Orcas - UAC 설정 관련
506정성태6/9/200721534오류 유형: 39. VC Package not available or not registered
505정성태6/9/200721195오류 유형: 38. Visual SourceSafe - DB 잠김 오류
504정성태6/9/200726490오류 유형: 37. Visual SourceSafe - Anaylze 도중 비정상 종료
503정성태6/7/200729218VS.NET IDE: 49. Orcas - VC++ 다중 소스 동시 컴파일 옵션: /MP
502정성태6/7/200724014VS.NET IDE: 48. Orcas - VC++ 프로젝트 마이그레이션
500정성태6/4/200732761VS.NET IDE: 47. Orcas - Web Browser Debugger를 이용한 보호 모드의 ActiveX 컨트롤 디버깅
499정성태6/3/200725344VS.NET IDE: 46. Orcas - ComUtil로 인한 증분(/INCREMENTAL) 링크 옵션 사용 제한파일 다운로드1
498정성태5/31/200719838Windows: 26. 스마트 카드 암호 바꾸는 방법.
497정성태5/31/200723276오류 유형: 36. SQL 2005 - DB 속성창 띄울 때 오류
496정성태5/29/200721273VS.NET IDE: 45. VS.NET 2005/Orcas 솔루션 파일과 UAC
495정성태5/28/200723665VS.NET IDE: 44. Orcas와 VS.NET 2005의 혼합 개발 [1]
494정성태5/26/200727980오류 유형: 35. 비스타 탐색기 - 특정 파일을 오른쪽 마우스 클릭했을 때, 비정상 종료되는 문제
493정성태5/26/200726992오류 유형: 34. Windows Server 2008 : CA 인증서 발급 실패
492정성태5/23/200726503.NET Framework: 89. ManagedThreadId - 두 번째 이야기 [5]파일 다운로드1
491정성태5/21/200726621.NET Framework: 88. ManagedThreadId ? [4]
... 166  167  168  169  170  171  172  173  174  175  176  177  178  179  [180]  ...