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

비밀번호

댓글 작성자
 




... 151  152  153  154  155  156  157  158  [159]  160  161  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1169정성태11/10/201133020.NET Framework: 264. 다중 LAN 카드 환경에서 Dns.GetHostAddresses(local)가 반환해 주는 IP의 우선순위는 어떻게 될까요? [4]
1168정성태11/6/201129385오류 유형: 139. TlbImp : error TI0000 : A single valid machine type compatible with the input type library must be specified
1167정성태11/5/201141098개발 환경 구성: 133. Registry 등록 과정 없이 COM 개체 사용 - 두 번째 이야기 [5]파일 다운로드4
1166정성태11/5/201127236.NET Framework: 263. byte[] pData = new byte[100000]로 인한 성능 차이? [1]파일 다운로드1
1165정성태11/3/201132318개발 환경 구성: 132. "Visual Studio Command Prompt (2010)" 명령행에서 2.0 버전의 MSBuild를 구동하는 방법 [2]파일 다운로드1
1164정성태11/1/201130333.NET Framework: 262. .NET 스레드 콜 스택 덤프 (4) - .NET 4.0을 지원하지 않는 MSE 응용 프로그램 원인 분석
1163정성태10/31/201129918.NET Framework: 261. .NET 스레드 콜 스택 덤프 (3) - MSE 소스 코드 개선파일 다운로드1
1162정성태10/30/201129969.NET Framework: 260. .NET 스레드 콜 스택 덤프 (2) - Managed Stack Explorer 소스 코드를 이용한 스택 덤프 구하는 방법파일 다운로드1
1161정성태10/29/201126748.NET Framework: 259. Type.GetMethod - System.Reflection.AmbiguousMatchException파일 다운로드1
1159정성태10/28/201130813.NET Framework: 258. Roslyn 맛보기 - SyntaxTree 조작 [2]
1158정성태10/24/201129506.NET Framework: 257. Roslyn 맛보기 - Roslyn Symbol / Binding API파일 다운로드1
1157정성태10/23/201134027.NET Framework: 256. Roslyn 맛보기 - Syntax Analysis (Roslyn Syntax API) [2]
1156정성태10/23/201132959.NET Framework: 255. Roslyn 맛보기 - Roslyn Services APIs를 이용한 Code Issue 및 Code Action 기능 소개 [1]
1155정성태10/22/201130571.NET Framework: 254. Roslyn 맛보기 - C# Interactive (2)
1154정성태10/22/201137437.NET Framework: 253. Roslyn 맛보기 - C# Interactive (1)
1153정성태10/21/201146503.NET Framework: 252. Roslyn 맛보기 - C# 소스 코드를 스크립트처럼 다루는 방법 [7]파일 다운로드1
1152정성태10/20/201128026.NET Framework: 251. string.GetHashCode는 hash 값을 cache 할까?
1151정성태10/18/201126862Java: 13. 자바도 64비트에서 (2GB) OutOfMemoryException 예외가 발생할까?
1150정성태10/18/201134395.NET Framework: 250. WPF - ComboBox의 SelectionChagned 이벤트파일 다운로드1
1149정성태10/16/201129779.NET Framework: 249. WPF - d:DesignHeight 값을 구할 수 있을까?
1148정성태10/14/201135428Java: 12. 자바에서 LINQ 사용? [7]
1147정성태10/13/201131684.NET Framework: 248. 닷넷에서 지원되는 문자열 인코딩 이름 목록
1146정성태10/12/201137355.NET Framework: 247. LINQ에서의 Max 기능 구현 [10]파일 다운로드1
1144정성태10/10/201133251.NET Framework: 246. WCF - 서버 측에서의 유효한 Timeout 설정파일 다운로드1
1143정성태10/9/201139775.NET Framework: 245. ASP.NET 서버 측 코드에서 페이스북 계정 연동하는 방법
1142정성태10/8/201139382.NET Framework: 244. 윈도우 폼을 열고 닫는 것만으로 메모리 leak이 발생할까? [2]파일 다운로드1
... 151  152  153  154  155  156  157  158  [159]  160  161  162  163  164  165  ...