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

비밀번호

댓글 작성자
 




... 91  [92]  93  94  95  96  97  98  99  100  101  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11728정성태10/9/201824381사물인터넷: 50. Audio Jack 커넥터의 IR 적외선 송신기 [1]
11727정성태10/8/201825912오류 유형: 491. Visual Studio의 리눅스 SSH 원격 연결 - "Connectivity Failure. Please make sure host name and port number are correct."
11726정성태10/7/201829070사물인터넷: 49. 라즈베리 파이를 이용해 원격 컴퓨터의 전원 스위치 제어파일 다운로드1
11724정성태10/5/201829002개발 환경 구성: 407. 유니코드와 한글 - "Hangul Compatibility Jamo"파일 다운로드1
11723정성태10/4/201819983개발 환경 구성: 406. "Docker for Windows" 컨테이너 내의 .NET Core 응용 프로그램에서 직렬 포트(Serial Port, COM Port) 사용 방법
11722정성태10/4/201825748.NET Framework: 798. C# - Hyper-V 가상 머신의 직렬 포트와 연결된 Named Pipe 간의 통신파일 다운로드1
11721정성태10/4/201826188.NET Framework: 797. Linux 환경의 .NET Core 응용 프로그램에서 직렬 포트(Serial Port, COM Port) 사용 방법파일 다운로드1
11720정성태10/4/201827561개발 환경 구성: 405. Hyper-V 가상 머신에서 직렬 포트(Serial Port, COM Port) 사용
11719정성태10/4/201828347.NET Framework: 796. C# - 인증서를 윈도우에 설치하는 방법
11718정성태10/4/201823145개발 환경 구성: 404. (opkg가 설치된) Synology NAS(DS216+II)에 cmake 설치
11717정성태10/3/201824893사물인터넷: 48. 넷두이노의 C# 네트워크 프로그램 [1]
11716정성태10/3/201826330사물인터넷: 47. Raspberry PI Zero (W)에 FTDI 장치 연결 후 C/C++로 DTR 제어파일 다운로드1
11715정성태10/3/201824010사물인터넷: 46. Raspberry PI Zero (W)에 docker 설치
11714정성태10/2/201824392사물인터넷: 45. Raspberry PI에 ping을 hostname으로 하는 방법
11713정성태10/2/201825096개발 환경 구성: 403. Synology NAS(DS216+II)에 docker 설치 후 .NET Core 2.1 응용 프로그램 실행하는 방법
11712정성태10/2/201830909.NET Framework: 795. C# - 폰트 목록을 한글이 아닌 영문으로 구하는 방법 [3]
11711정성태10/2/201825744오류 유형: 490. 윈도우 라이선스 키 입력 오류 0xc004f050, 0xc004e028
11710정성태10/2/201825324.NET Framework: 794. C# - 같은 모양, 다른 값의 한글 자음을 비교하는 호환 분해 [5]
11709정성태9/30/201824163개발 환경 구성: 402. .NET Core 콘솔 응용 프로그램을 docker로 실행/디버깅하는 방법 [1]
11708정성태9/30/201827479개발 환경 구성: 401. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 [2]파일 다운로드1
11707정성태9/30/201829028오류 유형: 489. ASP.NET Core를 docker에서 실행 시 "Failed with a critical error." 오류 발생 [1]
11706정성태9/29/201823097개발 환경 구성: 400. Synology NAS(DS216+II)에서 실행한 gcc의 Segmentation fault [2]
11705정성태9/29/201823620개발 환경 구성: 399. Synology NAS(DS216+II)에 gcc 컴파일러 설치
11704정성태9/29/201829641기타: 73. Synology NAS 신호음(beep) 끄기 [1]파일 다운로드1
11703정성태9/27/201822341개발 환경 구성: 398. Blazor 환경 구성 후 빌드 속도가 너무 느리다면? [2]
11702정성태9/26/201820084사물인터넷: 44. 넷두이노(Netduino)의 네트워크 설정 방법
... 91  [92]  93  94  95  96  97  98  99  100  101  102  103  104  105  ...