Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 10개 있습니다.)

windbg에서 python 스크립트 실행하는 방법 - pykd

windbg에서 python 스크립트를 실행하는 다음의 플러그-인이 있습니다.

Python extension for WinDbg
; http://pykd.codeplex.com/
; https://githomelab.ru/pykd

위의 홈페이지에 다운로드 받은 pykd.dll 파일을 x64/x86에 따라 다음의 windbg 폴더에 복사해 주면 됩니다.

// x64
C:\Program Files (x86)\Windows Kits\10\Debuggers\x64\winext

// x86
C:\Program Files (x86)\Windows Kits\10\Debuggers\x86\winext

(당연히 Python 2.7 버전이 설치된 상태에서) windbg 실행 후 pykd 확장을 로드한 다음,

.load pykd

c:\temp\test.py 파일을 다음과 같이 만들어,

# test.py 

print("Hello")

pykd를 통해 실행해 줄 수 있습니다.

0:005> !py c:\temp\test.py
Hello




사실, python 스크립트만 실행하는 것으로는 windbg에서 크게 효용성이 있지는 않습니다. 당연히 ^^ windbg 객체 모델을 접근할 수 있어야 하는데, 이 기능은 별도로 pykd.pyd 파일에서 제공합니다. pykd.pyd 파일 설치는 windbg 내에서 다음과 같이 pip 명령어로 간단하게 끝낼 수 있습니다.

0:005> !pip install pykd
Downloading/unpacking pykd
Installing collected packages: pykd
Successfully installed pykd
Cleaning up...

0:005> !pip install pykd --upgrade
Requirement already up-to-date: pykd in c:\python27\lib\site-packages
Cleaning up...

pykd.pyd 파일은 "C:\Python27\Lib\site-packages\pykd" 폴더에 생성되고, 이후로는 windbg에서 다음과 같은 내용의 python 소스 파일을 실행할 수 있습니다.

# test.py

from pykd import *
dprintln("Hello2")

0:005>  !py c:\temp\test.py
Hello2

그리고, 이런 Python 스크립트로 windbg를 잘 활용하도록 만들어진 사례가 바로 mona입니다.

Mona
; http://expdev-kiuhnm.rhcloud.com/2015/05/19/mona-2/

따라서 다음의 경로에 있는 python 소스 코드 2개를 내려받아,

https://raw.githubusercontent.com/corelan/windbglib/master/windbglib.py
https://raw.githubusercontent.com/corelan/mona/master/mona.py

Python 2.7 설치 경로 하위의 Lib 폴더에 복사해 주면 됩니다.

C:\Python27\Lib

이후, mona.py의 기능을 활용해 windbg 기능을 보다 편리하게 사용할 수 있습니다.




현시점(2017-06-19)에 x64 버전의 windbg에서는 !py mona를 실행하는 경우 다음과 같은 경고 메시지가 뜰 수 있습니다.

