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)
10839정성태8/22/201532823Windows: 112. 윈도우 10에서 터치 키보드를 안 뜨게 할 수 있는 방법 [5]
10838정성태8/22/201543780오류 유형: 304. Windows 10에서 VPN 연결이 실패한다면? [3]
10837정성태8/21/201521534오류 유형: 303. Your computer is low on memory. Save your files and close these programs...
10836정성태8/21/201524459오류 유형: 302. 설치 파일 실행 시 "This app can't run on your PC" 오류가 뜬다면?
10835정성태8/21/201531720웹: 31. Microsoft Edge 브라우저를 명령행에서 띄우는 방법 [1]
10834정성태8/19/201525287.NET Framework: 526. 닷넷 - 값 형식을 new 없이 생성하면 0으로 초기화되지 않는다?
10833정성태8/18/201529520.NET Framework: 525. C# - 닷넷에서 프로세스가 열고 있는 파일 목록을 구하는 방법파일 다운로드1
10832정성태8/17/201533134디버깅 기술: 74. x64 콜 스택 인자 추적과 windbg의 Child-SP, RetAddr, Args to Child 값 확인 [8]파일 다운로드2
10831정성태8/13/201534747.NET Framework: 524. .NET 4.0과 .NET 4.5의 컴파일 결과 차이점 [1]파일 다운로드1
10830정성태8/12/201528169개발 환경 구성: 275. Web.config이 적용되지 않는 프로젝트에서 Razor 템플릿 파일의 C# 컴파일러 버전 제어 [1]
10829정성태8/10/201530332개발 환경 구성: 274. PowerShell/명령행에서 JDK/JRE를 무인(unattended)/자동 설치를 하는 방법 [3]
10828정성태8/10/201535652웹: 30. Edge 브라우저에서 "이 웹 사이트에는 Internet Explorer가 필요함" 단계를 없애는 방법 [1]
10827정성태7/8/201535816개발 환경 구성: 273. Visual Studio 2015에서 Github와 연동하는 방법 [3]
10826정성태7/8/201527305오류 유형: 301. The trust relationship between this workstation and the primary domain failed. - 두 번째 이야기
10825정성태7/8/201524565개발 환경 구성: 272. Visual Studio IDE 설치 없이 Visual Studio SDK 설치하는 방법
10824정성태7/7/201530828개발 환경 구성: 271. Team Foundation Server 2015 설치 방법 [1]
10823정성태7/7/201532281오류 유형: 300. SqlException (0x80131904): Unable to open the physical file
10822정성태7/7/201530248오류 유형: 299. The 'Visual C++ Project System Package' package did not load correctly.
10821정성태7/7/201523963오류 유형: 298. Unable to start debugging on the web server. IIS does not list a web site that matches the launched URL.
10820정성태7/7/201529397오류 유형: 297. HTTP Error 503. The service is unavailable. - 두 번째
10819정성태7/2/201532381오류 유형: 296. SQL Server Express 시작 오류 - error code 3417
10818정성태7/1/201531996오류 유형: 295. HTTP Error 503. The service is unavailable. [1]
10817정성태6/29/201537026.NET Framework: 523. C# 람다(Lambda)에서 변수 캡처 방식 [3]
10816정성태6/25/201531306.NET Framework: 522. 닷넷의 어셈블리 서명 데이터 확인 방법파일 다운로드1
10815정성태6/23/201530304Graphics: 1. 자네 나와 함께... UNITY 하지 않겠는가! [4]
10814정성태6/22/201528177.NET Framework: 521. Roslyn을 이용해 C# 문법 변형하기 (2) [5]
... 121  122  123  124  125  126  [127]  128  129  130  131  132  133  134  135  ...