LINUX.ORG.RU

Влияние аппаратного обеспечения на качество виртуализии 32-разрядной windows server

 , ,


0

1

Приветствую. Столкнулся с такой проблемой: в 64-разрядном Debian 11 на старом Intel Xeon E3-1220 v5 виртуальная машина с 32-разрядной Windows Server 2008 R2 SP2 работает хорошо, а на более свежем железе, Intel Core i5-10400F, та же самая виртуальная машина с точно такими же версиями Debian и VirtualBox и теми же самыми параметрами (или даже большим выделением ресурсов) - заметно тормозит, по сравнению с Xeon (сама виртуальная машина после включения загружается в 3-4 раза дольше, а также это сильно заметно при открытии и отрисовке приложений в терминальных сессиях). При этом, виртуальная машина с 64-разрядной Windows Server 2016 на i5 работает хорошо, без всяких тормозов. Пробовал выставлять разные параметры для виртуальной машины - ничего не повлияло, пришёл к выводу, что, вероятнее всего, это проблема аппаратной виртуализации 32-разрядной системы на более современном 64-разрядном процессоре.

Прошу подсказать специалистов или тех, кто сталкивался с аналогичной проблемой, что конкретно может на это влиять (может быть, поддержка каких-то специфических инструкций процессором?). Необходимо сохранить работоспособность виртуальной машины с 32-разрядным Windows Server, но перейти на более современное железо.

Старый Xeon, на котором виртуальная машина с 32-разрядным Windows Server работет хорошо:

$ lscpu
Architecture:                    x86_64
CPU op-mode(s):                  32-bit, 64-bit
Byte Order:                      Little Endian
Address sizes:                   39 bits physical, 48 bits virtual
CPU(s):                          4
On-line CPU(s) list:             0-3
Thread(s) per core:              1
Core(s) per socket:              4
Socket(s):                       1
NUMA node(s):                    1
Vendor ID:                       GenuineIntel
CPU family:                      6
Model:                           94
Model name:                      Intel(R) Xeon(R) CPU E3-1220 v5 @ 3.00GHz
Stepping:                        3
CPU MHz:                         3404.313
CPU max MHz:                     3500.0000
CPU min MHz:                     800.0000
BogoMIPS:                        6000.00
Virtualization:                  VT-x
L1d cache:                       128 KiB
L1i cache:                       128 KiB
L2 cache:                        1 MiB
L3 cache:                        8 MiB
NUMA node0 CPU(s):               0-3
Vulnerability Itlb multihit:     KVM: Mitigation: Split huge pages
Vulnerability L1tf:              Mitigation; PTE Inversion; VMX conditional cache flushes, SMT disabled
Vulnerability Mds:               Mitigation; Clear CPU buffers; SMT disabled
Vulnerability Meltdown:          Mitigation; PTI
Vulnerability Mmio stale data:   Mitigation; Clear CPU buffers; SMT disabled
Vulnerability Retbleed:          Mitigation; IBRS
Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp
Vulnerability Spectre v1:        Mitigation; usercopy/swapgs barriers and __user pointer sanitization
Vulnerability Spectre v2:        Mitigation; IBRS, IBPB conditional, RSB filling, PBRSB-eIBRS Not affected
Vulnerability Srbds:             Mitigation; Microcode
Vulnerability Tsx async abort:   Mitigation; Clear CPU buffers; SMT disabled
Flags:                           fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe sysca
                                 ll nx pdpe1gb rdtscp lm constant_tsc art arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc cpuid aperfmperf pni pclmu
                                 lqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 sdbg fma cx16 xtpr pdcm pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_
                                 timer aes xsave avx f16c rdrand lahf_lm abm 3dnowprefetch cpuid_fault epb invpcid_single pti ssbd ibrs ibpb stibp tpr_shadow 
                                 vnmi flexpriority ept vpid ept_ad fsgsbase tsc_adjust bmi1 hle avx2 smep bmi2 erms invpcid rtm mpx rdseed adx smap clflushopt
                                  intel_pt xsaveopt xsavec xgetbv1 xsaves dtherm ida arat pln pts hwp hwp_notify hwp_act_window hwp_epp md_clear flush_l1d

Более новый i5, на котором 32-разрядная виртуальная машина тормозит, а 64-разрядная работает корректно:

