Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 169. Hyper-V의 VM에 대한 메모리 덤프를 뜨는 방법 [링크 복사], [링크+제목 복사]
조회: 10243
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 10개 있습니다.)
Windows: 63. 윈도우 서버 2012 - Hyper-V의 새로운 기능 Live Migration
; https://www.sysnet.pe.kr/2/0/1356

개발 환경 구성: 211. Hyper-V - Generation 2 유형의 VM 생성 시 ISO 부팅이 안된다면?
; https://www.sysnet.pe.kr/2/0/1603

개발 환경 구성: 236. Hyper-V에 설치한 리눅스 VM의 VHD 크기 늘리는 방법
; https://www.sysnet.pe.kr/2/0/1742

개발 환경 구성: 317. Hyper-V 내의 VM에서 다시 Hyper-V를 설치: Nested Virtualization
; https://www.sysnet.pe.kr/2/0/11218

개발 환경 구성: 405. Hyper-V 가상 머신에서 직렬 포트(Serial Port, COM Port) 사용
; https://www.sysnet.pe.kr/2/0/11720

.NET Framework: 798. C# - Hyper-V 가상 머신의 직렬 포트와 연결된 Named Pipe 간의 통신
; https://www.sysnet.pe.kr/2/0/11722

디버깅 기술: 169. Hyper-V의 VM에 대한 메모리 덤프를 뜨는 방법
; https://www.sysnet.pe.kr/2/0/12284

개발 환경 구성: 608. Hyper-V 가상 머신에 Console 모드로 로그인하는 방법
; https://www.sysnet.pe.kr/2/0/12859

개발 환경 구성: 664. Hyper-V에 설치한 리눅스 VM의 VHD 크기 늘리는 방법 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/13246

Windows: 259. Hyper-V Generation 1 유형의 VM을 Generation 2 유형으로 바꾸는 방법
; https://www.sysnet.pe.kr/2/0/13564




Hyper-V의 VM에 대한 메모리 덤프를 뜨는 방법

아래의 글을 읽어 보면,

윈도우즈 룻킷 - 윈도우즈 디펜더 무력화
; https://learn.darungrim.com/contents/windows10-rootkits-disabling-windows-defender.html

VMWare의 VM에 대한 메모리 덤프를 Vmss2core라는 도구를 이용해 뜨는 방법이 나옵니다. 왠지 Hyper-V도 제공할 거라는 ^^ 추측으로 검색해 보니 다음의 글이 나옵니다.

Collect Memory dump from virtual machine hosted in Hyper-V
; https://knowledge.broadcom.com/external/article/184806/collect-memory-dump-from-virtual-machine.html

Use LiveKD to get dump out of VM
; https://windowsprivatecloud.wordpress.com/about/use-livekd-to-get-dump-out-of-vm/

즉, 다음과 같은 형식으로 livekd를 이용해 VM의 덤프를 뜰 수 있는 것인데,

livekd -hv <vmname> -p -o C:\Memory.dmp

예를 들어, 이름이 windows2019인 VM의 덤프를 뜨려면 다음과 같이 실행하면 됩니다.

C:\WINDOWS\system32> livekd -hv windows2019 -p -o c:\temp\memory.dmp

LiveKd v5.63 - Execute kd/windbg on a live system
Sysinternals - www.sysinternals.com
Copyright (C) 2000-2020 Mark Russinovich and Ken Johnson

Unexpected failure from VidGetPartitionIds.
Writing c:\temp\memory.dmp: 02%

그럼, 해당 VM은 VM paused 상태로 바뀌고, (제 테스트 환경이 좀 느리긴 하지만) 무려 33분 정도가 걸려 4GB 메모리 덤프를 마치게 됩니다. 현실적인 이유로 봤을 때, 아주 특별한 상황이 아니고서는 쓸 일이 별로 없을 것 같습니다. ^^;




검색해 보면, PowerShell의 Debug-VM 명령어도 나옵니다.

