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

(시리즈 글이 2개 있습니다.)
디버깅 기술: 170. WinDbg Preview 버전부터 닷넷 코어 3.0 이후의 메모리 덤프에 대해 sos.dll 자동 로드
; https://www.sysnet.pe.kr/2/0/12316

오류 유형: 949. WinDbg - .NET Core/5+ 응용 프로그램 디버깅 시 sos 확장을 자동으로 로드하지 못하는 문제
; https://www.sysnet.pe.kr/2/0/13911




WinDbg - .NET Core/5+ 응용 프로그램 디버깅 시 sos 확장을 자동으로 로드하지 못하는 문제

이상하군요, 분명히 예전에는 StoreApp 유형의 WinDbg부터 .NET Core 3.0+ 응용 프로그램에 대해 sos 확장을 자동으로 로딩했었습니다.

WinDbg Preview 버전부터 닷넷 코어 3.0 이후의 메모리 덤프에 대해 sos.dll 자동 로드
; https://www.sysnet.pe.kr/2/0/12316

그런데, 현재의 (1.2502.25002.0 버전의) WinDbg에서 .NET 8 응용 프로그램에 대해 덤프를 로드했더니 다음과 같은 오류가 떨어집니다.

...[생략]...
ModLoad: 00007ffa`feae0000 00007ffa`fefbd000   C:\Program Files\dotnet\shared\Microsoft.NETCore.App\8.0.14\coreclr.dll
The call to LoadLibrary(sos) failed, Win32 error 0n2
    "The system cannot find the file specified."
Please check your debugger configuration and/or network access.
Extension DLL search Path:
    ...[생략]...
You may also consider deploying your extension to the UserExtensions extension gallery repository
located at %LOCALAPPDATA%\dbg\UserExtensions folder. It would require an extension manifest.
Error: Failed to load extension sos

coreclr.dll이 로드된 시점에 WinDbg가 자동으로 sos.dll을 로드하려고 시도한 듯한데, 관련 DLL을 찾지 못한 것입니다. 당연히 sos 관련 명령어가 실행되지도 않고,

0:000>  !soshelp
soshelp is not extension gallery command
No export soshelp found

0:000> !clrstack
clrstack is not extension gallery command
No export clrstack found

DLL 자체도 로딩이 안 돼 있습니다.

0:000> .chain
Extension DLL search Path:
    ...[생략]...
Extension DLL chain:
    CLRComposition: image 10.0.27793.1000, API 0.0.0, 
        [path: C:\Program Files\WindowsApps\Microsoft.WinDbg_1.2502.25002.0_x64__8wekyb3d8bbwe\amd64\winext\CLRComposition.dll]
    dbghelp: image 10.0.27793.1000, API 10.0.6, 
        [path: C:\Program Files\WindowsApps\Microsoft.WinDbg_1.2502.25002.0_x64__8wekyb3d8bbwe\amd64\dbghelp.dll]
    exts: image 10.0.27793.1000, API 1.0.0, 
        [path: C:\Program Files\WindowsApps\Microsoft.WinDbg_1.2502.25002.0_x64__8wekyb3d8bbwe\amd64\WINXP\exts.dll]
    uext: image 10.0.27793.1000, API 1.0.0, 
        [path: C:\Program Files\WindowsApps\Microsoft.WinDbg_1.2502.25002.0_x64__8wekyb3d8bbwe\amd64\winext\uext.dll]
    ntsdexts: image 10.0.27793.1000, API 1.0.0, 
        [path: C:\Program Files\WindowsApps\Microsoft.WinDbg_1.2502.25002.0_x64__8wekyb3d8bbwe\amd64\WINXP\ntsdexts.dll]

참고로, 이러한 오류 메시지는 ".loadby sos coreclr" 명령어의 결과와도 같습니다.

0:000> .loadby sos coreclr
The call to LoadLibrary(C:\Program Files\dotnet\shared\Microsoft.NETCore.App\8.0.14\sos.dll) failed, Win32 error 0n126
    "The specified module could not be found."
Please check your debugger configuration and/or network access.
Extension DLL search Path:
    ...[생략]...
You may also consider deploying your extension to the UserExtensions extension gallery repository
located at %LOCALAPPDATA%\dbg\UserExtensions folder. It would require an extension manifest.
Error: Failed to load extension C:\Program Files\dotnet\shared\Microsoft.NETCore.App\8.0.14\sos.dll

한 가지 약간 다른 점이 있다면 "C:\Program Files\dotnet\shared\Microsoft.NETCore.App\8.0.14\sos.dll"을 명시적으로 로드하려고 시도했다는 것입니다. (해당 위치에는 sos.dll 파일이 없었습니다.)




어쩔 수 없군요, 이렇게 된 이상 sos.dll을 수동으로 로드해야 합니다.

윈도우용 .NET Core 3 이상에서 Windbg의 sos 사용법
; https://www.sysnet.pe.kr/2/0/12641

따라서 dotnet-sos를 설치하고,

// (낮은 버전은 불가능하고,) 높은 버전이라면 지정 가능
// dotnet tool install -g dotnet-sos --version 9.0.607501

c:\temp> dotnet tool install -g dotnet-sos
You can invoke the tool using the following command: dotnet-sos
Tool 'dotnet-sos' (version '9.0.607501') was successfully installed.

이를 통해 sos.dll을 다운로드할 수 있습니다.

c:\temp> echo %USERPROFILE%
C:\Users\testusr