$ lscpu
Architecture:                    x86_64
CPU op-mode(s):                  32-bit, 64-bit
Byte Order:                      Little Endian
Address sizes:                   39 bits physical, 48 bits virtual
CPU(s):                          12
On-line CPU(s) list:             0-11
Thread(s) per core:              2
Core(s) per socket:              6
Socket(s):                       1
NUMA node(s):                    1
Vendor ID:                       GenuineIntel
CPU family:                      6
Model:                           165
Model name:                      Intel(R) Core(TM) i5-10400F CPU @ 2.90GHz
Stepping:                        3
Frequency boost:                 enabled
CPU MHz:                         1999.995
CPU max MHz:                     2901.0000
CPU min MHz:                     800.0000
BogoMIPS:                        5799.77
Virtualization:                  VT-x
L1d cache:                       192 KiB
L1i cache:                       192 KiB
L2 cache:                        1.5 MiB
L3 cache:                        12 MiB
NUMA node0 CPU(s):               0-11
Vulnerability Itlb multihit:     KVM: Mitigation: Split huge pages
Vulnerability L1tf:              Not affected
Vulnerability Mds:               Not affected
Vulnerability Meltdown:          Not affected
Vulnerability Mmio stale data:   Vulnerable: Clear CPU buffers attempted, no microcode; SMT vulnerable
Vulnerability Retbleed:          Mitigation; Enhanced IBRS
Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp
Vulnerability Spectre v1:        Mitigation; usercopy/swapgs barriers and __user pointer sanitization
Vulnerability Spectre v2:        Mitigation; Enhanced IBRS, IBPB conditional, RSB filling, PBRSB-eIBRS SW sequence
Vulnerability Srbds:             Vulnerable: No microcode
Vulnerability Tsx async abort:   Not affected
Flags:                           fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe sysca
                                 ll nx pdpe1gb rdtscp lm constant_tsc art arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc cpuid aperfmperf pni pclmu
                                 lqdq dtes64 monitor ds_cpl vmx est tm2 ssse3 sdbg fma cx16 xtpr pdcm pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_time
                                 r aes xsave avx f16c rdrand lahf_lm abm 3dnowprefetch cpuid_fault epb invpcid_single ssbd ibrs ibpb stibp ibrs_enhanced tpr_s
                                 hadow vnmi flexpriority ept vpid ept_ad fsgsbase tsc_adjust bmi1 avx2 smep bmi2 erms invpcid mpx rdseed adx smap clflushopt i
                                 ntel_pt xsaveopt xsavec xgetbv1 xsaves dtherm ida arat pln pts md_clear flush_l1d arch_capabilities

Новее то он новее, но вот насчёт лучше я сомневаюсь. Ядер разве что больше, это не везде нужно.

Частота меньше, bogomips меньше.

Попробуй гипертрединг отключить, сравни результаты.

firkax ★★★★★
()
Последнее исправление: firkax (всего исправлений: 1)

с 64-разрядной Windows Server 2016 на i5 работает хорошо

Значит проблема тут:

VirtualBox 

Попробуйте так:

1. sudo apt install virt-manager -y
2. sudo usermod -aG libvirt ivanov
3. newgrp libvirt
4. virt-manager
И затем попробуйте создать виртуальную машину. Используйте образ с драйверами virtio-win. Он поможет установить драйверы в виндовс.

sfedosenko
()

Благодарю всех ответивших, проблема, действительно, оказалась программной. При новой установке w2008x86 на новом железе в том же VirtualBox - новая виртуальная машина работает нормально, то есть проблема была в работе исключительно самой старой виртуальной машины на новом железе. Учитывая это, было принято решение создать новую виртуальную машину с 32-разрядным Windows для поддержки устаревшего ПО.

Kircher
() автор топика
Ответ на: комментарий от mumpster

а в виртуалбокс пробрасывалась модель процессора?

Если правильно понял вопрос - в обоих случаях - нет. Использовался не только оригинальный диск, но и сам файл настроек виртуальной машины (.vbox) с той же самой версией virtualbox - поэтому в первую очередь и предположил, что проблема аппаратная.

Kircher
() автор топика
Ответ на: комментарий от Kircher

причём тут файл настроек? ЕМНИП по умолчанию Virtual Box передаёт реальное CPUID. но можно подать нужное, а не реальное. вот я о чём.

ref:

–cpu-profile

https://superuser.com/questions/625648/virtualbox-how-to-force-a-specific-cpu-to-the-guest

mumpster ★★★★★
()