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

WinDbg - _NT_SYMBOL_PATH 환경 변수에 설정한 경로로 심벌 파일을 다운로드하지 않는 경우

이상하군요, 분명히 전역 환경 변수에 이런 설정을 추가했는데,

이름: _NT_SYMBOL_PATH
값: SRV*d:\Symbols*https://msdl.microsoft.com/download/symbols;

.reload 명령에 따른 pdb 다운로드를 엉뚱한 경로에 하고 있습니다.

2: kd> .reload /f

2: kd> lm o
start             end                 module name
fffff804`07b50000 fffff804`07b77000   mcupdate_AuthenticAMD   (no symbols)           
fffff804`0bb80000 fffff804`0bb93000   kdstub     (pdb symbols)          C:\ProgramData\Dbg\sym\kdstub.pdb\D07598226A01432938B804CFF470D3D11\kdstub.pdb
fffff804`0bba0000 fffff804`0bbe9000   kdcom      (pdb symbols)          C:\ProgramData\Dbg\sym\kdnet.pdb\68137BA161AB8180B428399B9E422A321\kdnet.pdb
...[생략]...

WinDbg 내에서 확인해 보면 일단 _NT_SYMBOL_PATH 환경 변수가 적용은 됐으나,

2: kd> .sympath 
Symbol search path is: srv*;SRV*d:\Symbols*https://msdl.microsoft.com/download/symbols
Expanded Symbol search path is: cache*;SRV*https://msdl.microsoft.com/download/symbols;srv*d:\symbols*https://msdl.microsoft.com/download/symbols

************* Path validation summary **************
Response                         Time (ms)     Location
Deferred                                       srv*
Deferred                                       SRV*d:\Symbols*https://msdl.microsoft.com/download/symbols

msdl.microsoft.com 경로에 대해 "cache*"와 "SRV*https://msdl.microsoft.com/download/symbols" 2개가 앞서 정의된 것을 볼 수 있습니다. 어쩔 수 없군요, ^^ 다시 명시적으로 .sympath를 이용해 기존 설정을 덮어버리면 됩니다.

0: kd> .sympath SRV*d:\Symbols*https://msdl.microsoft.com/download/symbols

그래서 결국 이렇게 결과가 나와야 하고,

0: kd> .sympath 
Symbol search path is: SRV*d:\Symbols*https://msdl.microsoft.com/download/symbols
Expanded Symbol search path is: srv*d:\symbols*https://msdl.microsoft.com/download/symbols

************* Path validation summary **************
Response                         Time (ms)     Location
Deferred                                       SRV*d:\Symbols*https://msdl.microsoft.com/download/symbols

위와 같은 설정 상태에서 .reload 명령을 다시 내리면 정상적으로 우리가 지정했던 (위의 경우 d:\symbols) 경로에 pdb가 내려오는 것을 확인할 수 있습니다. 참고로, 커널 모드 드라이버를 디버깅한다면 이를 위해 응용 프로그램만의 심벌 파일 경로를 추가로 지정해 두는 것도 좋겠고!

이름: _NT_SYMBOL_PATH
값: SRV*d:\Symbols*https://msdl.microsoft.com/download/symbols;D:\SymbolsDrv




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







[최초 등록일: ]
[최종 수정일: 1/18/2025]

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

비밀번호

댓글 작성자
 




... 166  167  168  [169]  170  171  172  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
910정성태8/19/201042702개발 환경 구성: 83. Hyper-V의 네트워크 유형 (1)
909정성태8/18/201037401오류 유형: 102. System.MissingMethodException
908정성태8/17/201028399개발 환경 구성: 82. Windows Virtual PC의 네트워크 유형 (3)
907정성태8/14/201025782개발 환경 구성: 81. Windows Virtual PC의 네트워크 유형 (2)
906정성태8/13/201033523개발 환경 구성: 80. Windows Virtual PC의 네트워크 유형 (1)
905정성태8/8/201037556Team Foundation Server: 39. 배치 파일로 팀 빌드 구성 [2]파일 다운로드1
904정성태8/8/201039742오류 유형: 101. SignTool Error: No certificates were found that met all the given criteria. [2]
903정성태8/6/201036661Team Foundation Server: 38. TFS 소스 코드 관리 기능 (4) - Branch
902정성태8/5/201029129Team Foundation Server: 37. TFS 2010의 소스 서버 수작업 구성
901정성태8/4/201028290Team Foundation Server: 36. TFS 소스 코드 관리 기능 (3) - Label
900정성태8/3/201031226Team Foundation Server: 35. TFS 소스 코드 관리 기능 (2) - Shelveset
899정성태8/2/201032803Team Foundation Server: 34. TFS 소스 코드 관리 기능 (1) - Changeset
898정성태7/31/201033044.NET Framework: 182. WCF의 InactivityTimeout [1]파일 다운로드1
897정성태7/26/201133963.NET Framework: 181. AssemblyVersion, AssemblyFileVersion, AssemblyInformationalVersion [4]
896정성태7/25/201041029.NET Framework: 180. C# Singleton 인스턴스 생성 [2]
895정성태7/25/201024698VS.NET IDE: 68. Visual Studio 2010 - .NET 1.1 원격 디버깅
894정성태7/25/201030551오류 유형: 100. Could not find the Database Engine startup handle. [1]
893정성태7/25/201031454오류 유형: 99. .NET 4.0 설치된 윈도우 7에서 SQL Server 2008 R2 설치 오류
892정성태7/9/201032543오류 유형: 98. 영문 윈도우에 한글 SQL Server 2008 R2 설치할 때 오류 [4]
891정성태7/8/201029067오류 유형: 97. MsiGetProductInfo failed to retrieve ProductVersion for package with Product Code = '{...}'. Error code: 1605. [2]
889정성태7/5/201030934.NET Framework: 179. Dictionary.Get(A) 대신 Dictionary.Get(A.GetHashCode())를 사용해서는 안 되는 이유 [1]
888정성태6/30/201028508오류 유형: 96. Hyper-V 연결 오류 - A connection will not be made because credentials may not be sent to the remote computer
887정성태6/23/201038362개발 환경 구성: 79. Hyper-V의 가상 머신에서 소리 재생 방법 [2]
886정성태6/23/201026407제니퍼 .NET: 14. ASMX, WCF 호출 모니터링 및 누수 확인
885정성태6/20/201028449개발 환경 구성: 78. COM+ 서버에서 COM+ 서버를 호출하는 방법
884정성태6/20/201031047제니퍼 .NET: 13. COM+ 서버 모니터링 [2]
... 166  167  168  [169]  170  171  172  173  174  175  176  177  178  179  180  ...