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

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

우선 아래의 페이지에서,

pykd-ext 
; https://githomelab.ru/pykd/pykd-ext
; https://githomelab.ru/pykd/pykd-ext/-/wikis/Downloads

pykd_ext_[vesrion].zip 파일을 다운로드해 압축을 풀어 둡니다. (이 글에서는 d:\wext 디렉터리로 가정합니다.)

이후, windbg preview를 실행해 pykd.dll을 로드합니다.

0:00> .load d:\wext\x64\pykd.dll

일단 위의 명령어까지는 잘 실행이 될 텐데, 그다음 pykd 명령어를 실행할 때 다음과 같은 오류가 발생할 수 있습니다.

0:001> !py
failed to find python interpreter

전에도 이에 대해 설명은 했지만,

windbg - !py 확장 명령어 실행 시 "failed to find python interpreter"
; https://www.sysnet.pe.kr/2/0/12334

windbg에서 python 스크립트 실행하는 방법 - pykd
; https://www.sysnet.pe.kr/2/0/11227#python

구체적으로 어떻게 파이썬 인터프리터를 찾는가에 관해서는 "https://githomelab.ru/pykd/pykd-ext/-/blob/master/sources/pyinterpret.cpp#L321" 소스 코드에 잘 나옵니다. 즉, "HKEY_LOCAL_MACHINE"과 "HKEY_CURRENT_USER"에서 모두 "\SOFTWARE\Python" 설정을 찾는데, 반드시 그 하위에는 "InstallPath" 키를 포함하고 있어야 합니다.

그렇게 해서 검색이 되는 경로를 "!pkyd.info" 명령어를 통해서 확인할 수 있습니다.

0:000> !pykd.info

pykd bootstrapper version: 2.0.0.13

Installed python:

Version:        Status:     Image:
------------------------------------------------------------------------------
* 3.8 x86-64    Unloaded    E:\Python38\python38.dll

이후, (pykd windbg 확장 모듈이 아닌) pykd 파이썬 모듈을 설치하면 끝!

E:\Python38\Scripts> pip install pykd




그건 그렇고, 아마도 Visual Studio의 설치와 함께 등록된 파이썬의 경우,

0:000> !pykd.info

pykd bootstrapper version: 2.0.0.25

Installed python:

Version:        Status:     Image:
------------------------------------------------------------------------------
* 3.9 x86-64    Loaded      C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64\python39.dll

뭔가 잘 안 맞는 부분이 있습니다. 가령 windbg 내에서 pykd 파이썬 모듈을 설치하려고 해도 이런 오류가 발생하고,

0:000> .load d:\wext\x64\pykd.dll

0:000> !pip install pykd

Traceback (most recent call last):

  File "<string>", line 1, in <module>

  File "C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64\Lib\runpy.py", line 206, in run_module
    mod_name, mod_spec, code = _get_module_details(mod_name)

  File "C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64\Lib\runpy.py", line 141, in _get_module_details
    raise error("No module named %s" % mod_name)

ImportError: No module named pip

이로 인해 관리자 권한의 cmd 명령행에서 설치하면 잘 진행은 되지만,

C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64\Scripts> pip install pykd
Collecting pykd
  Using cached pykd-0.3.4.15-cp37-none-win_amd64.whl (11.2 MB)
Installing collected packages: pykd
Successfully installed pykd-0.3.4.15

windbg 내에서 pykd를 로드하는 경우 여전히 오류가 발생합니다.

