Microsoft MVP성태의 닷넷 이야기
오류 유형: 685. WinDbg Preview - error InitTypeRead [링크 복사], [링크+제목 복사],
조회: 8875
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

WinDbg Preview - error InitTypeRead

이상하군요, 다른 컴퓨터에서 남긴 메모리 덤프 파일을 복사해 왔는데 pdb 로드가 안 돼서 이런 오류가 발생합니다.

0:000> !teb
TEB at 00007ff6c278e000
*************************************************************************
***                                                                   ***
***                                                                   ***
***    Either you specified an unqualified symbol, or your debugger   ***
***    doesn't have full symbol information.  Unqualified symbol      ***
***    resolution is turned off by default. Please either specify a   ***
***    fully qualified symbol module!symbolname, or enable resolution ***
***    of unqualified symbols by typing ".symopt- 100". Note that     ***
***    enabling unqualified symbol resolution with network symbol     ***
***    server shares in the symbol path may cause the debugger to     ***
***    appear to hang for long periods of time when an incorrect      ***
***    symbol name is typed or the network symbol server is down.     ***
***                                                                   ***
***    For some commands to work properly, your symbol path           ***
***    must point to .pdb files that have full type information.      ***
***                                                                   ***
***    Certain .pdb files (such as the public OS symbols) do not      ***
***    contain the required information.  Contact the group that      ***
***    provided you with these symbols if you need this command to    ***
***    work.                                                          ***
***                                                                   ***
***    Type referenced: nt!_TEB                                       ***
***                                                                   ***
*************************************************************************
error InitTypeRead( TEB )...

원인 파악을 해보면,

0:000> !sym noisy
noisy mode - symbol prompts on

0:000> .reload /s /f ntdll.dll
SYMSRV:  BYINDEX: 0xB
         c:\symbols
         ntdll.pdb
         6DFD0B387E7941A587A3B64F824B1CAC1
SYMSRV:  UNC: c:\symbols\ntdll.pdb\6DFD0B387E7941A587A3B64F824B1CAC1\ntdll.pdb - path not found
SYMSRV:  UNC: c:\symbols\ntdll.pdb\6DFD0B387E7941A587A3B64F824B1CAC1\ntdll.pd_ - path not found
SYMSRV:  UNC: c:\symbols\ntdll.pdb\6DFD0B387E7941A587A3B64F824B1CAC1\file.ptr - path not found
SYMSRV:  RESULT: 0x80070003
DBGHELP: *http://msdl.microsoft.com/download/symbols\ntdll.pdb - file not found
DBGHELP: *http://msdl.microsoft.com/download/symbols\dll\ntdll.pdb - file not found
DBGHELP: *http://msdl.microsoft.com/download/symbols\symbols\dll\ntdll.pdb - file not found
DBGHELP: ntdll.pdb - file not found
DBGHELP: ntdll - export symbols

************* Symbol Loading Error Summary **************
Module name            Error
ntdll                  The system cannot find the file specified
                The SYMSRV client failed to find a file in the UNC store, or there
                is an invalid UNC store (an invalid path or the pingme.txt file is
                not present in the root directory), or the file is present in the
                symbol server exclusion list.

로컬 캐시에서 찾는 경로에 6DFD0B387E7941A587A3B64F824B1CAC1 값을 포함하고 있으니, 당연히 서버 쪽으로 이런 경로 요청이 있어야 하는데,

http://msdl.microsoft.com/download/symbols/ntdll.pdb/6DFD0B387E7941A587A3B64F824B1CAC1/ntdll.pdb

단순히 /symbols\ntdll.pdb, /symbols\dll\ntdll.pdb, /symbols\symbols\dll\ntdll.pdb에 대한 것만 보입니다. 결국 ntdll.pdb 파일을 찾을 수 없어 명령어 실행에 실패하게 된 것입니다.




대신 "WinDbg Preview (1.0.2007.06001, 엔진 버전 10.0.20153.1000)"가 아닌 일반 버전의 windbg로는 잘 로드가 됩니다.

0:000>  !sym noisy
noisy mode - symbol prompts on

0:000> .reload /s /f ntdll.dll
SYMSRV:  BYINDEX: 0x4
         c:\symbols*http://msdl.microsoft.com/download/symbols
         ntdll.pdb
         6DFD0B387E7941A587A3B64F824B1CAC1
SYMSRV:  UNC: c:\symbols\ntdll.pdb\6DFD0B387E7941A587A3B64F824B1CAC1\ntdll.pdb - file not found
SYMSRV:  UNC: c:\symbols\ntdll.pdb\6DFD0B387E7941A587A3B64F824B1CAC1\ntdll.pd_ - file not found
SYMSRV:  UNC: c:\symbols\ntdll.pdb\6DFD0B387E7941A587A3B64F824B1CAC1\file.ptr - file not found
SYMSRV:  HTTPGET: /download/symbols/ntdll.pdb/6DFD0B387E7941A587A3B64F824B1CAC1/ntdll.pdb
SYMSRV:  HttpQueryInfo: 801900c8 - HTTP_STATUS_OK
SYMSRV:  /download/symbols/ntdll.pdb/6DFD0B387E7941A587A3B64F824B1CAC1/ntdll.pdb
...[생략]...

