Microsoft MVP성태의 닷넷 이야기
오류 유형: 460. windbg - sos 명령어 수행 시 c0000006 오류 발생 [링크 복사], [링크+제목 복사],
조회: 17582
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

windbg - sos 명령어 수행 시 c0000006 오류 발생

!clrstack은 잘 되는데,

0:350> !clrstack 
OS Thread Id: 0x1544 (350)
ESP       EIP     
4cdbee34 7c9683ac [HelperMethodFrame: 4cdbee34] 
4cdbeea0 062c6fed System.String.ToCharArray(Int32, Int32)
4cdbeec4 062c6b39 System.Text.StringBuilder.AppendFormat(System.IFormatProvider, System.String, System.Object[])
4cdbef0c 0ee0a58e System.Diagnostics.StackTrace.ToString(TraceFormat)
4cdbef64 0ee0e052 System.Diagnostics.StackTrace.ToString()
4cdbef68 2b8e6ec5 TestApp.ThreadDumper.GetCallStack(System.Threading.Thread, Boolean ByRef)
4cdbf010 090d41b4 TestApp.AutoCallStackThread.dumpRepeatCallStack(TestApp.CancellableThread)
4cdbf0fc 090d2f95 TestApp.AutoCallStackThread.repeatCallStackFunc(System.Object)
4cdbf158 08c7688b System.Threading.ThreadHelper.ThreadStart_Context(System.Object)
4cdbf168 08c76382 System.Threading.ExecutionContext.runTryCode(System.Object)
4cdbf598 79e71b4c [HelperMethodFrame_PROTECTOBJ: 4cdbf598] System.Runtime.CompilerServices.RuntimeHelpers.ExecuteCodeWithGuaranteedCleanup(TryCode, CleanupCode, System.Object)
4cdbf600 08c758dc System.Threading.ExecutionContext.RunInternal(System.Threading.ExecutionContext, System.Threading.ContextCallback, System.Object)
4cdbf61c 08c756b7 System.Threading.ExecutionContext.Run(System.Threading.ExecutionContext, System.Threading.ContextCallback, System.Object)
4cdbf634 08c75603 System.Threading.ThreadHelper.ThreadStart(System.Object)
4cdbf860 79e71b4c [GCFrame: 4cdbf860] 
4cdbfb50 79e71b4c [ContextTransitionFrame: 4cdbfb50] 

-a 옵션을 넣는 경우 이런 오류가 발생할 수 있습니다.

0:350> !clrstack -a
OS Thread Id: 0x1544 (350)
ESP       EIP     
4cdbee34 7c9683ac [HelperMethodFrame: 4cdbee34] 
4cdbeea0 062c6fed System.String.ToCharArray(Int32, Int32)c0000006 Exception in f:\dump\sos.dll.clrstack debugger extension.
      PC: 638d96f0  VA: 638d96f0  R/W: 8  Parameter: c000026e

제 경험으로 볼 때, 저렇게 sos.dll에서 오류가 발생하는 경우는 예전 버전의 sos.dll을 사용할 때입니다. 이런 식으로 windbg에서 c0000006 오류가 발생하면 그 이후의 명령들이 모두 먹통이 됩니다. 즉, dso와 같은 명령어를 수행하려고 해도 다음과 같이 나옵니다.

0:350> !dso
c0000006 Exception in f:\dump\sos.dll.dso debugger extension.
      PC: 638daa00  VA: 638daa00  R/W: 8  Parameter: c000026e

재미있는 것은, 이럴 때 당황하지 마시고 ^^ windbg를 다시 실행해 덤프를 로드하면 종종 잘 되는 경우가 있습니다. 심지어 위에서 !clrstack -a 명령어 수행 시 c000026e 오류가 발생했지만 다시 로드하고 나서는 그것조차도 정상적으로 실행되기도 합니다.




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







