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

Hyper-V Manager - VM 목록의 CPU Usage 항목이 항상 0%로 나오는 문제

(미리 말씀드리지만, 이 문제는 해결되지 않았습니다.)

이상하군요, 원래 VM의 CPU 값이 잘 나왔었는데 어느 순간부터 무조건 0%로만 나옵니다.

hyperv_cpu_is_zero_1.png

정확하게 기억은 안 나지만, 아마도 Hyper-V의 "Configuration Version" 지원이 "12.0"으로 올라가는 윈도우부터 그랬던 것 같은데요, 가령 Windows 11인 경우 24H2부터, Windows Server의 경우 2025 버전에 있는 Hyper-V부터 저런 현상이 발생한 것 같습니다. (실제로, 제가 가지고 있는 Windows 11 23H2의 Hyper-V는 CPU Usage가 정상적으로 나옵니다.)

물론, 실제로 0%일 수도 있지만 CPU 부하를 주는 프로그램을 띄워도 항상 0으로 나옵니다. 검색해 보면, 위의 출력은 사실상 PowerShell의 Get-VM의 결과와 같다고 하는데요, 실제로 테스트해 보면 그 명령어의 CPUUsage 항목도 0%로 나옵니다.

PS C:\Windows\System32> Get-VM -Name win2019

Name    State   CPUUsage(%) MemoryAssigned(M) Uptime             Status             Version
----    -----   ----------- ----------------- ------             ------             -------
win2019 Running 0           8192              3.17:46:11.6150000 Operating normally 12.0

PS C:\Windows\System32> Get-VM win2019 | select -ExpandProperty VMIntegrationService

VMName  Name                    Enabled PrimaryStatusDescription SecondaryStatusDescription
------  ----                    ------- ------------------------ --------------------------
win2019 Guest Service Interface True    OK
win2019 Heartbeat               True    OK
win2019 Key-Value Pair Exchange True    OK
win2019 Shutdown                True    OK
win2019 Time Synchronization    True    OK
win2019 VSS                     True    OK

그 외에도 ResourceMeteringEnabled를 켠 VM에 대한 Measure-VM 명령어도 AvgCPU(Mhz)가 0으로 나옵니다.

PS C:\Windows\System32> Get-VM -Name win2019 | Enable-VMResourceMetering

PS C:\Windows\System32> Measure-VM -Name win2019

VMName  AvgCPU(MHz) AvgRAM(M) MaxRAM(M) MinRAM(M) TotalDisk(M) NetworkInbound(M) NetworkOutbound(M)
------  ----------- --------- --------- --------- ------------ ----------------- ------------------
win2019 0           8192      8192      8192      72704        251               58

참고로, WMI의 Win32_Processor를 이용한 CPU 사용량을 확인해 보면 정상적으로 나오긴 합니다.

PS C:\Windows\System32> (Get-WMIObject -ComputerName "win2019" Win32_Processor).LoadPercentage
13




더욱 이상한 것은, 관련 정보를 찾아보려고 해도 딱히 검색이 되지 않는다는 점입니다. 그나마 (Hyper-V Manager가 아닌) VMM과 관련해 아래와 같은 글이 있긴 한데,

VMM 2016: 0% CPU shown for all guest VMs
; https://learn.microsoft.com/en-us/answers/questions/321785/vmm-2016-0-cpu-shown-for-all-guest-vms

Virtual Machine Manager 2012 R2 may show CPU Average of Virtual Machines [VM’s] as 0 % percent
; http://www.kuskaya.info/2015/11/20/virtual-machine-manager-2012-r2-may-show-cpu-average-of-virtual-machines-vms-as-0-percent/

혹시나 싶어 VM과 호스트 모두 성능 카운터를 다시 등록하고 재부팅을 해도,

cd c:\windows\system32
lodctr /R
cd c:\windows\sysWOW64
lodctr /R

WINMGMT.EXE /RESYNCPERF

여전히 0%로 나옵니다. 마지막으로 ^^ 이와 관련해서 질문을 남겼는데,

CPU Usage columns always show as 0% in Hyper-V Manager
; https://learn.microsoft.com/en-us/answers/questions/2200481/cpu-usage-columns-always-show-as-0-in-hyper-v-mana

아쉽게도, 다른 성능 카운터를 참조하라고만 하고 저 문제 자체에 대한 해결책이 나오진 않았습니다. 혹시 여러분의 Hyper-V Manager는 "CPU Usage" 항목의 값이 정상적으로 나오나요? ^^




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