혹은 그냥 로그로부터 알아낸 "6DFD0B387E7941A587A3B64F824B1CAC1" 값을 이용해 직접 다운로드 후 로컬에 경로를 맞춰 저장해도 WinDbg Preview에서 사용할 수 있습니다.




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







[최초 등록일: ]
[최종 수정일: 11/24/2020]

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

비밀번호

댓글 작성자
 




... 61  62  63  64  [65]  66  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12022정성태9/12/201915800개발 환경 구성: 458. C# 8.0 (Preview) 신규 문법을 위한 개발 환경 구성 [3]
12021정성태9/12/201927750도서: 시작하세요! C# 8.0 프로그래밍 [4]
12020정성태9/11/201914511VC++: 134. SYSTEMTIME 값 기준으로 특정 시간이 지났는지를 판단하는 함수
12019정성태9/11/20199873Linux: 23. .NET Core + 리눅스 환경에서 Environment.CurrentDirectory 접근 시 주의 사항
12018정성태9/11/20198860오류 유형: 567. IIS - Unrecognized attribute 'targetFramework'. Note that attribute names are case-sensitive. (D:\lowSite4\web.config line 11)
12017정성태9/11/201911930오류 유형: 566. 비주얼 스튜디오 - Failed to register URL "http://localhost:6879/" for site "..." application "/". Error description: Access is denied. (0x80070005)
12016정성태9/5/201912868오류 유형: 565. git fetch - warning: 'C:\ProgramData/Git/config' has a dubious owner: '(unknown)'.
12015정성태9/3/201916749개발 환경 구성: 457. 윈도우 응용 프로그램의 Socket 연결 시 time-out 시간 제어
12014정성태9/3/201911204개발 환경 구성: 456. 명령행에서 AWS, Azure 등의 원격 저장소에 파일 관리하는 방법 - cyberduck/duck 소개
12013정성태8/28/201913986개발 환경 구성: 455. 윈도우에서 (테스트) 인증서 파일 만드는 방법 [3]
12012정성태8/28/201917873.NET Framework: 859. C# - HttpListener를 이용한 HTTPS 통신 방법
12011정성태8/27/201916112사물인터넷: 57. C# - Rapsberry Pi Zero W와 PC 간 Bluetooth 통신 예제 코드파일 다운로드1
12010정성태8/27/201911353VS.NET IDE: 138. VSIX - DTE.ItemOperations.NewFile 메서드에서 템플릿 이름을 다국어로 설정하는 방법
12009정성태8/26/201911947.NET Framework: 858. C#/Windows - Clipboard(Ctrl+C, Ctrl+V)가 동작하지 않는다면?파일 다운로드1
12008정성태8/26/201911734.NET Framework: 857. UWP 앱에서 SQL Server 데이터베이스 연결 방법
12007정성태8/24/201910881.NET Framework: 856. .NET Framework 버전을 올렸을 때 오류가 발생할 수 있는 상황
12006정성태8/23/201914105디버깅 기술: 129. guidgen - Encountered an improper argument. 오류 해결 방법 (및 windbg 분석) [1]
12005정성태8/13/201912061.NET Framework: 855. 닷넷 (및 VM 계열 언어) 코드의 성능 측정 시 주의할 점 [2]파일 다운로드1
12004정성태8/12/201919846.NET Framework: 854. C# - 32feet.NET을 이용한 PC 간 Bluetooth 통신 예제 코드 [14]
12003정성태8/12/201912576오류 유형: 564. Visual C++ 컴파일 오류 - fatal error C1090: PDB API call failed, error code '3'
12002정성태8/12/201911569.NET Framework: 853. Excel Sheet를 WinForm에서 사용하는 방법 - 두 번째 이야기 [5]
12001정성태8/10/201916079.NET Framework: 852. WPF/WinForm에서 UWP의 기능을 이용해 Bluetooth 기기와 Pairing하는 방법 [1]
12000정성태8/9/201914940.NET Framework: 851. WinForm/WPF에서 Console 창을 띄워 출력하는 방법파일 다운로드1
11999정성태8/1/201910695오류 유형: 563. C# - .NET Core 2.0 이하의 Unix Domain Socket 사용 시 System.IndexOutOfRangeException 오류
11998정성태7/30/201911904오류 유형: 562. .NET Remoting에서 서비스 호출 시 SYN_SENT로 남는 현상파일 다운로드1
11997정성태7/30/201913447.NET Framework: 850. C# - Excel(을 비롯해 Office 제품군) COM 객체를 제어 후 Excel.exe 프로세스가 남아 있는 문제 [2]파일 다운로드1
... 61  62  63  64  [65]  66  67  68  69  70  71  72  73  74  75  ...