Advanced troubleshooting for Windows-based computer freeze issues
; https://learn.microsoft.com/ko-kr/windows/client-management/troubleshoot-windows-freeze#use-memory-dump-to-collect-data-for-the-virtual-machine-thats-running-in-a-frozen-state

다른 점이라면 대상 VM을 아예 BSOD를 발생시켜 덤프를 뜨게 만드는 것인데, 다음과 같이 실행해 보면,

PS C:\WINDOWS\system32> Debug-VM -Name "windows2019" -InjectNonMaskableInterrupt

(시스템을 다운시키는 것이므로) 질문을 한번 받게 되고,

Are you sure you want to inject a non-maskable interrupt into the virtual machine "windows2019"?

yes를 선택하면 "NMI HARDWARE FAILURE" 예외를 발생시켜 "C:\Windows\MEMORY.DMP" 파일로 덤프를 남기며 재부팅이 됩니다. 이때의 이벤트 로그에는 다음과 같은 메시지가 남게 됩니다.

로그 이름:         System
원본:            Microsoft-Windows-WER-SystemErrorReporting
날짜:            2020-07-14 오후 1:15:12
이벤트 ID:        1001
작업 범주:         없음
수준:            오류
키워드:           클래식
사용자:           해당 없음
컴퓨터:           windows2019.testad.com
설명:
컴퓨터가 오류 검사 후 다시 부팅되었습니다. 오류 검사: 0x00000080 (0x00000000004f4454, 0x0000000000000000, 0x0000000000000000, 0x0000000000000000). 덤프 저장 위치: C:\Windows\MEMORY.DMP. 보고서 ID: eaa12cd2-c8f0-455e-be62-e44fbff10240




참고로, livekd를 실행했을 때 이런 오류가 발생한다면?

C:\WINDOWS\system32> livekd -hv windows2019 -p -o c:\temp\memory.dmp

LiveKd v5.3 - Execute kd/windbg on a live system
Sysinternals - www.sysinternals.com
Copyright (C) 2000-2012 Mark Russinovich and Ken Johnson

Unexpected failure from VidGetPartitionIds.
Invalid Hyper-V VM: windows2019
Specify the GUID or VM name of a running VM.
Use LiveKd -hvl to list running VMs.

C:\WINDOWS\system32> livekd -hvl

LiveKd v5.3 - Execute kd/windbg on a live system
Sysinternals - www.sysinternals.com
Copyright (C) 2000-2012 Mark Russinovich and Ken Johnson

Unexpected failure from VidGetPartitionIds.
Unable to list active Hyper-V partitions: Error 31.
In order to perform Hyper-V VM debugging, this machine must have the Hyper-V role installed and active.

livekd를 최신 버전(5.63)으로 업데이트하시면 됩니다. 정상적으로 지원하기 시작하는 livekd라면 -hvl 옵션에서 다음과 같은 식의 VM 목록을 출력하게 될 것입니다.

C:\WINDOWS\system32> livekd -hvl

LiveKd v5.63 - Execute kd/windbg on a live system
Sysinternals - www.sysinternals.com
Copyright (C) 2000-2020 Mark Russinovich and Ken Johnson

Partition GUID                         Name
902490AE-DA6C-4472-89E8-3F5A03BBDC87   win7
75DB36E8-F90D-4462-9EF2-6BAE20CDCDF5   win8
1AB47C73-1FB6-426E-AE80-EBF774483290   win10

또는, 실행시 다음과 같은 오류 메시지를 뱉는 경우도 있을 것입니다.

C:\WINDOWS\system32> livekd -hv windows2019 -p -o c:\temp\memory.dmp

LiveKd v5.63 - Execute kd/windbg on a live system
Sysinternals - www.sysinternals.com
Copyright (C) 2000-2020 Mark Russinovich and Ken Johnson

Unexpected failure from VidGetPartitionIds.
Error finding kd.exe:
The system cannot find the file specified.

오류 내용을 잘 보면, windbg의 kd.exe를 찾지 못해 발생하는 것이므로 PATH에 windbg의 경로를 걸어준 후 실행하면 됩니다.

C:\WINDOWS\system32> set PATH=C:\Program Files (x86)\Windows Kits\8.1\Debuggers\x64;%PATH%

