Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 219. WinDbg - 명령어 내에서 환경 변수 사용법 [링크 복사], [링크+제목 복사],
조회: 2478
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 

(시리즈 글이 2개 있습니다.)
디버깅 기술: 216. WinDbg - 2가지 유형의 식 평가 방법(MASM, C++)
; https://www.sysnet.pe.kr/2/0/13860

디버깅 기술: 219. WinDbg - 명령어 내에서 환경 변수 사용법
; https://www.sysnet.pe.kr/2/0/13910




WinDbg - 명령어 내에서 환경 변수 사용법

아쉽게도 WinDbg의 표현식에서 환경 변수를 사용할 수는 없습니다.

그래서, .load와 같은 명령어를 사용할 때 (윈도우 명령행처럼) 환경 변수를 이용하면 오류가 발생합니다.

0:00> .load "%USERPROFILE%\\.dotnet\\sos\\sos.dll"
The call to LoadLibrary(%USERPROFILE%\.dotnet\sos\sos.dll) failed, Win32 error 0n2
    "The system cannot find the file specified."
...[생략]...

위의 결과에도 나오지만, "%USERPROFILE%"을 환경 변수로 인식하는 것이 아니라 경로명 자체로 인식하기 때문입니다.

대신, 우회하는 방법이 하나 있긴 한데요, "as" 명령어를 이용해,

as, aS (Set Alias)
; https://learn.microsoft.com/en-us/windows-hardware/drivers/debuggercmds/as--as--set-alias-

이렇게 WinDbg 변수로 정의할 수 있습니다.

// https://community.osr.com/t/how-to-nest-if-token/39299/5

0:014> as /e MyEnvVar USERPROFILE

그럼, 다음과 같이 각종 WinDbg 명령에서 사용할 수 있습니다.

0:014> .echo ${MyEnvVar}
C:\Users\testusr

0:014> .load ${MyEnvVar}\.dotnet\sos\sos.dll

0:014> .chain
Extension DLL search Path:
    ...[생략]...
Extension DLL chain:
    C:\Users\testusr\.dotnet\sos\sos.dll: image 9,0,12,7501 @Commit: a651406e39038aef1dbc7c8097b52953284dba27, API 2.0.0, built Sat Jan 25 17:30:17 2025
        [path: C:\Users\testusr\.dotnet\sos\sos.dll]
    kdexts: image 10.0.27793.1000, API 1.0.0, 
    ...[생략]...




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







[최초 등록일: ]
[최종 수정일: 4/8/2025]

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)
1614정성태1/29/201425127.NET Framework: 416. System.Net.Sockets.NetworkStream이 Thread-safe할까?파일 다운로드1
1613정성태1/29/201427046.NET Framework: 415. IIS 작업자 프로세스 재생(recycle)하는 방법 [1]
1612정성태1/29/201423735오류 유형: 219. IIS 500 Internal Server Error - Skydrive에 공유된 경우
1611정성태1/27/201455507.NET Framework: 414. C# - 컴퓨터에서 알아낼 수 있는 고윳값 정리 [3]파일 다운로드1
1610정성태1/26/201439289.NET Framework: 413. C# - chromiumembedded 사용 [11]파일 다운로드1
1609정성태1/26/201422299오류 유형: 218. wsDualHttpBinding + Windows Server 2003인 경우 발생하는 오류
1608정성태1/26/201427700.NET Framework: 412. HttpContext.Current를 통해 이해하는 CallContext와 ExecutionContext [4]
1607정성태1/26/201427662.NET Framework: 411. 유니코드의 "compatibility character"가 뭘까요? [4]파일 다운로드1
1606정성태1/25/201425756오류 유형: 217. 델 베뉴 스타일러스 관련 업데이트 오류 - 5830_Firmware_X267N_WN_1.0.4.1_A01.EXE
1605정성태1/23/201422547개발 환경 구성: 212. Visual Studio Online과 "Monaco" 서비스 연동
1604정성태1/23/201422901오류 유형: 216. 윈도우 서버 백업 - Hyper-V 가상 머신이 백업되지 않는 경우 (2)
1603정성태1/23/201434843개발 환경 구성: 211. Hyper-V - Generation 2 유형의 VM 생성 시 ISO 부팅이 안된다면? [1]
1602정성태1/22/201425007디버깅 기술: 62. windbg - 사용자 모드 원격 디버깅
1601정성태1/22/201428788오류 유형: 215. windbg - Symbol file could not be found. Defaulted to export symbols
1600정성태1/19/201425283.NET Framework: 410. C# - 재귀호출을 스택 자료구조와 반복문을 이용해 대체하는 방법을 Paralle.For와 함께? [1]파일 다운로드1
1599정성태1/18/201433538.NET Framework: 409. C# - 재귀호출을 스택 자료구조와 반복문을 이용해 대체하는 방법 [1]파일 다운로드1
1598정성태1/17/201426947디버깅 기술: 61. NT 서비스 시작 단계에서 닷넷 메서드에 BP를 걸어 디버깅하는 방법
1597정성태1/17/201425512Phone: 9. Xamarin Android에 구글 AdMob 사용하는 방법 [1]
1596정성태1/17/201424157오류 유형: 214. Local SYSTEM 계정으로 실행된 IE에서 다운로드가 안 되는 문제
1595정성태1/16/201421346오류 유형: 213. attrib - Not resetting system file
1594정성태1/15/201423569오류 유형: 212. 마이크로소프트 라이브 계정 로그인 실패하는 경우
1593정성태1/14/201422128오류 유형: 211. ASP.NET 응용 프로그램을 IIS Express에서 디버깅할 때 "Requested registry access is not allowed" 오류 발생
1592정성태1/14/201422069오류 유형: 210. 2대의 AD가 있는 경우 도메인에 컴퓨터 추가를 실패한다면? [1]
1591정성태1/14/201424564오류 유형: 209. DebugDiag: Unable to find mscordacwks_x86_x86_[...version...].dll
1590정성태1/14/201425426오류 유형: 208. VSS Writer - NTDS 오류
1589정성태1/14/201434404Windows: 85. 컴퓨터를 껐는데도 어느 순간 자동으로 켜진다면? [2]
... 136  137  138  [139]  140  141  142  143  144  145  146  147  148  149  150  ...