Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 4개 있습니다.)
(시리즈 글이 2개 있습니다.)
디버깅 기술: 147. pdb 파일을 다운로드하기 위한 symchk.exe 실행에 필요한 최소 파일
; https://www.sysnet.pe.kr/2/0/12091

.NET Framework: 873. C# - 코드를 통해 PDB 심벌 파일 다운로드 방법
; https://www.sysnet.pe.kr/2/0/12094




pdb 파일을 다운로드하기 위한 symchk.exe 실행에 필요한 최소 파일

windbg 설치 후 함께 있는 symchk.exe를 이용하면 명령행에서 쉽게 PDB 파일을 다운로드할 수 있습니다.

Using SymChk
; https://learn.microsoft.com/en-us/windows-hardware/drivers/debugger/using-symchk

예를 들어, "ntdll.dll"의 pdb 파일을 다운로드하려면 다음과 같이 명령을 내리면 됩니다.

symchk.exe c:\WINDOWS\system32\ntdll.dll /s http://msdl.microsoft.com/download/symbols

[또는, 다운로드할 폴더를 지정해서]

symchk.exe c:\WINDOWS\system32\ntdll.dll /s SRV*c:\temp*http://msdl.microsoft.com/download/symbols

// D:\symbols;srv*D:\symbols*http://msdl.microsoft.com/download/symbols




그런데 symchk.exe만 복사해 실행하면 SymbolCheck.dll이 없다고 오류가 발생합니다.

The code execution cannot proceed because SymbolCheck.dll was not found. Reinstalling the program may fix this problem. 

SymbolCheck.dll이(가) 없어 코드 실행을 진행할 수 없습니다. 프로그램을 다시 설치하면 이 문제가 해결될 수 있습니다. 

당연히 symchk.exe와 동일한 폴더에 있던 SymbolCheck.dll을 복사해 주면 이 부분은 해결되지만 그래도 다음과 같이 여전히 pdb 다운로드에는 실패합니다.

c:\temp> symchk.exe c:\WINDOWS\system32\ntdll.dll /s http://msdl.microsoft.com/download/symbols
SYMCHK: ntdll.dll            FAILED  - ntdll.pdb mismatched or not found

SYMCHK: FAILED files = 1
SYMCHK: PASSED + IGNORED files = 0

좀 더 오류 내용을 확인하기 위해 "/v" 옵션을 주면 symsrv.dll이 없다는 단서를 얻을 수 있습니다.

c:\temp> symchk.exe /v c:\WINDOWS\system32\ntdll.dll /s SRV*c:\temp*http://msdl.microsoft.com/download/symbols
[SYMCHK] Searching for symbols to c:\WINDOWS\system32\ntdll.dll in path http://msdl.microsoft.com/download/symbols
DBGHELP: Symbol Search Path: http://msdl.microsoft.com/download/symbols
[SYMCHK] Using search path "http://msdl.microsoft.com/download/symbols"
DBGHELP: No header for c:\WINDOWS\system32\ntdll.dll.  Searching for image on disk
DBGHELP: c:\WINDOWS\system32\ntdll.dll - OK
DBGHELP: symsrv.dll load failure
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 - no symbols loaded
[SYMCHK] MODULE64 Info ----------------------
[SYMCHK] Struct size: 1680 bytes
[SYMCHK] Base: 0x180000000
[SYMCHK] Image size: 2031616 bytes
[SYMCHK] Date: 0x99ca0526
[SYMCHK] Checksum: 0x001ed133
[SYMCHK] NumSyms: 0
[SYMCHK] SymType: SymNone
[SYMCHK] ModName: ntdll
[SYMCHK] ImageName: c:\WINDOWS\system32\ntdll.dll
[SYMCHK] LoadedImage: c:\WINDOWS\system32\ntdll.dll
[SYMCHK] PDB: ""
[SYMCHK] CV: RSDS
[SYMCHK] CV DWORD: 0x53445352
[SYMCHK] CV Data:  ntdll.pdb
[SYMCHK] PDB Sig:  0
[SYMCHK] PDB7 Sig: {0C2E19EA-1901-E9B8-2E45-67D2D21E56D2}
[SYMCHK] Age: 1
[SYMCHK] PDB Matched:  TRUE
[SYMCHK] DBG Matched:  TRUE
[SYMCHK] Line nubmers: FALSE
[SYMCHK] Global syms:  FALSE
[SYMCHK] Type Info:    FALSE
[SYMCHK] ------------------------------------
SymbolCheckVersion  0x00000002
Result              0x00010001
DbgFilename         ntdll.dbg
DbgTimeDateStamp    0x00000000
DbgSizeOfImage      0x00000000
DbgChecksum         0x00000000
PdbFilename         ntdll.pdb
PdbSignature        {0C2E19EA-1901-E9B8-2E45-67D2D21E56D2}
PdbDbiAge           0x00000001
[SYMCHK] [ 0x00000000 - 0x00010001 ] Checked "c:\WINDOWS\system32\ntdll.dll"
SYMCHK: ntdll.dll            FAILED  - ntdll.pdb mismatched or not found