0:000> !py
Python 3.9.5 (tags/v3.9.5:0a7dcbd, May  3 2021, 17:27:52) [MSC v.1928 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
(InteractiveConsole)
>>> import pykd
Traceback (most recent call last):
  File "<console>", line 1, in <module>
  File "C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64\lib\site-packages\pykd\__init__.py", line 4, in <module>
    from pykd.pykd import *
ImportError: DLL load failed while importing pykd: %1 is not a valid Win32 application.
>>> 

0:000> !pip list

Traceback (most recent call last):

  File "<string>", line 1, in <module>

  File "C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64\Lib\runpy.py", line 206, in run_module
    mod_name, mod_spec, code = _get_module_details(mod_name)

  File "C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64\Lib\runpy.py", line 141, in _get_module_details
    raise error("No module named %s" % mod_name)

ImportError: No module named pip

일단 직접적인 해결은 못했고, (비주얼 스튜디오의 것이 아닌) 별도로 설치한 Python 런타임인 경우에는 잘 되는 것을 확인했습니다. 그래서 레지스트리에 원하는 런타임을 등록하기 위해 다음의 reg 파일을 만들고, (경로 및 버전은 각자의 환경에 맞게 조절합니다.)


Windows Registry Editor Version 5.00

[HKEY_CURRENT_USER\SOFTWARE\Python]

[HKEY_CURRENT_USER\SOFTWARE\Python\PythonCore]

[HKEY_CURRENT_USER\SOFTWARE\Python\PythonCore\3.8]

[HKEY_CURRENT_USER\SOFTWARE\Python\PythonCore\3.8\InstallPath]
@="E:\\Python38\\"

[HKEY_CURRENT_USER\SOFTWARE\Python\PythonCore\3.8\InstallPath\InstallGroup]
@="Python 3.8"

[HKEY_CURRENT_USER\SOFTWARE\Python\PythonCore\3.8\PythonPath]
@="E:\\Python38\\Lib;E:\\Python38\\DLLs"

등록한 다음, windbg 내에서 해당 런타임의 파이썬을 선택하면 됩니다.

0:000> .load d:\wext\x64\pykd.dll

0:000> !pykd.info

pykd bootstrapper version: 2.0.0.25

Installed python:

Version:        Status:     Image:
------------------------------------------------------------------------------
  3.8 x86-64    Unloaded    E:\Python38\python38.dll
* 3.9 x86-64    Loaded      C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64\python39.dll

0:000> !pykd.select -3.8
0:000> !pykd.info

pykd bootstrapper version: 2.0.0.25

Installed python:

Version:        Status:     Image:
------------------------------------------------------------------------------
* 3.8 x86-64    Loaded      E:\Python38\python38.dll
  3.9 x86-64    Loaded      C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64\python39.dll




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







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

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

비밀번호

댓글 작성자
 




... [16]  17  18  19  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13229정성태1/25/20235084.NET Framework: 2090. C# - UDP Datagram의 최대 크기
13228정성태1/24/20235213.NET Framework: 2089. C# - WMI 논리 디스크가 속한 물리 디스크의 정보를 얻는 방법 [2]파일 다운로드1
13227정성태1/23/20234914개발 환경 구성: 659. Windows - IP MTU 값을 바꿀 수 있을까요? [1]
13226정성태1/23/20234586.NET Framework: 2088. .NET 5부터 지원하는 GetRawSocketOption 사용 시 주의할 점
13225정성태1/21/20233839개발 환경 구성: 658. Windows에서 실행 중인 소켓 서버를 다른 PC 또는 WSL에서 접속할 수 없는 경우
13224정성태1/21/20234193Windows: 221. Windows - Private/Public/Domain이 아닌 네트워크 어댑터 단위로 방화벽을 on/off하는 방법
13223정성태1/20/20234390오류 유형: 838. RDP 연결 오류 - The two computers couldn't connect in the amount of time allotted
13222정성태1/20/20234065개발 환경 구성: 657. WSL - DockerDesktop.vhdx 파일 위치를 옮기는 방법
13221정성태1/19/20234300Linux: 57. C# - 리눅스 프로세스 메모리 정보파일 다운로드1
13220정성태1/19/20234419오류 유형: 837. NETSDK1045 The current .NET SDK does not support targeting .NET ...
13219정성태1/18/20233983Windows: 220. 네트워크의 인터넷 접속 가능 여부에 대한 판단 기준
13218정성태1/17/20233925VS.NET IDE: 178. Visual Studio 17.5 (Preview 2) - 포트 터널링을 이용한 웹 응용 프로그램의 외부 접근 허용
13217정성태1/13/20234503디버깅 기술: 185. windbg - 64비트 운영체제에서 작업 관리자로 뜬 32비트 프로세스의 덤프를 sos로 디버깅하는 방법
13216정성태1/12/20234761디버깅 기술: 184. windbg - 32비트 프로세스의 메모리 덤프인 경우 !peb 명령어로 나타나지 않는 환경 변수
13215정성태1/11/20236316Linux: 56. 리눅스 - /proc/pid/stat 정보를 이용해 프로세스의 CPU 사용량 구하는 방법 [1]
13214정성태1/10/20235866.NET Framework: 2087. .NET 6부터 SourceGenerator와 통합된 System.Text.Json [1]파일 다운로드1
13213정성태1/9/20235408오류 유형: 836. docker 이미지 빌드 시 "RUN apt install ..." 명령어가 실패하는 이유
13212정성태1/8/20235158기타: 85. 단정도/배정도 부동 소수점의 정밀도(Precision)에 따른 형변환 손실
13211정성태1/6/20235187웹: 42. (https가 아닌) http 다운로드를 막는 웹 브라우저
13210정성태1/5/20234276Windows: 219. 윈도우 x64의 경우 0x00000000`7ffe0000 아래의 주소는 왜 사용하지 않을까요?
13209정성태1/4/20234177Windows: 218. 왜 윈도우에서 가상 메모리 공간은 64KB 정렬이 된 걸까요?
13208정성태1/3/20234121.NET Framework: 2086. C# - Windows 운영체제의 2MB Large 페이지 크기 할당 방법파일 다운로드1
13207정성태12/26/20224418.NET Framework: 2085. C# - gpedit.msc의 "User Rights Assignment" 특권을 코드로 설정/해제하는 방법파일 다운로드1
13206정성태12/24/20224649.NET Framework: 2084. C# - GetTokenInformation으로 사용자 SID(Security identifiers) 구하는 방법 [3]파일 다운로드1
13205정성태12/24/20224978.NET Framework: 2083. C# - C++과의 연동을 위한 구조체의 fixed 배열 필드 사용 (2)파일 다운로드1
13204정성태12/22/20224276.NET Framework: 2082. C# - (LSA_UNICODE_STRING 예제로) CustomMarshaler 사용법파일 다운로드1
... [16]  17  18  19  20  21  22  23  24  25  26  27  28  29  30  ...