Saya telah menulis perangkat lunak multi-threaded yang melakukan banyak simulasi sehari. Ini adalah tugas yang sangat intensif dengan CPU, dan saya telah menjalankan program ini pada layanan cloud, biasanya pada konfigurasi seperti 1GB per inti.
Saya menjalankan CentOS 6.7, dan /proc/cpuinfo
memberi saya bahwa empat inti VPS saya adalah 2.5GHz.
processor : 3
vendor_id : GenuineIntel
cpu family : 6
model : 63
model name : Intel(R) Xeon(R) CPU E5-2680 v3 @ 2.50GHz
stepping : 2
microcode : 1
cpu MHz : 2499.992
cache size : 30720 KB
physical id : 3
siblings : 1
core id : 0
cpu cores : 1
apicid : 3
initial apicid : 3
fpu : yes
fpu_exception : yes
cpuid level : 13
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ss syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon rep_good unfair_spinlock pni pclmulqdq ssse3 fma cx16 pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand hypervisor lahf_lm abm arat xsaveopt fsgsbase bmi1 avx2 smep bmi2 erms invpcid
bogomips : 4999.98
clflush size : 64
cache_alignment : 64
address sizes : 40 bits physical, 48 bits virtual
power management:
Dengan kenaikan nilai tukar, VPS saya mulai menjadi lebih mahal, dan saya telah mencapai "banyak" pada server bare-metal bekas.
Saya membeli empat HP DL580 G5 , dengan masing-masing empat Intel Xeon X7350. Pada dasarnya, setiap mesin memiliki 16x 2.93GHz core dan 16GB, untuk menjaga hal-hal seperti cloud VPS saya .
processor : 15
vendor_id : GenuineIntel
cpu family : 6
model : 15
model name : Intel(R) Xeon(R) CPU X7350 @ 2.93GHz
stepping : 11
microcode : 187
cpu MHz : 1600.002
cache size : 4096 KB
physical id : 6
siblings : 4
core id : 3
cpu cores : 4
apicid : 27
initial apicid : 27
fpu : yes
fpu_exception : yes
cpuid level : 10
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall lm constant_tsc arch_perfmon pebs bts rep_good aperfmperf pni dtes64 monitor ds_cpl vmx est tm2 ssse3 cx16 xtpr pdcm dca lahf_lm dts tpr_shadow vnmi flexpriority
bogomips : 5866.96
clflush size : 64
cache_alignment : 64
address sizes : 40 bits physical, 48 bits virtual
power management:
Pada dasarnya itu tampak hebat, karena saya bisa berhenti menggunakan VPS untuk melakukan pekerjaan batch ini. Sekarang ini adalah hal-hal aneh ...
- Pada VPS, saya telah menjalankan 1,25 thread per core, seperti yang saya lakukan pada bare metal. (Utas 0,25 tambahan adalah untuk mengkompensasi waktu idle yang disebabkan oleh penggunaan jaringan.)
- Pada VPS saya, menggunakan total 44x 2.5GHz core, saya mendapatkan hampir 900 simulasi per menit.
- Pada DL580 saya, menggunakan total 64x 2.93GHz core, saya hanya mendapatkan 300 simulasi per menit.
Saya mengerti bahwa DL580 memiliki prosesor yang lebih tua. Tetapi jika saya menjalankan satu utas per inti, dan server bare metal memiliki inti yang lebih cepat, mengapa kinerjanya lebih buruk daripada VPS saya?
Saya tidak memiliki pertukaran memori yang terjadi di server mana pun.
TOP mengatakan prosesor saya berjalan pada 100%. Saya mendapatkan beban rata-rata 18 (5 pada VPS).
Apakah ini akan menjadi seperti ini, atau apakah saya kehilangan sesuatu?
Menjalankan lscpu memberi saya 1.6GHz di server bare metal saya. Ini terlihat di /proc/cpuinfo
juga.
Apakah informasi ini benar, atau terhubung ke manajemen daya yang salah?
[BARE METAL] $ lscpu
Architecture: x86_64
CPU op-mode(s): 32-bit, 64-bit
Byte Order: Little Endian
CPU(s): 16
On-line CPU(s) list: 0-15
Thread(s) per core: 1
Core(s) per socket: 4
Socket(s): 4
NUMA node(s): 1
Vendor ID: GenuineIntel
CPU family: 6
Model: 15
Stepping: 11
**CPU MHz: 1600.002**
BogoMIPS: 5984.30
Virtualization: VT-x
L1d cache: 32K
L1i cache: 32K
L2 cache: 4096K
NUMA node0 CPU(s): 0-15
[VPS] $ lscpu
Architecture: x86_64
CPU op-mode(s): 32-bit, 64-bit
Byte Order: Little Endian
CPU(s): 4
On-line CPU(s) list: 0-3
Thread(s) per core: 1
Core(s) per socket: 1
Socket(s): 4
NUMA node(s): 1
Vendor ID: GenuineIntel
CPU family: 6
Model: 63
Stepping: 2
**CPU MHz: 2499.992**
BogoMIPS: 4999.98
Hypervisor vendor: KVM
Virtualization type: full
L1d cache: 32K
L1i cache: 32K
L2 cache: 256K
L3 cache: 30720K
NUMA node0 CPU(s): 0-3