Microsoft MVP성태의 닷넷 이야기
오류 유형: 685. WinDbg Preview - error InitTypeRead [링크 복사], [링크+제목 복사],
조회: 16159
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 136  137  138  139  140  [141]  142  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1530정성태11/5/201327471기타: 38. 오픈소스로 풀린 하드 디스크 관리 도구 - WindowSMART
1529정성태11/5/201323354오류 유형: 192. SQL 서버 - The transaction log for database '...' is full due to 'LOG_BACKUP'.
1528정성태11/5/201328943디버깅 기술: 58. windbg 분석 사례 - WPF 응용 프로그램의 UI가 반응하지 않는 문제 [5]
1527정성태11/4/201326573VC++: 72. error MIDL2311 - mktyplib compatability mode 컴파일 오류
1526정성태11/3/201323267디버깅 기술: 57. C# - double 값에 대한 windbg 확인
1525정성태11/2/201329664.NET Framework: 391. C# - EXE/DLL로부터 추출한 이미지/아이콘의 배경색 투명 처리 [8]
1524정성태11/2/201330496기타: 37. 프로그램에 보여지는 리소스(예: 아이콘) 추출하는 방법 [1]
1523정성태11/2/201326878VS.NET IDE: 81. Visual Studio 확장 도구 AttachToW3WP - w3wp.exe에 대한 디버거 연결을 자동화하는 도구 [2]
1522정성태11/1/201323457VS.NET IDE: 80. IIS 8.0/8.5 - Global.asax.cs처럼 초기에 실행되는 코드에 Breakpoint를 잡는 방법
1521정성태11/1/201329308VS.NET IDE: 79. IIS 7.5 - Global.asax.cs처럼 초기에 실행되는 코드에 Breakpoint를 잡는 방법
1520정성태10/31/201323717오류 유형: 191. Visual Studio 2010 - 웹 애플리케이션 생성 시 "The project type is not supported by this installation." 오류 발생 해결
1519정성태10/31/201349244기타: 36. SYSTEM 또는 TrustedInstaller 소유로 되어 있는 폴더/파일을 삭제하는 방법 [5]
1518정성태10/30/201326915VS.NET IDE: 78. Visual Studio 확장으로 XmlCodeGenerator 제작하는 방법
1517정성태10/28/201326463디버깅 기술: 56. 덤프 파일에 핸들/스레드 정보를 포함하는 방법 [1]
1516정성태10/28/201331829.NET Framework: 390. FolderBrowserDialog보다 더 쓸만한 대화창이 필요하다면? [1]
1515정성태10/24/201334475VS.NET IDE: 77. Visual Studio 확장(VSIX) 만드는 방법 [5]
1514정성태10/24/201367809개발 환경 구성: 202. Internet Explorer 11을 7, 8, 9, 10 버전으로 인식시키는 방법 [9]파일 다운로드1
1513정성태10/23/201324360개발 환경 구성: 201. Azure Blob Storage의 DNS 경로를 사용자 DNS로 바꾸는 방법 [1]
1512정성태10/18/201327578개발 환경 구성: 200. IIS AppPool의 실행 계정을 변경하는 방법
1511정성태10/12/201325726.NET Framework: 389. The 3n + 1 problem의 C#/Java 버전 풀이 [2]
1510정성태10/8/201326631오류 유형: 190. 윈도우 서버 2012 R2 설치 후 인텔 NIC으로 인한 WMI 오류 발생
1509정성태10/8/201331793오류 유형: 189. Windows Server 8.1/2012 R2 - IME 비정상 종료 현상 [1]
1508정성태10/4/201326869.NET Framework: 388. 일반 닷넷 프로젝트에서 WinRT API를 호출하는 방법 [2]파일 다운로드1
1507정성태9/30/201324741오류 유형: 188. The key 'LocalizedPerfCounter' does not exist in the appSettings configuration section.
1506정성태9/30/201326924오류 유형: 187. Parameter "basePath" cannot be a relative path
1505정성태9/26/201375404기타: 35. Microsoft Office 2007 인증 생략하는 방법 [10]
... 136  137  138  139  140  [141]  142  143  144  145  146  147  148  149  150  ...