c:\temp;gt; dotnet-sos install
Installing SOS to C:\Users\testusr\.dotnet\sos
Creating installation directory...
Copying files from C:\Users\testusr\.dotnet\tools\.store\dotnet-sos\9.0.607501\dotnet-sos\9.0.607501\tools\net6.0\any\win-x64
Copying files from C:\Users\testusr\.dotnet\tools\.store\dotnet-sos\9.0.607501\dotnet-sos\9.0.607501\tools\net6.0\any\lib
Execute '.load C:\Users\testusr\.dotnet\sos\sos.dll' to load SOS in your Windows debugger.
SOS install succeeded

메시지에 따라 WinDbg에서 다음의 명령어를 내리면 됩니다.

.load C:\Users\testusr\.dotnet\sos\sos.dll

// 또는 환경 변수를 이용

as /e MyEnvVar USERPROFILE
.load ${MyEnvVar}\.dotnet\sos\sos.dll




그건 그렇고, .chain 명령어를 보면 CLRComposition 확장이 눈에 띕니다. ^^

0:000> .extmatch /D /e CLRComposition *
!CLRComposition.clrflush
!CLRComposition.disableclrcomposition
!CLRComposition.enableclrcomposition
!CLRComposition.enableclrplugin
!CLRComposition.forceclrmixedmodeunwind
!CLRComposition.tryunknownmodulesforclrbind

검색해 보면, 겨우 이 정도의 정보만 나오는데요,

// https://learn.microsoft.com/en-us/windows-hardware/drivers/debuggercmds/windbg-release-notes#improved-clr-debugging-experience-without-clrcompositiondll

The redistributable component dbgeng.dll now has improved stack walking support for CLR frames without the need for clrcomposition.dll to be present.


혹시 이에 대한 이력을 알고 계신 분은 덧글 부탁드립니다. ^^




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







[최초 등록일: ]
[최종 수정일: 4/11/2025]

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)
1203정성태12/21/201125674제니퍼 .NET: 18. MEF가 적용된 ASP.NET 웹 사이트를 제니퍼 닷넷으로 모니터링 해본 결과! [6]
1202정성태12/21/201126109오류 유형: 144. The database '...' cannot be opened because it is version 661.
1201정성태12/14/201141154디버깅 기술: 47. .NET Reflector를 이용한 "소스 코드가 없는" 어셈블리 디버깅 [4]
1200정성태12/11/201127069디버깅 기술: 46. Windbg 확장 DLL 만들기 (2) - Debugger Extension API 사용파일 다운로드1
1199정성태12/11/201128378VC++: 55. JNI DLL 컴파일 시 x86과 x64의 Export된 함수의 이름이 왜 다를까요? [2]파일 다운로드1
1198정성태12/9/201132209디버깅 기술: 45. Windbg 확장 DLL 만들기 (1) - 스레드를 강제 종료시키는 명령어 [2]파일 다운로드1
1197정성태12/9/201129996.NET Framework: 282. Shader 강좌와 함께 배워보는 XNA Framework (2) - RenderMonkey의 Shader/Model 파일 연동파일 다운로드2
1196정성태12/9/201133173.NET Framework: 281. Shader 강좌와 함께 배워보는 XNA Framework (1) - 기초 프로그램 구조 [3]파일 다운로드2
1195정성태12/8/201147815오류 유형: 143. DXSDK_Jun10.exe 설치 시 "Error Code: S1023" 오류 해결하는 방법 [4]
1194정성태12/8/201135605개발 환경 구성: 137. Visual C++ 런타임 구성요소에 대한 디버그 버전 설치하는 방법
1193정성태12/8/201122708오류 유형: 142. Windows Phone SDK 7.1 설치 시 Expression Blend 제거를 요구하는 경우
1192정성태12/8/201125744개발 환경 구성: 136. Windows 7 SP1의 IIS에서 사용자 프로파일을 로드하는 방법
1191정성태12/6/201126842.NET Framework: 280. MVC3에서 JavaScriptSerializer 재정의하는 방법파일 다운로드1
1190정성태12/6/201130050오류 유형: 141. Visual C++ 컴파일 오류 - error C2275: 'xxxxx' : illegal use of this type as an expression [1]
1189정성태12/6/201137088VS.NET IDE: 70. Visual Studio에서 프로젝트 로드가 안된다면?
1188정성태12/3/201126194개발 환경 구성: 135. 마이크로소프트 TFS 호스팅 서비스 - Preview [3]
1187정성태12/2/201130845개발 환경 구성: 134. Robocopy 오류 및 종료 코드
1186정성태12/1/201132733.NET Framework: 279. WPF - 그리기 성능 및 Blurring 문제파일 다운로드1
1185정성태11/29/201123406.NET Framework: 278. WPF - Content의 Changed 이벤트에 해당하는게 뭔가요?파일 다운로드1
1184정성태11/29/201126216.NET Framework: 277. F#과 WPF가 어울리지 못하는 근본적인 이유 [2]
1183정성태11/26/201121739오류 유형: 140. Visual Studio 2010 - Floating된 에디트 윈도우가 사라지지 않는 경우 [2]
1182정성태11/25/201157439.NET Framework: 276. 중복 없는 숫자를 랜덤으로 배열하는 방법 [5]파일 다운로드1
1181정성태11/24/201127929디버깅 기술: 44. windbg의 mscordacwks DLL 로드 문제
1180정성태11/23/201137717.NET Framework: 275. 레지스트리 등록 및 Interop DLL 없이 COM 개체 사용하는 방법 [2]파일 다운로드1
1179정성태11/22/201128309.NET Framework: 274. ReaderWriterLockSlim은 언제 쓰는 걸까요? [4]파일 다운로드1
1178정성태11/19/201124830.NET Framework: 273. 설치된 .NET 버전에 민감한 코드를 포함하는 경우, 다중으로 어셈블리를 만들어야 할까요?파일 다운로드1
... 151  152  153  [154]  155  156  157  158  159  160  161  162  163  164  165  ...