[최초 등록일: ]
[최종 수정일: 4/9/2018]

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)
11150정성태2/21/201719353.NET Framework: 645. Visual Studio Fakes 기능에서 Shim... 클래스가 생성되지 않는 경우 [5]
11149정성태2/21/201723057오류 유형: 378. A 64-bit test cannot run in a 32-bit process. Specify platform as X64 to force test run in X64 mode on X64 machine.
11148정성태2/20/201721975.NET Framework: 644. AppDomain에 대한 단위 테스트 시 알아야 할 사항
11147정성태2/19/201721206오류 유형: 377. Windows 10에서 Fake 어셈블리를 생성하는 경우 빌드 시 The type or namespace name '...' does not exist in the namespace 컴파일 오류 발생
11146정성태2/19/201719901오류 유형: 376. Error VSP1033: The file '...' does not contain a recognized executable image. [2]
11145정성태2/16/201721356.NET Framework: 643. 작업자 프로세스(w3wp.exe)가 재시작되는 시점을 알 수 있는 방법 - 두 번째 이야기 [4]파일 다운로드1
11144정성태2/6/201724763.NET Framework: 642. C# 개발자를 위한 Win32 DLL export 함수의 호출 규약 (부록 1) - CallingConvention.StdCall, CallingConvention.Cdecl에 상관없이 왜 호출이 잘 될까요?파일 다운로드1
11143정성태2/5/201722111.NET Framework: 641. [Out] 형식의 int * 인자를 가진 함수에 대한 P/Invoke 호출 방법파일 다운로드1
11142정성태2/5/201730136.NET Framework: 640. 닷넷 - 배열 크기의 한계 [2]파일 다운로드1
11141정성태1/31/201724423.NET Framework: 639. C# 개발자를 위한 Win32 DLL export 함수의 호출 규약 (4) - CLR JIT 컴파일러의 P/Invoke 호출 규약 [1]파일 다운로드1
11140정성태1/27/201720170.NET Framework: 638. RSAParameters와 RSA파일 다운로드1
11139정성태1/22/201722898.NET Framework: 637. C# 개발자를 위한 Win32 DLL export 함수의 호출 규약 (3) - x64 환경의 __fastcall과 Name mangling [1]파일 다운로드1
11138정성태1/20/201721195VS.NET IDE: 113. 프로젝트 생성 시부터 "Enable the Visual Studio hosting process" 옵션을 끄는 방법 - 두 번째 이야기 [3]
11137정성태1/20/201719857Windows: 135. AD에 참여한 컴퓨터로 RDP 연결 시 배경 화면을 못 바꾸는 정책
11136정성태1/20/201719064오류 유형: 375. Hyper-V 내에 구성한 Active Directory 환경의 시간 구성 방법 - 두 번째 이야기
11135정성태1/20/201720055Windows: 134. Windows Server 2016의 작업 표시줄에 있는 시계가 사라졌다면? [1]
11134정성태1/20/201727450.NET Framework: 636. System.Threading.Timer를 이용해 타이머 작업을 할 때 유의할 점 [5]파일 다운로드1
11133정성태1/20/201723589.NET Framework: 635. C# 개발자를 위한 Win32 DLL export 함수의 호출 규약 (2) - x86 환경의 __fastcall [1]파일 다운로드1
11132정성태1/19/201735111.NET Framework: 634. C# 개발자를 위한 Win32 DLL export 함수의 호출 규약 (1) - x86 환경에서의 __cdecl, __stdcall에 대한 Name mangling [1]파일 다운로드1
11131정성태1/13/201724001.NET Framework: 633. C# - IL 코드 분석을 위한 팁 [2]
11130정성태1/11/201724537.NET Framework: 632. x86 실행 환경에서 SECURITY_ATTRIBUTES 구조체를 CreateEvent에 전달할 때 예외 발생파일 다운로드1
11129정성태1/11/201728903.NET Framework: 631. async/await에 대한 "There Is No Thread" 글의 부가 설명 [9]파일 다운로드1
11128정성태1/9/201723297.NET Framework: 630. C# - Interlocked.CompareExchange 사용 예제 [3]파일 다운로드1
11127정성태1/8/201722915기타: 63. (개발자를 위한) Visual Studio의 "with MSDN" 라이선스 설명
11126정성태1/7/201727618기타: 62. Edge 웹 브라우저의 즐겨찾기(Favorites)를 편집/백업/복원하는 방법 [1]파일 다운로드1
11125정성태1/7/201724478개발 환경 구성: 310. IIS - appcmd.exe를 이용해 특정 페이지에 클라이언트 측 인증서를 제출하도록 설정하는 방법
... 106  107  108  109  110  [111]  112  113  114  115  116  117  118  119  120  ...