// set PATH=C:\Program Files (x86)\Windows Kits\10\Debuggers\x64;%PATH%

C:\WINDOWS\system32> livekd -hv windows2019 -p -o c:\temp\memory.dmp

그러니까 결국, Sysinternals의 livekd.exe와 windbg의 kd.exe가 함께 필요한 것입니다.




좀 더 검색해 보면, vm2dmp라는 도구도 찾을 수 있을 것입니다.

WindowsDiag/SHA/vm2dmp/
; https://github.com/CSS-Windows/WindowsDiag/tree/master/SHA/vm2dmp

Microsoft Hyper-V VM State to Memory Dump Converter
; https://learn.microsoft.com/en-us/archive/blogs/hugofe/microsoft-hyper-v-vm-state-to-memory-dump-converter

VM2DMP - Hyper-V (tm) VM State to Memory Dump Converter
; https://learn.microsoft.com/en-us/archive/blogs/virtualworld/vm2dmp-hyper-v-tm-vm-state-to-memory-dump-converter

하지만 아쉽게 이 도구는 현재 deprecated 상태라고 봐야 할 것입니다.

However, this tool works only on files created with Hyper-V Version 1 & 2 (Hyper-V/Windows Server 2008 & R2). When snapshots or saved states created on Hyper-V 2012 or 2012 R2 are tried being converted, the tool will fail.

그렇긴 한데, 배포본을 보면 2016과 2019에 대한 지원을 하는 듯 보여서,

vm2dmp_HYPER-V2016.zip
vm2dmp_HYPER-V2019.zip

실행해 봤지만 (어떻게 시도해봐도 ^^;) 오류가 발생합니다. (혹시, 2016/2019에서 vm2dmp로 성공하신 분은 덧글 부탁드립니다. ^^)

C:\vm2dmp\Debuggers\x64> vm2dmp.exe -vmrs C:\TESTVM\windows2019\Snapshots\730379DE-CF77-44DF-A802-3026F6438C5C.VMRS -dmp c:\temp\memory2.dmp
VM2DMP: Hyper-V VM State to Memory Dump Converter (version 3.0.0.0)

ERROR: Library C:\WINDOWS\SYSTEM32\symsrv.dll could not be found in the same directory as loaded library dbghelp.dll. hr = 0x80070003.
ERROR: You need to have vm2dmp.exe in Debugging Tools for Windows installation folder or have dbghelp.dll and symsrv.dll in the same working directory as vm2dmp.exe.
'
ERROR: Result code 0x3

C:\vm2dmp\Debuggers\x64> vm2dmp.exe -vmrs "C:\TESTVM\windows2019\Snapshots\730379DE-CF77-44DF-A802-3026F6438C5C.VMRS" -dmp "c:\temp\memory2.dmp"
VM2DMP: Hyper-V VM State to Memory Dump Converter (version 3.0.0.0)

INFO: Using VMRS file C:\TESTVM\windows2019\Snapshots\730379DE-CF77-44DF-A802-3026F6438C5C.vmrs

ERROR: Result code 0x2

C:\vm2dmp\Debuggers\x64> vm2dmp -vm "windows2019" -snap "windows2019-snap" -dmp "c:\temp\memory2.dmp"
VM2DMP: Hyper-V VM State to Memory Dump Converter (version 3.0.0.0)

ERROR: Result code 0x80004005

C:\vm2dmp\Debuggers\x64> vm2dmp -vm "windows2019" -snap "windows2019 - (2020-07-14 - 오후 2:48:10)" -dmp "c:\temp\memory2.dmp"
VM2DMP: Hyper-V VM State to Memory Dump Converter (version 3.0.0.0)

INFO: Using VMRS file C:\TESTVM\windows2019\Snapshots\46CE2553-6F58-4FCA-91A4-5199DA49CB61.vmrs

ERROR: Result code 0x2

