Soalan biasa dalam kalangan sysadmin: "Bagaimanakah saya boleh menjana beban CPU tiruan pada mesin ini dengan cepat?" Jika beban CPU ringkas 100% merentasi satu atau lebih teras adalah mencukupi, membina penyelesaian tersuai adalah sangat mudah.
Penyelesaian Teras Tunggal (Satu Pelapik)
Barisan tunggal kod C ini, disusun dan dijalankan, akan menambat satu teras pada penggunaan 100%:
<code class="language-c">int main() {while (1) {}}</code>
Kompilasi menggunakan gcc -o stressme stressme.c
(atau cl stressme.c
pada Windows) dan jalankan dengan ./stressme
(atau stressme.exe
). Untuk menekankan berbilang teras, hanya jalankan berbilang kejadian program.
Penyelesaian Berbilang Teras (Berbilang Benang)
Untuk ujian tekanan berbilang teras yang lebih terkawal, pertimbangkan versi berbilang benang ini menggunakan 4 utas POSIX:
<code class="language-c">#include <pthread.h> #include <unistd.h> #define NUM_THREADS 4 void *loop(void *arg) { while (1) {} } int main() { pthread_t threads[NUM_THREADS]; for (int i = 0; i < NUM_THREADS; i++) { pthread_create(&threads[i], NULL, loop, NULL); } for (int i = 0; i < NUM_THREADS; i++) { pthread_join(threads[i], NULL); } return 0; }</code>
Kompil dengan gcc -o multistress multistress.c -pthread
.
Cara Ia Berfungsi
Kefungsian teras ialah gelung tak terhingga yang ringkas (while (1) {}
). Pada peringkat pemasangan, ini diterjemahkan kepada arahan jmp
berterusan, memaksimumkan penggunaan CPU. Sistem pengendalian berbilang tugas awalan moden membenarkan gelung ini menggunakan masa pemproses tanpa menyebabkan sistem tidak bertindak balas sepenuhnya; proses masih boleh ditamatkan. Sebaliknya, sistem multitasking koperasi yang lebih lama mungkin akan membeku disebabkan gelung sedemikian.
<code class="language-assembly">global _start _start: jmp _start</code>
Atas ialah kandungan terperinci Bagaimana untuk % CPU. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!