Centos7

為什麼 Windows 10 虛擬機在 KVM hyprvisor 上顯示高 CPU 負載

  • March 5, 2019

在 KVM (Centos 7) 管理程序上,Windows 10 虛擬機顯示 CPU 使用率很高。30%左右。而其他 Linux、Windows 2k16、Windows 2k12 和 Windows 7 虛擬機僅使用 1% 到 7% 的 CPU。

通過 cpu 負載,我指的是 qemu-kvm 程序的“頂部”輸出中的 %CPU 列。例如,在下面的頂部輸出中,前 2 個程序是 windows 10 虛擬機,而這個虛擬機管理程序也很少執行 linux、Windows 2k12、Windows 7 和 Windows 2k16 VMS。

top - 08:04:31 up 9 days, 20:05,  1 user,  load average: 1.07, 1.04, 0.98
Tasks: 333 total,   2 running, 165 sleeping,   0 stopped,   0 zombie
%Cpu(s):  1.4 us,  1.6 sy,  0.0 ni, 97.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem : 39623299+total, 37377676+free, 21391056 used,  1065184 buff/cache
KiB Swap:  8388604 total,  8388604 free,        0 used. 37248361+avail Mem

   PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND
570162 qemu      20   0 3053036   2.3g  30468 S  29.2  0.6 259:41.40 qemu-kvm
569759 qemu      20   0 3054316   2.3g  30964 S  28.2  0.6 252:47.93 qemu-kvm
543245 qemu      20   0 3221396   2.5g  30700 S   7.0  0.7 201:02.59 qemu-kvm
543511 qemu      20   0 3222416   2.5g  30388 R   6.0  0.7 199:15.69 qemu-kvm
  7803 root      10 -10 1005872 135920   9628 S   4.7  0.0 115:42.79 ovs-vswitchd
539175 qemu      20   0 3256520   2.5g  30796 S   2.3  0.7 136:58.51 qemu-kvm
538482 qemu      20   0 3252560   2.5g  30316 S   2.0  0.7 136:27.08 qemu-kvm
539317 qemu      20   0 3239552   2.5g  30744 S   1.7  0.7  75:38.31 qemu-kvm
539459 qemu      20   0 3233408   2.5g  30724 S   1.0  0.7  28:17.44 qemu-kvm
  7730 root      10 -10   46072   6632   3780 S   0.7  0.0   9:33.40 ovsdb-server

我環顧四周,發現了一些建議,例如

  1. 在 VM 配置中打開 hpet(高精度事件計時器)
  2. 在 VM 配置中打開平板電腦 USB 設備

但這些似乎都不能解決問題。

我在 XEN 管理程序上沒有看到這樣的負載問題。

管理程序是 Centos 7.6.1810,核心為 4.20.8-1.el7.elrepo.x86_64 和 qemu-kvm-1.5.3-160

下面是執行 VM 的完整 qemu 選項。

/usr/libexec/qemu-kvm -name 7f96031a1afac1394534792b82606e2e -S -machine pc-i440fx-rhel7.0.0,accel=kvm,usb=off,dump-guest-core=off -cpu IvyBridge-IBRS,+ds,+acpi,+ss,+ht,+tm,+pbe,+dtes64,+monitor,+ds_cpl,+vmx,+smx,+est,+tm2,+xtpr,+pdcm,+pcid,+dca,+osxsave,+arat,+stibp,+ssbd,+xsaveopt,+pdpe1gb,hv_time,hv_relaxed,hv_vapic,hv_spinlocks=0x1fff -bios /usr/share/edk2.git/ovmf-x64/OVMF-pure-efi.fd -m 2192 -realtime mlock=off -smp 2,sockets=2,cores=1,threads=1 -uuid c66b5fed-8db2-4b35-984d-8e4c20cea10a -no-user-config -nodefaults -chardev socket,id=charmonitor,path=/var/lib/libvirt/qemu/domain-12-7f96031a1afac1394534/monitor.sock,server,nowait -mon chardev=charmonitor,id=monitor,mode=control -rtc base=localtime,driftfix=slew -global kvm-pit.lost_tick_policy=delay -no-hpet -no-shutdown -global PIIX4_PM.disable_s3=1 -global PIIX4_PM.disable_s4=1 -boot strict=on -device piix3-usb-uhci,id=usb,bus=pci.0,addr=0x1.0x2 -drive file=rbd:cvm2/7f96031a1afac1394534792b82606e2e-1:id=clientuser2:key=AQCWBYtbzlLBABAAuJJjzV6pJuY2GxHvB4Qv8g==:auth_supported=cephx\;none,format=raw,if=none,id=drive-virtio-disk0,throttling.bps-total=500000000,throttling.iops-read=2500000,throttling.iops-write=2500000 -device virtio-blk-pci,scsi=off,bus=pci.0,addr=0x4,drive=drive-virtio-disk0,id=virtio-disk0,bootindex=1 -netdev tap,fd=27,id=hostnet0,vhost=on,vhostfd=35 -device virtio-net-pci,netdev=hostnet0,id=net0,mac=00:16:ee:61:2d:ba,bus=pci.0,addr=0x3 -netdev tap,fd=36,id=hostnet1,vhost=on,vhostfd=37 -device virtio-net-pci,netdev=hostnet1,id=net1,mac=00:16:27:4e:c4:d5,bus=pci.0,addr=0x5 -chardev pty,id=charserial0 -device isa-serial,chardev=charserial0,id=serial0 -vnc 10.1.1.48:4,share=allow-exclusive -vga std -global VGA.vgamem_mb=16 -device virtio-balloon-pci,id=balloon0,bus=pci.0,addr=0x6 -msg timestamp=on

任何幫助或建議將不勝感激。

問候

我在 proxmox 論壇中發現了一些提示。在測試完所有這些之後,這對我有用

push @$cpuFlags , 'hv_synic';
push @$cpuFlags , 'hv_stimer';

將它們轉換為 libvirt xml 格式

<synic state='on'/>
<stimer state='on'/>

現在 Windows 10 VM 的 CPU 負載下降到 4% 到 7%

引用自:https://serverfault.com/questions/955439