0:006> !py mona heap
*******************************************************************************************
 You are running a newer version of pykd.pyd
 mona.py was tested against v0.2.0.29
 and not against v0.3.2.6
 This version may not work properly.
 If you are having issues, I recommend to download the correct version from
   https://github.com/corelan/windbglib/raw/master/pykd/pykd.zip
   (unzip with 7zip)

 NOTE: PyKD v0.3.2.6 requires msdia120.dll, which only gets installed via Visual Studio 2013 (yup, I know)
 Alternatively, you can use the copy of msdia120.dll from the pykd.pyd file
  (https://github.com/corelan/windbglib/raw/master/pykd/pykd03.zip), but use this file at your own risk
*******************************************************************************************
...[생략]...

이유는, mona.py가 0.2.0.29 버전의 pykd.pyd 모듈에 대해 테스트되었다는 것인데 현재 "c:\python27\lib\site-packages" 경로에 설치된 pykd.pyd 버전은 0.3.2.6이기 때문입니다.

메시지에서는 "https://github.com/corelan/windbglib/raw/master/pykd/pykd.zip" 경로에서 0.2.0.29 버전의 pykd.pyd 파일을 다운로드할 수 있다고 하는데, 이는 x86 버전이기 때문에 x64에는 적용할 수 없습니다. (아마도, x64 버전은 0.2.0.29 버전이 아닌 곧바로 0.3.2.6 버전부터 개발된 것으로 보입니다.) 따라서, 현재는 x64 버전으로 실행하는 경우 감수해야 하는 경고 메시지입니다. (아니면, mona.py 소스 코드에서 삭제하거나!)

참고로, 원하는 버전의 모듈이 있는 경우라면 버전을 지정해 "pip install"로 설치할 수 있습니다.

0:006> !pip install pykd==0.2.0.29
Collecting pykd==0.2.0.29
  Could not find a version that satisfies the requirement pykd==0.2.0.29 (from versions: 0.3.0.11, 0.3.0.12, 0.3.0.13, 0.3.0.14, 0.3.0.15, 0.3.0.16, 0.3.0.17, 0.3.0.18, 0.3.0.19, 0.3.0.20, 0.3.0.21, 0.3.0.22, 0.3.0.23, 0.3.0.24, 0.3.0.25, 0.3.0.26, 0.3.0.27, 0.3.0.28, 0.3.0.29, 0.3.0.30, 0.3.0.31, 0.3.0.32, 0.3.0.33, 0.3.0.34, 0.3.0.35, 0.3.0.36, 0.3.0.37, 0.3.1.3, 0.3.1.4, 0.3.1.5, 0.3.1.6, 0.3.1.7, 0.3.1.8, 0.3.1.9, 0.3.1.10, 0.3.2.0, 0.3.2.1, 0.3.2.2, 0.3.2.4, 0.3.2.5, 0.3.2.6)
No matching distribution found for pykd==0.2.0.29

보는 바와 같이, x64에서는 0.2.0.29 버전은 제공되지 않기 때문에 설치가 안됩니다.




만약 다음과 같은 오류가 발생한다면?

0:005> !py c:\temp\test.py
failed to find python interpreter

HKEY_LOCAL_MACHINE 또는 HKEY_CURRENT_USER 노드 하위에 "SOFTWARE\\Python\\PythonCore" 설정이 있는지 확인합니다. 없는 경우, 다음의 내용을 .reg 파일로 저장한 후 등록해 줍니다.

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\Python]

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore]

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\2.7]

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\2.7\Help]

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\2.7\Help\Main Python Documentation]
@="c:\\Python27\\Doc\\python2710.chm"

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\2.7\InstallPath]
@="c:\\Python27\\"

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\2.7\InstallPath\InstallGroup]
@="Python 2.7"

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\2.7\Modules]

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\2.7\PythonPath]
@="c:\\Python27\\Lib;c:\\Python27\\DLLs;c:\\Python27\\Lib\\lib-tk"

혹은, 다음과 같이 오류가 발생할 수 있습니다.

0:006> .load pykd
0:006> !py c:\temp\test.py

Traceback (most recent call last):

  File "c:\temp\test.py", line 1, in <module>
    from pykd import *

ImportError: No module named pykd

이런 경우는 pykd.pyd 파일 설치가 안되어 있기 때문입니다. 본문에서 설명한 pip install을 이용해 pykd를 설치해 주면 됩니다.

혹은, 다음과 같이 오류가 발생할 수 있습니다.

0:006> !py mona heap
Do not run this script outside of a debugger !

위와 같이 나오면 pykd.pyd 파일의 유무와 플랫폼이 맞는지 확인해야 합니다. 가령, x86 버전의 pykd.pyd 파일을 x64 버전 환경에서 로딩되도록 설정한 상태일 수 있습니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/3/2022]

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

비밀번호

댓글 작성자
 



2017-06-22 02시30분
[Lyn] 크... 꾸준히 연구하시는 모습이 멋집니다
[guest]
2017-06-22 04시12분
아니... ^^ 그냥 따라해 본 정도인데요.
정성태
2017-06-30 12시39분
Debugger Updates in the 16225 SDK Preview
; https://blogs.msdn.microsoft.com/windbg/2017/06/29/debugger-updates-in-the-16225-sdk-preview/

