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

windbg - !py 확장 명령어 실행 시 "failed to find python interpreter" (2)

지난 글에 정리했었는데,

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

이번에 오랜만에 구성하다가 오류가 발생해서 다시 한번 정리해봤습니다. ^^




pykd.info 명령어를 수행했는데,

0:000> !pykd.info
failed to find python interpreter

"failed to find python interpreter" 오류가 발생하면, 레지스트리 설정을 하면 됩니다. 테스트해 보면 딱 이 정도의 레지스트리 설정으로 충분합니다.

Windows Registry Editor Version 5.00


[HKEY_LOCAL_MACHINE\SOFTWARE\Python]

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore]

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\3.7]

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\3.7\InstallPath]
@="C:\\Python37\\"

[HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\3.7\PythonPath]
@="C:\\Python37\\Lib\\"

그럼, 적어도 !pykd.info 명령어까지는 잘 될 것입니다.

0:000> !pykd.info

pykd bootstrapper version: 2.0.0.13

Installed python:

Version:        Status:     Image:
------------------------------------------------------------------------------
* 3.7 x86-64    Unloaded    C:\Python37\python37.dll

참고로, "!py" 명령어는 python을 외부 프로세스로 실행하는 것이 아니라, dll 파일을 로드해서 실행합니다. 즉, "EngHost.exe" 내에 "!pykd.info" 출력으로 나온 DLL, 위의 경우 "C:\Python37\python37.dll" 파일을 in-process로 로드해 파이썬 스크립트를 실행합니다.




대부분의 경우 위와 같은 정도만 되면 정상적으로 !py 명령어도 수행할 텐데요, 64비트 운영체제에서 32비트 덤프를 뜬 경우에는 pykd.dll도 32비트 DLL을 사용해야 하고, 파이썬 역시 32비트 버전을 레지스트리에 등록해야 합니다.

이때, 레지스트리 설정을 이렇게 하면,

Windows Registry Editor Version 5.00


[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Python]

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Python\PythonCore]

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Python\PythonCore\3.7]

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Python\PythonCore\3.7\InstallPath]
@="C:\\Python37_32\\"

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Python\PythonCore\3.7\PythonPath]
@="C:\\Python37_32\\Lib\\"

(!pykd.info 명령어는 문제 없지만) !py 명령어를 수행했을 때 이런 오류가 발생합니다.

0:000> !py
failed to load python module

왜냐하면, 32비트에 대해서는 레지스트리 경로에 반드시 "-32"라는 플랫폼 접미사를 붙여야 하기 때문입니다. 그래서 정상 동작하려면 이렇게 등록해야 합니다.

Windows Registry Editor Version 5.00


[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Python]

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Python\PythonCore]

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Python\PythonCore\3.7-32]

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Python\PythonCore\3.7-32\InstallPath]
@="C:\\Python37_32\\"

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Python\PythonCore\3.7-32\PythonPath]
@="C:\\Python37_32\\Lib\\"

물론, 위의 레지스트리 설정은 "Windows installer (64-bit)", "Windows installer (32 -bit)" 등의 설치 버전이라면 자동으로 구성해 주므로 신경 쓰지 않아도 됩니다. 단지, "Windows embeddable package (64-bit)" 등의 압축 파일을 풀어 사용하는 경우에는 위와 같이 레지스트리 구성을 직접 해줘야 합니다.




마지막으로, 이런 오류가 발생한다면?

ModuleNotFoundError: No module named 'pykd'

!pykd.info 명령어의 결과로 나오는 경로에 대해,

0:000> !pykd.info

pykd bootstrapper version: 2.0.0.25

Installed python:

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

"C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64" 디렉터리로 이동해 직접 pip install로 설치하시면 됩니다.

C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python39_64> python -m pip install pykd




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







[최초 등록일: ]
[최종 수정일: 6/20/2024]

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)
13502정성태12/26/202312301닷넷: 2187. C# - 다른 프로세스의 환경변수 읽는 예제파일 다운로드1
13501정성태12/25/202311649개발 환경 구성: 700. WSL + uwsgi - IPv6로 바인딩하는 방법
13500정성태12/24/202312310디버깅 기술: 194. Windbg - x64 가상 주소를 물리 주소로 변환
13498정성태12/23/202313460닷넷: 2186. 한국투자증권 KIS Developers OpenAPI의 C# 래퍼 버전 - eFriendOpenAPI NuGet 패키지
13497정성태12/22/202312162오류 유형: 885. Visual Studiio - error : Could not connect to the remote system. Please verify your connection settings, and that your machine is on the network and reachable.
13496정성태12/21/202311337Linux: 66. 리눅스 - 실행 중인 프로세스 내부의 환경변수 설정을 구하는 방법 (gdb)
13495정성태12/20/202311837Linux: 65. clang++로 공유 라이브러리의 -static 옵션 빌드가 가능할까요?
13494정성태12/20/202311706Linux: 64. Linux 응용 프로그램의 (C++) so 의존성 줄이기(ReleaseMinDependency) - 두 번째 이야기
13493정성태12/19/202312320닷넷: 2185. C# - object를 QueryString으로 직렬화하는 방법
13492정성태12/19/202311511개발 환경 구성: 699. WSL에 nopCommerce 예제 구성
13491정성태12/19/202310336Linux: 63. 리눅스 - 다중 그룹 또는 사용자를 리소스에 권한 부여
13490정성태12/19/202311474개발 환경 구성: 698. Golang - GLIBC 의존을 없애는 정적 빌드 방법
13489정성태12/19/202311119개발 환경 구성: 697. GoLand에서 ldflags 지정 방법
13488정성태12/18/202310426오류 유형: 884. HTTP 500.0 - 명령행에서 실행한 ASP.NET Core 응용 프로그램을 실행하는 방법
13487정성태12/16/202312153개발 환경 구성: 696. C# - 리눅스용 AOT 빌드를 docker에서 수행 [1]
13486정성태12/15/202310552개발 환경 구성: 695. Nuget config 파일에 값 설정/삭제 방법
13485정성태12/15/202310140오류 유형: 883. dotnet build/restore - error : Root element is missing
13484정성태12/14/202311637개발 환경 구성: 694. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법
13483정성태12/14/202311529닷넷: 2184. C# - 하나의 resource 파일을 여러 프로그램에서 (AOT 시에도) 사용하는 방법파일 다운로드1
13482정성태12/13/202313208닷넷: 2183. C# - eFriend Expert OCX 예제를 .NET Core/5+ Console App에서 사용하는 방법 [2]파일 다운로드1
13481정성태12/13/202312070개발 환경 구성: 693. msbuild - .NET Core/5+ 프로젝트에서 resgen을 이용한 리소스 파일 생성 방법파일 다운로드1
13480정성태12/12/202314029개발 환경 구성: 692. Windows WSL 2 + Chrome 웹 브라우저 설치
13479정성태12/11/202310781개발 환경 구성: 691. WSL 2 (Ubuntu) + nginx 환경 설정
13477정성태12/8/202311536닷넷: 2182. C# - .NET 7부터 추가된 Int128, UInt128 [1]파일 다운로드1
13476정성태12/8/202311888닷넷: 2181. C# - .NET 8 JsonStringEnumConverter의 AOT를 위한 개선파일 다운로드1
13475정성태12/7/202312464닷넷: 2180. .NET 8 - 함수 포인터에 대한 Reflection 정보 조회파일 다운로드1
... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...