Jadual Kandungan
2. Idea penyelesaian masalah " >2. Idea penyelesaian masalah
2.1 Cari pid proses beban tinggi" >2.1 Cari pid proses beban tinggi
2.2 Cari perniagaan luar biasa tertentu" >2.2 Cari perniagaan luar biasa tertentu
2.3 Cari benang tidak normal dan baris kod tertentu" >2.3 Cari benang tidak normal dan baris kod tertentu
Rumah Tutorial sistem LINUX Biar saya pergi, CPU sistem Linux 100% penuh!

Biar saya pergi, CPU sistem Linux 100% penuh!

Feb 13, 2024 pm 11:27 PM
linux tutorial linux sistem linux arahan linux skrip shell embeddedlinux Bermula dengan linux pembelajaran linux

Petang semalam, tiba-tiba saya menerima makluman e-mel daripada bahagian operasi dan penyelenggaraan, yang menunjukkan bahawa kadar penggunaan CPU pelayan platform data adalah setinggi 98.94%. Sejak kebelakangan ini, kadar penggunaan ini terus melebihi 70%. Pada pandangan pertama, nampaknya sumber perkakasan telah mencapai kesesakan dan perlu dikembangkan. Tetapi selepas memikirkannya dengan teliti, saya mendapati bahawa sistem perniagaan kami bukanlah aplikasi yang sangat serentak atau intensif CPU. Kadar penggunaan ini terlalu keterlaluan, dan kesesakan perkakasan tidak dapat dicapai dengan begitu cepat. Pasti ada masalah dengan logik kod perniagaan di suatu tempat.

2. Idea penyelesaian masalah

2.1 Cari pid proses beban tinggi

Mula-mula log masuk ke pelayan dan gunakan arahan teratas untuk mengesahkan situasi khusus pelayan, dan kemudian menganalisis dan menilai berdasarkan situasi tertentu.

我去,Linux 系统 CPU 100% 打满了!

Dengan memerhatikan purata beban dan piawaian penilaian beban (8 teras), ia boleh disahkan bahawa pelayan mempunyai beban yang tinggi

我去,Linux 系统 CPU 100% 打满了!

Memerhatikan penggunaan sumber setiap proses, kita dapat melihat bahawa proses dengan proses ID 682 mempunyai nisbah CPU yang lebih tinggi

2.2 Cari perniagaan luar biasa tertentu

Di sini kita boleh menggunakan perintah pwdx untuk mencari laluan proses perniagaan berdasarkan pid, dan kemudian mencari orang yang bertanggungjawab dan projek:

我去,Linux 系统 CPU 100% 打满了!

Boleh disimpulkan bahawa proses ini sepadan dengan perkhidmatan web platform data.

2.3 Cari benang tidak normal dan baris kod tertentu

Penyelesaian tradisional biasanya 4 langkah:

1. urutan teratas dengan dengan P: 1040 // Isih mengikut beban proses dahulu untuk mencari maxLoad(pid)

2 atas -Hp proses PID: 1073 // Cari PID beban yang berkaitan

3. printf “0x%x” Thread PID: 0x431 // Tukarkan thread PID kepada perenambelasan untuk bersedia untuk mencari log jstack nanti

4. proses jstack PID |.

Tetapi untuk lokasi masalah dalam talian, setiap detik penting, dan 4 langkah di atas masih terlalu rumit dan memakan masa, Oldratlee, yang memperkenalkan Taobao sebelum ini, merangkumkan proses di atas ke dalam alat: show-busy-java-threads.sh. Anda boleh mencari jenis masalah ini dengan mudah dalam talian:

我去,Linux 系统 CPU 100% 打满了!Boleh disimpulkan bahawa CPU pelaksanaan kaedah alat masa dalam sistem adalah agak tinggi Selepas mengesan kaedah tertentu, semak sama ada terdapat masalah prestasi dalam logik kod.

※ Jika masalah dalam talian lebih mendesak, anda boleh meninggalkan 2.1 dan 2.2 dan terus melaksanakan 2.3 Analisis di sini adalah dari pelbagai sudut hanya untuk memberikan anda idea analisis yang lengkap.

3. Analisis punca akar