[최초 등록일: ]
[최종 수정일: 3/5/2025]

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

비밀번호

댓글 작성자
 




... 121  122  123  124  125  126  127  128  129  130  131  132  [133]  134  135  ...
NoWriterDateCnt.TitleFile(s)
1730정성태8/11/201422108개발 환경 구성: 234. Royal TS의 터미널(Terminal) 연결에서 한글이 깨지는 현상 해결 방법
1729정성태8/11/201418181오류 유형: 236. SqlConnection - The requested Performance Counter is not a custom counter, it has to be initialized as ReadOnly.
1728정성태8/8/201430214.NET Framework: 453. C# - 오피스 파워포인트(Powerpoint) 파일을 WinForm에서 보는 방법파일 다운로드1
1727정성태8/6/201420469오류 유형: 235. SignalR 오류 메시지 - Counter 'Messages Bus Messages Published Total' does not exist in the specified Category. [2]
1726정성태8/6/201419383오류 유형: 234. IIS Express에서 COM+ 사용 시 SecurityException - "Requested registry access is not allowed" 발생
1725정성태8/6/201421326오류 유형: 233. Visual Studio 2013 Update3 적용 후 Microsoft.VisualStudio.Web.PageInspector.Runtime 모듈에 대한 FileNotFoundException 예외 발생
1724정성태8/5/201426091.NET Framework: 452. .NET System.Threading.Thread 개체에서 Native Thread Id를 구하는 방법 - 두 번째 이야기 [1]파일 다운로드1
1723정성태7/29/201458300개발 환경 구성: 233. DirectX 9 예제 프로젝트 빌드하는 방법 [3]파일 다운로드1
1722정성태7/25/201421019오류 유형: 232. IIS 500 Internal Server Error - NTFS 암호화된 폴더에 웹 애플리케이션이 위치한 경우
1721정성태7/24/201424034.NET Framework: 451. 함수형 프로그래밍 개념 - 리스트 해석(List Comprehension)과 순수 함수 [2]
1720정성태7/23/201422062개발 환경 구성: 232. C:\WINDOWS\system32\LogFiles\HTTPERR 폴더에 로그 파일을 남기지 않는 설정
1719정성태7/22/201425992Math: 13. 동전을 여러 더미로 나누는 경우의 수 세기(Partition Number) - 두 번째 이야기파일 다운로드1
1718정성태7/19/201435253Math: 12. HTML에서 수학 관련 기호/수식을 표현하기 위한 방법 - MathJax.js [4]
1716정성태7/17/201434961개발 환경 구성: 231. PC 용 무료 안드로이드 에뮬레이터 - genymotion
1715정성태7/13/201430574기타: 47. 운영체제 종료 후에도 USB 외장 하드의 전원이 꺼지지 않는 경우 [3]
1714정성태7/11/201420887VS.NET IDE: 92. Visual Studio 2013을 지원하는 IL Support 확장 도구
1713정성태7/11/201444583Windows: 98. 윈도우 시스템 디스크 용량 확보를 위한 "Package Cache" 폴더 이동 [1]
1712정성태7/10/201432856.NET Framework: 450. 영문 윈도우에서 C# 콘솔 프로그램의 유니코드 출력 방법 [3]
1711정성태7/10/201438038Windows: 97. cmd.exe 창에서 사용할 폰트를 추가하는 방법 [1]
1710정성태7/8/201430563개발 환경 구성: 230. 유니코드의 Surrogate Pair, Supplementary Characters가 뭘까요?파일 다운로드2
1709정성태7/8/201427335VS.NET IDE: 91. Visual Studio에서 32/64비트 IIS Express 실행하는 방법
1708정성태7/7/201424691VS.NET IDE: 90. Visual Studio - 사용자 정의 정적 분석 규칙 만드는 방법 [3]파일 다운로드1
1707정성태7/4/201422976.NET Framework: 449. C#에서 C++로 VARIANT 넘겨주는 방법파일 다운로드1
1706정성태7/3/201421383.NET Framework: 448. .NET SmartClient 컨트롤을 윈도우 8/2012에서 활성화하는 방법파일 다운로드1
1705정성태7/2/201435037VC++: 78. 보이어-무어(Boyer-Moore) 알고리즘이 정말 빠를까? [6]파일 다운로드1
1704정성태7/2/201421631.NET Framework: 447. w3wp.exe AppPool 재생(recycle)하는 방법 정리
... 121  122  123  124  125  126  127  128  129  130  131  132  [133]  134  135  ...