J'ai écrit un logiciel multithread qui effectue un grand nombre de simulations par jour. C’est une tâche très gourmande en ressources processeur, et j’exécutais ce programme sur des services cloud, généralement sur des configurations telles que 1 Go par cœur.
Je suis en cours d'exécution CentOS 6.7, et /proc/cpuinfo
me donne que mes quatre cœurs de VPS sont 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:
Avec la hausse des taux de change, mon VPS a commencé à être plus cher, et je suis arrivé à une "bonne affaire" sur des serveurs nus en métal.
J'ai acheté quatre HP DL580 G5 , avec quatre Intel Xeon X7350 chacun. Fondamentalement, chaque machine dispose de 16 x 2,93 GHz et de 16 Go, pour garder des choses comme mon cloud VPS .
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:
Essentiellement, cela semblait beaucoup, car je pouvais arrêter d'utiliser des VPS pour effectuer ces travaux par lots. Maintenant c'est le truc bizarre ...
- Sur les VPS, j'ai utilisé 1,25 fil par noyau, tout comme je l'ai fait sur du métal nu. (Le thread supplémentaire 0.25 doit compenser le temps d'inactivité causé par l'utilisation du réseau.)
- Sur mon VPS, en utilisant au total 44 x 2,5 GHz, je reçois près de 900 simulations par minute.
- Sur mon DL580, en utilisant au total 64 x 2,93 GHz, je n’obtiens que 300 simulations par minute.
Je comprends que le DL580 a un processeur plus ancien. Mais si j'exécute un thread par cœur et que le serveur bare metal a un cœur plus rapide, pourquoi fonctionne-t-il moins bien que mon VPS?
Je n'ai aucun échange de mémoire qui se passe dans aucun des serveurs.
TOP dit que mes processeurs fonctionnent à 100%. Je reçois une charge moyenne de 18 (5 sur VPS).
Est-ce que ça va être comme ça, ou est-ce que je manque quelque chose?
Exécuter lscpu me donne 1,6 GHz sur mon serveur bare metal. Cela a été vu sur le /proc/cpuinfo
aussi.
Cette information est-elle correcte ou est-elle liée à une gestion de l'alimentation incorrecte?
[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