* Thread Description in Minidumps
* Function Aliases in JavaScript
정성태
2017-10-25 05시01분
[horensic] 좋은 글 감사합니다~ 덕분에 많은 도움 받아갑니다!
[guest]
2019-04-25 03시46분
정성태
2021-05-24 02시46분
정성태

... 16  17  18  19  20  21  [22]  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13083정성태6/20/20227305.NET Framework: 2024. .NET 7에 도입된 GC의 메모리 해제에 대한 segment와 region의 차이점 [2]
13082정성태6/19/20226323.NET Framework: 2023. C# - Process의 I/O 사용량을 보여주는 GetProcessIoCounters Win32 API파일 다운로드1
13081정성태6/17/20226397.NET Framework: 2022. C# - .NET 7 Preview 5 신규 기능 - System.IO.Stream ReadExactly / ReadAtLeast파일 다운로드1
13080정성태6/17/20227011개발 환경 구성: 643. Visual Studio 2022 17.2 버전에서 C# 11 또는 .NET 7.0 preview 적용
13079정성태6/17/20224658오류 유형: 814. 파이썬 - Error: The file/path provided (...) does not appear to exist
13078정성태6/16/20226716.NET Framework: 2021. WPF - UI Thread와 Render Thread파일 다운로드1
13077정성태6/15/20227073스크립트: 40. 파이썬 - PostgreSQL 환경 구성
13075정성태6/15/20226039Linux: 50. Linux - apt와 apt-get의 차이 [2]
13074정성태6/13/20226346.NET Framework: 2020. C# - NTFS 파일에 사용자 정의 속성값 추가하는 방법파일 다운로드1
13073정성태6/12/20226573Windows: 207. Windows Server 2022에 도입된 WSL 2
13072정성태6/10/20226856Linux: 49. Linux - ls 명령어로 출력되는 디렉터리 색상 변경 방법
13071정성태6/9/20227439스크립트: 39. Python에서 cx_Oracle 환경 구성
13070정성태6/8/20227239오류 유형: 813. Windows 11에서 입력 포커스가 바뀌는 문제 [1]
13069정성태5/26/20229468.NET Framework: 2019. C# - .NET에서 제공하는 3가지 Timer 비교 [2]
13068정성태5/24/20227993.NET Framework: 2018. C# - 일정 크기를 할당하는 동안 GC를 (가능한) 멈추는 방법 [1]파일 다운로드1
13067정성태5/23/20227303Windows: 206. Outlook - 1년 이상 지난 메일이 기본적으로 안 보이는 문제
13066정성태5/23/20226658Windows: 205. Windows 11 - Windows + S(또는 Q)로 뜨는 작업 표시줄의 검색 바가 동작하지 않는 경우
13065정성태5/20/20227311.NET Framework: 2017. C# - Windows I/O Ring 소개 [2]파일 다운로드1
13064정성태5/18/20226914.NET Framework: 2016. C# - JIT 컴파일러의 인라인 메서드 처리 유무
13063정성태5/18/20227337.NET Framework: 2015. C# - 인라인 메서드(inline methods)
13062정성태5/17/20228056.NET Framework: 2014. C# - async/await 그리고 스레드 (4) 비동기 I/O 재현파일 다운로드1
13061정성태5/16/20226890.NET Framework: 2013. C# - FILE_FLAG_OVERLAPPED가 적용된 파일의 읽기/쓰기 시 Position 관리파일 다운로드1
13060정성태5/15/20229384.NET Framework: 2012. C# - async/await 그리고 스레드 (3) Task.Delay 재현파일 다운로드1
13059정성태5/14/20227803.NET Framework: 2011. C# - CLR ThreadPool의 I/O 스레드에 작업을 맡기는 방법 [1]파일 다운로드1
13058정성태5/13/20227700.NET Framework: 2010. C# - ThreadPool.SetMaxThreads 사용법
13057정성태5/12/20229390오류 유형: 812. 파이썬 - ImportError: cannot import name ...
... 16  17  18  19  20  21  [22]  23  24  25  26  27  28  29  30  ...