Selepas analisis dan penyelesaian masalah sebelum ini, kami akhirnya menemui masalah alat masa, yang menyebabkan beban pelayan yang berlebihan dan penggunaan CPU.

  • Logik kaedah pengecualian: adalah untuk menukar cap masa ke dalam format tarikh dan masa tertentu yang sepadan
  • Panggilan lapisan atas: Kira semua saat dari awal pagi hingga waktu semasa, tukarkannya ke dalam format yang sepadan dan masukkannya ke dalam set untuk mengembalikan hasilnya
  • Lapisan logik: Sepadan dengan logik pertanyaan laporan masa nyata platform data Laporan masa nyata akan datang pada selang masa tetap, dan akan terdapat berbilang (n) panggilan kaedah dalam satu pertanyaan.

Maka boleh disimpulkan bahawa jika masa semasa ialah pukul 10 pagi, bilangan pengiraan untuk satu pertanyaan ialah 106060n kali = 36,000n pengiraan, dan apabila masa bertambah, bilangannya pertanyaan tunggal menjadi lebih dekat ke tengah malam akan meningkat secara linear. Memandangkan sebilangan besar permintaan pertanyaan daripada modul seperti pertanyaan masa nyata dan penggera masa nyata memerlukan panggilan kaedah ini beberapa kali, sejumlah besar sumber CPU telah diduduki dan dibazirkan.

4 Selepas mengesan masalah, pertimbangan pertama ialah mengurangkan bilangan pengiraan dan mengoptimumkan kaedah pengecualian. Selepas penyiasatan, didapati bahawa apabila digunakan pada lapisan logik, kandungan koleksi set yang dikembalikan melalui kaedah ini tidak digunakan, tetapi nilai saiz set hanya digunakan. Selepas mengesahkan logik, mudahkan pengiraan melalui kaedah baru (saat semasa - saat pada awal pagi hari), gantikan kaedah yang dipanggil, dan selesaikan masalah pengiraan yang berlebihan. Selepas pergi ke dalam talian, kami memerhatikan beban pelayan dan penggunaan CPU Berbanding dengan tempoh masa yang tidak normal, beban pelayan dan penggunaan CPU menurun sebanyak 30 kali dan kembali normal Pada ketika ini, masalah telah diselesaikan.