C:\vm2dmp\Debuggers\x64> vm2dmp -vmrs "C:\TESTVM\windows2019\Virtual Machines\044EADA9-7BAA-4B19-AA54-4347E3D1FB38.VMRS" -dmp "c:\temp\memory2.dmp"
VM2DMP: Hyper-V VM State to Memory Dump Converter (version 3.0.0.0)

INFO: Using VMRS file C:\TESTVM\windows2019\Virtual Machines\044EADA9-7BAA-4B19-AA54-4347E3D1FB38.VMRS

ERROR: Result code 0x2




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 4/13/2023]

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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...
NoWriterDateCnt.TitleFile(s)
13253정성태2/9/20235151Windows: 222. C# - 다른 윈도우 프로그램이 실행되었음을 인식하는 방법파일 다운로드1
13252정성태2/9/20233971오류 유형: 844. ssh로 명령어 수행 시 멈춤 현상
13251정성태2/8/20234424스크립트: 44. 파이썬의 3가지 스레드 ID
13250정성태2/8/20236232오류 유형: 843. System.InvalidOperationException - Unable to configure HTTPS endpoint
13249정성태2/7/20235068오류 유형: 842. 리눅스 - You must wait longer to change your password
13248정성태2/7/20234142오류 유형: 841. 리눅스 - [사용자 계정] is not in the sudoers file. This incident will be reported.
13247정성태2/7/20235041VS.NET IDE: 180. Visual Studio - 닷넷 소스 코드 디버깅 중 "Decompile source code"가 동작하는 않는 문제
13246정성태2/6/20234159개발 환경 구성: 664. Hyper-V에 설치한 리눅스 VM의 VHD 크기 늘리는 방법 - 두 번째 이야기
13245정성태2/6/20234735.NET Framework: 2093. C# - PEM 파일을 이용한 RSA 개인키/공개키 설정 방법파일 다운로드1
13244정성태2/5/20234079VS.NET IDE: 179. Visual Studio - External Tools에 Shell 내장 명령어 등록
13243정성태2/5/20234949디버깅 기술: 190. windbg - Win32 API 호출 시점에 BP 거는 방법 [1]
13242정성태2/4/20234368디버깅 기술: 189. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.UnauthorizedAccessException
13241정성태2/3/20233887디버깅 기술: 188. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.IO.FileNotFoundException
13240정성태2/1/20234042디버깅 기술: 187. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.Web.HttpException
13239정성태2/1/20233703디버깅 기술: 186. C# - CacheDependency의 숨겨진 예외 - System.Web.HttpException
13238정성태1/31/20235767.NET Framework: 2092. IIS 웹 사이트를 TLS 1.2 또는 TLS 1.3 프로토콜로만 운영하는 방법
13237정성태1/30/20235437.NET Framework: 2091. C# - 웹 사이트가 어떤 버전의 TLS/SSL을 지원하는지 확인하는 방법
13236정성태1/29/20235054개발 환경 구성: 663. openssl을 이용해 인트라넷 IIS 사이트의 SSL 인증서 생성
13235정성태1/29/20234617개발 환경 구성: 662. openssl - 윈도우 환경의 명령행에서 SAN 적용하는 방법
13234정성태1/28/20235685개발 환경 구성: 661. dnSpy를 이용해 소스 코드가 없는 .NET 어셈블리의 코드를 변경하는 방법 [1]
13233정성태1/28/20237015오류 유형: 840. C# - WebClient로 https 호출 시 "The request was aborted: Could not create SSL/TLS secure channel" 예외 발생
13232정성태1/27/20234795스크립트: 43. uwsgi의 --processes와 --threads 옵션
13231정성태1/27/20233685오류 유형: 839. python - TypeError: '...' object is not callable
13230정성태1/26/20234077개발 환경 구성: 660. WSL 2 내부로부터 호스트 측의 네트워크로 UDP 데이터가 1개의 패킷으로만 제한되는 문제
13229정성태1/25/20235066.NET Framework: 2090. C# - UDP Datagram의 최대 크기
13228정성태1/24/20235190.NET Framework: 2089. C# - WMI 논리 디스크가 속한 물리 디스크의 정보를 얻는 방법 [2]파일 다운로드1
1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...