SYMCHK: FAILED files = 1
SYMCHK: PASSED + IGNORED files = 0

따라서 symsrv.dll도 복사해 주는데 그래도 여전히 pdb 다운로드에는 실패합니다. 이쯤 해서 depends.exe를 이용해 symchk.exe의 의존성을 살펴보면 dbghelp.dll과 dbgeng.dll이 걸려 있는 것을 볼 수 있습니다.

그런데 실제로 테스트해 보면 dbghelp.dll만 필요한 것을 알 수 있습니다. 결국, symchk.exe를 정상적으로 실행하려면 다음의 파일만 복사해 오면 됩니다.

  • symchk.exe
  • dbghelp.dll
  • SymbolCheck.dll
  • symsrv.dll




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 3/9/2024]

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

비밀번호

댓글 작성자
 



2020-07-29 03시47분
OFFLINE에서 메모리 덤프를 분석할 때 필요한 TIP
; https://kuaaan.tistory.com/509

symchk.exe /id "G:\dump\memorydump.dmp" /om C:\temp\symbolinfo.txt
symchk.exe /ie notepad.exe /om C:\temp\symbolinfo.txt
symchk.exe /if c:\Windows\system32\FirewallAPI.dll /om c:\temp\symbolinfo.txt

symchk.exe /im c:\temp\symbolinfo.txt /s SRV*C:\Temp\SYMBOLS*http://msdl.microsoft.com/download/symbols
정성태

... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
227정성태4/13/200617423Team Foundation Server: 2. TFS 빌드 오류 유형 - MSBUILD: warning : Specified cast is not valid
226정성태4/13/200615415Team Foundation Server: 1. TFS 오류 유형 - TF50608: Unable to retrieve information for security object
225정성태10/17/200614950.NET Framework: 67. VS.NET 2005 도구 상자에 있는 Workflow Activity 항목의 아이콘 변경
223정성태4/13/200626231.NET Framework: 66. Microsoft .NET Framework 2.0 Configuration 수동 설치파일 다운로드1
224정성태4/13/200619782    답변글 .NET Framework: 66.1. "Microsoft .NET Framework 2.0 Configuration" MSI 설치 파일 버전파일 다운로드1
222정성태4/13/200618780.NET Framework: 65. VS.NET 2005: 파일 기반 웹 프로젝트의 "Virtual Path" 제거
220정성태4/13/200616516.NET Framework: 64. ClickOnce - 배포 시 오류 : "Error: An unexpected error occurred -- The parameter is incorrect."
219정성태4/13/200631365.NET Framework: 63. ClickOnce - 최초 실행 시 보안 경고창 없애는 방법 [1]
216정성태4/13/200618389스크립트: 8. 3월 1일 ActiveX Patch 적용 후, JS 로 수정한 임베딩 컨트롤이 여전히 비활성화 되는 문제 [2]
215정성태4/13/200619736.NET Framework: 62. ASP.NET 웹 컨트롤 렌더링 가로채기
214정성태4/13/200619079.NET Framework: 61. DateTime - DateTime = 사이의 "Month" 수 계산 [2]
213정성태4/13/200621323.NET Framework: 60. localhost 이외의 컴퓨터에서 asmx 테스트 페이지 호출 [1]
218정성태4/13/200619707    답변글 .NET Framework: 60.1. asmx 테스트 페이지를 보여주고 싶지 않을 때
211정성태4/13/200617576VS.NET IDE: 38. VS.NET 2005 - "Export Template" 메뉴
210정성태4/13/200617093.NET Framework: 59. EXE 참조 가능 - VS.NET 2005 [2]
209정성태4/13/200616501스크립트: 7. 4월 12일 ActiveX 패치 문제를 해결할 수 있는 가장 간단한 방법 [6]파일 다운로드1
208정성태10/21/200616309Windows: 1. 성태도 ^^ Vista 설치 해봤습니다.
212정성태10/20/200615829    답변글 Windows: 1.1. Vista 에서 WinFX 런타임 구동
207정성태4/13/200624836VC++: 23. VC++ RGS 파일에 사용자 정의 파라미터 추가
205정성태4/13/200621898VS.NET IDE: 37. devenv.exe를 이용한 Command Line 컴파일 [1]
204정성태5/8/200617078웹: 2. Server Unavailable - Server Application Unavailable
203정성태4/13/200615951웹: 1. IIS 설정 옵션: Verify(Check) that file exists
202정성태4/13/200615648VS.NET IDE: 36. Automatically synchronize with an Internet time server
201정성태4/13/200618714기타: 12. XMLHTTP Failure and SUS Admin
200정성태4/13/200618075.NET Framework: 58. 웹 서비스 메서드 호출 오류 유형 - text/html; charset=xxx, but expected 'text/xml'
199정성태4/13/200619429스크립트: 6. XHTML or HTML 4.01 표준 준수
... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...