![Petang semalam, saya tiba-tiba menerima amaran e-mel daripada bahagian operasi dan penyelenggaraan, menunjukkan bahawa kadar penggunaan CPU pelayan platform data adalah setinggi 98.94%. Sejak kebelakangan ini, kadar penggunaan ini terus melebihi 70%. Pada pandangan pertama, nampaknya sumber perkakasan telah mencapai kesesakan dan perlu dikembangkan. Tetapi selepas memikirkannya dengan teliti, saya mendapati bahawa sistem perniagaan kami bukanlah aplikasi yang sangat serentak atau intensif CPU. Kadar penggunaan ini terlalu keterlaluan dan kesesakan perkakasan tidak dapat dicapai dengan begitu cepat. Pasti ada masalah dengan logik kod perniagaan di suatu tempat.

2. Idea penyelesaian masalah

2.1 Cari pid proses beban tinggi

Mula-mula log masuk ke pelayan dan gunakan arahan teratas untuk mengesahkan situasi khusus pelayan, dan kemudian menganalisis dan menilai berdasarkan situasi tertentu.

Dengan memerhatikan purata beban dan piawaian penilaian beban (8 teras), ia boleh disahkan bahawa pelayan mempunyai beban yang tinggi

我去,Linux 系统 CPU 100% 打满了!

Memerhatikan penggunaan sumber setiap proses, kita dapat melihat bahawa proses dengan proses ID 682 mempunyai nisbah CPU yang lebih tinggi

我去,Linux 系统 CPU 100% 打满了!

2.2 Cari perniagaan luar biasa tertentu

Di sini kita boleh menggunakan perintah pwdx untuk mencari laluan proses perniagaan berdasarkan pid, dan kemudian mencari orang yang bertanggungjawab dan projek:

Boleh disimpulkan bahawa proses ini sepadan dengan perkhidmatan web platform data.

我去,Linux 系统 CPU 100% 打满了!

2.3 Cari benang tidak normal dan baris kod tertentu

Penyelesaian tradisional biasanya 4 langkah:

1. Susunan teratas mengikut P:

1040 // Isih mengikut beban proses dahulu untuk mencari maxLoad(pid)

2 atas -Hp proses PID:

1073 // Cari PID beban yang berkaitan

3. printf “0x%x” Thread PID:

0x431 // Tukarkan thread PID kepada perenambelasan untuk bersedia untuk mencari log jstack nanti

4. proses jstack PID |.

Tetapi untuk lokasi masalah dalam talian, setiap detik penting, dan 4 langkah di atas masih terlalu rumit dan memakan masa, Oldratlee, yang memperkenalkan Taobao sebelum ini, merangkumkan proses di atas ke dalam alat: show-busy-java-threads.sh. Anda boleh mencari jenis masalah ini dengan mudah dalam talian:

我去,Linux 系统 CPU 100% 打满了!Boleh disimpulkan bahawa CPU pelaksanaan kaedah alat masa dalam sistem adalah agak tinggi Selepas mengesan kaedah tertentu, semak sama ada terdapat masalah prestasi dalam logik kod.

※ Jika masalah dalam talian adalah lebih mendesak, anda boleh meninggalkan 2.1 dan 2.2 dan terus melaksanakan 2.3 Analisis di sini adalah dari pelbagai sudut hanya untuk memberikan anda idea analisis yang lengkap.

3. Analisis punca akar

Selepas analisis dan penyelesaian masalah sebelum ini, kami akhirnya menemui masalah alat masa, yang menyebabkan beban pelayan yang berlebihan dan penggunaan CPU.

  • Logik kaedah pengecualian: adalah untuk menukar cap masa ke dalam format tarikh dan masa tertentu yang sepadan
  • Panggilan lapisan atas: Kira semua saat dari awal pagi hingga waktu semasa, tukarkannya ke dalam format yang sepadan dan masukkannya ke dalam set untuk mengembalikan hasilnya
  • Lapisan logik: Sepadan dengan logik pertanyaan laporan masa nyata platform data Laporan masa nyata akan datang pada selang masa tetap, dan akan terdapat berbilang (n) panggilan kaedah dalam satu pertanyaan.
Maka boleh disimpulkan bahawa jika masa semasa ialah pukul 10 pagi, bilangan pengiraan untuk satu pertanyaan ialah 10

6060n kali = 36,000n pengiraan, dan apabila masa bertambah, bilangannya pertanyaan tunggal menjadi lebih dekat ke tengah malam akan meningkat secara linear. Memandangkan sebilangan besar permintaan pertanyaan daripada modul seperti pertanyaan masa nyata dan penggera masa nyata memerlukan panggilan kaedah ini beberapa kali, sejumlah besar sumber CPU telah diduduki dan dibazirkan.

4 Selepas mengesan masalah, pertimbangan pertama ialah mengurangkan bilangan pengiraan dan mengoptimumkan kaedah pengecualian. Selepas penyiasatan, didapati bahawa apabila digunakan pada lapisan logik, kandungan koleksi set yang dikembalikan melalui kaedah ini tidak digunakan, tetapi nilai saiz set hanya digunakan. Selepas mengesahkan logik, mudahkan pengiraan melalui kaedah baru (saat semasa - saat pada awal pagi hari), gantikan kaedah yang dipanggil, dan selesaikan masalah pengiraan yang berlebihan. Selepas pergi ke dalam talian, kami memerhatikan beban pelayan dan penggunaan CPU Berbanding dengan tempoh masa yang tidak normal, beban pelayan dan penggunaan CPU menurun sebanyak 30 kali dan kembali normal Pada ketika ini, masalah telah diselesaikan.

5 我去,Linux 系统 CPU 100% 打满了!

Semasa proses pengekodan, selain melaksanakan logik perniagaan, kita juga mesti menumpukan pada mengoptimumkan prestasi kod. Keupayaan untuk merealisasikan keperluan perniagaan dan keupayaan untuk mencapainya dengan lebih cekap dan lebih elegan sebenarnya adalah dua manifestasi yang sama sekali berbeza kebolehan dan alam jurutera, dan yang terakhir juga merupakan daya saing teras jurutera. Selepas kod ditulis, lakukan lebih banyak ulasan dan fikirkan lebih lanjut sama ada ia boleh dilaksanakan dengan cara yang lebih baik.

    Jangan terlepas sebarang butiran kecil dalam soalan dalam talian! Perincian adalah syaitan pelajar teknikal perlu mempunyai kehausan untuk ilmu dan semangat mengejar kecemerlangan Hanya dengan cara ini mereka boleh terus berkembang dan bertambah baik.

Atas ialah kandungan terperinci Biar saya pergi, CPU sistem Linux 100% penuh!. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Konfigurasi komputer apa yang diperlukan untuk vscode Konfigurasi komputer apa yang diperlukan untuk vscode Apr 15, 2025 pm 09:48 PM

Keperluan Sistem Kod Vs: Sistem Operasi: Windows 10 dan ke atas, MACOS 10.12 dan ke atas, pemproses pengedaran Linux: minimum 1.6 GHz, disyorkan 2.0 GHz dan ke atas memori: minimum 512 MB, disyorkan 4 GB dan ke atas ruang penyimpanan: minimum 250 mb, disyorkan 1 GB dan di atas keperluan lain:

VSCode tidak dapat memasang pelanjutan VSCode tidak dapat memasang pelanjutan Apr 15, 2025 pm 07:18 PM

Sebab -sebab pemasangan sambungan kod VS mungkin: ketidakstabilan rangkaian, kebenaran yang tidak mencukupi, isu keserasian sistem, versi kod VS terlalu lama, perisian antivirus atau gangguan firewall. Dengan menyemak sambungan rangkaian, keizinan, fail log, mengemas kini kod VS, melumpuhkan perisian keselamatan, dan memulakan semula kod VS atau komputer, anda boleh menyelesaikan masalah dan menyelesaikan masalah secara beransur -ansur.

Boleh vscode digunakan untuk mac Boleh vscode digunakan untuk mac Apr 15, 2025 pm 07:36 PM

VS Kod boleh didapati di Mac. Ia mempunyai sambungan yang kuat, integrasi git, terminal dan debugger, dan juga menawarkan banyak pilihan persediaan. Walau bagaimanapun, untuk projek yang sangat besar atau pembangunan yang sangat profesional, kod VS mungkin mempunyai prestasi atau batasan fungsi.

Apa itu vscode untuk apa vscode? Apa itu vscode untuk apa vscode? Apr 15, 2025 pm 06:45 PM

VS Kod adalah nama penuh Visual Studio Code, yang merupakan editor kod dan persekitaran pembangunan yang dibangunkan oleh Microsoft. Ia menyokong pelbagai bahasa pengaturcaraan dan menyediakan penonjolan sintaks, penyiapan automatik kod, coretan kod dan arahan pintar untuk meningkatkan kecekapan pembangunan. Melalui ekosistem lanjutan yang kaya, pengguna boleh menambah sambungan kepada keperluan dan bahasa tertentu, seperti debuggers, alat pemformatan kod, dan integrasi Git. VS Kod juga termasuk debugger intuitif yang membantu dengan cepat mencari dan menyelesaikan pepijat dalam kod anda.

Cara menggunakan vscode Cara menggunakan vscode Apr 15, 2025 pm 11:21 PM

Visual Studio Code (VSCode) adalah editor cross-platform, sumber terbuka dan editor kod percuma yang dibangunkan oleh Microsoft. Ia terkenal dengan ringan, skalabilitas dan sokongan untuk pelbagai bahasa pengaturcaraan. Untuk memasang VSCode, sila lawati laman web rasmi untuk memuat turun dan jalankan pemasang. Apabila menggunakan VSCode, anda boleh membuat projek baru, edit kod, kod debug, menavigasi projek, mengembangkan VSCode, dan menguruskan tetapan. VSCode tersedia untuk Windows, MacOS, dan Linux, menyokong pelbagai bahasa pengaturcaraan dan menyediakan pelbagai sambungan melalui pasaran. Kelebihannya termasuk ringan, berskala, sokongan bahasa yang luas, ciri dan versi yang kaya

Apr 16, 2025 pm 07:39 PM

Walaupun Notepad tidak dapat menjalankan kod Java secara langsung, ia dapat dicapai dengan menggunakan alat lain: menggunakan pengkompil baris arahan (Javac) untuk menghasilkan fail bytecode (fileName.class). Gunakan Java Interpreter (Java) untuk mentafsir bytecode, laksanakan kod, dan output hasilnya.

Apakah tujuan utama Linux? Apakah tujuan utama Linux? Apr 16, 2025 am 12:19 AM

Penggunaan utama Linux termasuk: 1. Sistem Operasi Pelayan, 2. Sistem Terbenam, 3. Linux cemerlang dalam bidang ini, menyediakan kestabilan, keselamatan dan alat pembangunan yang cekap.

Cara memeriksa alamat gudang git Cara memeriksa alamat gudang git Apr 17, 2025 pm 01:54 PM

Untuk melihat alamat repositori Git, lakukan langkah -langkah berikut: 1. Buka baris arahan dan navigasi ke direktori repositori; 2. Jalankan perintah "Git Remote -V"; 3. Lihat nama repositori dalam output dan alamat yang sepadan.

See all articles