Heim  >  Artikel  >  Java  >  So beheben Sie Probleme mit der CPU-Auslastung eines Java-Prozesses von 100 %

So beheben Sie Probleme mit der CPU-Auslastung eines Java-Prozesses von 100 %

不言
不言nach vorne
2019-03-19 09:25:095160Durchsuche

In diesem Artikel geht es um die Methode zur Fehlerbehebung bei der 100-prozentigen CPU-Auslastung des Java-Prozesses. Ich hoffe, dass er für Freunde hilfreich ist Du hast geholfen.

100 % bezieht sich auf die Belegung eines Kerns der CPU, zwei Kerne bedeuten 200 % und so weiter.
Die CPU-Auslastung und die entsprechende Prozess-ID (PID) können über den oberen Befehl ermittelt werden. Drücken Sie auf der oberen Benutzeroberfläche c (um die vollständigen Befehlszeilenparameter anzuzeigen) und drücken Sie 1 (um die Statistiken jedes Kerns anzuzeigen). (Empfohlen: Java-Tutorial)

Die häufigsten Möglichkeiten für dieses Problem sind wie folgt:

1. Unzureichender Heap-Speicher führt zu häufigem Full GC
Das kann passieren kann durch zwei Methoden gelöst werden: Befehl zum Bestimmen

sudo jmap -heap pid zum Anzeigen des Heap-Speicherverbrauchs

sudo jstat -gc pid Interval Count zum Anzeigen der GC-Situation, Beispiel: sudo jstat - gc 5746 3000 5 bedeutet, die GC-Situation des 5746-Prozesses anzuzeigen, alle 3000 Millisekunden zu drucken und insgesamt fünfmal zu drucken. Wenn FGC/FGCT deutlich ansteigt, kommt es sehr häufig zu einer vollständigen GC.

Folgeverarbeitung:

Wenn die Situation dringend ist, müssen Sie den Java-Anwendungsprozess sofort neu starten. Wenn es nicht dringend ist, müssen Sie relevante Informationen einholen, um zu analysieren, warum der Heapspeicher leer ist Es liegt möglicherweise ein Speicherverlustproblem vor. Sie können 1) sudo jmap -histo pid | verwenden, um die Belegungsstatistik von Java-Objekten anzuzeigen, 2) sudo jmap -dump:live,format=b,file= heap.bin pid Um den Heap-Dump in eine lokale Datei zu exportieren, können Sie das Eclipse MAT-Tool verwenden, um Speicherlecks zu analysieren

2. Code-Implementierungsprobleme

Idee: Finden Sie heraus, welcher Thread belegt ist 1) Suchen Sie zunächst die Thread-ID mit hoher CPU-Auslastung im lokalen System. 2) Suchen Sie den entsprechenden Java-Thread und Thread-Stack

top -H -p pid, um zu überprüfen, welche Threads in einem Prozess belegt sind CPU, kopieren Sie die entsprechende Thread-ID und konvertieren Sie sie in Hexadezimal [IDEA] Tools》Groovy Console》println Long.toHexString(1234), um die Konvertierung abzuschließen].

sudo jstack -l -F pid |. less Rufen Sie den Java-Thread-Stack ab, suchen Sie mit der hexadezimalen lokalen Thread-ID und Sie finden den entsprechenden Thread an der Nid einer bestimmten Zeile. Überprüfen Sie den Java-Thread-Stapel, um die entsprechende Java-Klasse und Zeilennummer zu finden, und lesen Sie dann den Code, um die mögliche Ursache des Problems zu finden.

Erklärung von tid/nid in Jstack-Stack-Informationen
https://docs.oracle.com/javas...

The thread dump consists of the thread stack, including the thread state, for all Java threads in the virtual machine.

The header line contains the following information about the thread:
- Thread ID (tid), which is the address of a thread structure in memory.
- ID of the native thread (nid).


Das obige ist der detaillierte Inhalt vonSo beheben Sie Probleme mit der CPU-Auslastung eines Java-Prozesses von 100 %. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen