This article will introduce to you how to use JVM commands in java to implement server troubleshooting. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.
Execute the top command: (View the details of process 15477, used below)
System information (first five lines):
Line 1: Top task queue information (system running status and average load), the same as the uptime command result .
Average system load: In the case of a single-core CPU, 0.00 means no load, 1.00 means just full load, more than 1 means overload, the ideal value is 0.7;
Multi-core CPU load: number of CPU cores * ideal value 0.7 = ideal load, for example: 4-core CPU load does not exceed 2.8, which means there is no high load.
Format: up xx days, HH:MM
For example: 241 days, 20:11, means continuous Running for 241 days, 20 hours and 11 minutes
Section 1: System current time, for example: 16:07:37
Paragraph 2: System running time, the time before restarting. The longer the time, the more stable the system will be.
Paragraph 3: The number of currently logged in users, for example: 1 user, indicating that there is currently only 1 user logged in
Paragraph 4 Segment: System load, that is, the average length of the task queue. The three values respectively count the average system load in the last 1, 5, and 15 minutes
Line 2: Tasks process related information
Paragraph 1: Total number of processes, for example: Tasks: 231 total, indicating a total of 231 processes running
Paragraph 2: Number of running processes, for example: 1 running,
Paragraph 3: Number of sleeping processes, for example: 230 sleeping,
Paragraph 4: Number of stopped processes, for example: 0 stopped,
Paragraph 5: Number of zombie processes, for example: 0 zombie
Line 3: Cpus CPU related information. If it is a multi-core CPU, press the number 1 to display the CPU information of each core. At this time, line 1 will be converted to the Cpu core number line, and the number 1 can be switched back and forth. .
Paragraph 1: us
Percentage of CPU occupied by user space, for example: Cpu (s): 12.7%us,
Paragraph 2: sy
The percentage of CPU occupied by the kernel space, for example: 8.4%sy,
Paragraph 3: ni
The percentage of CPU occupied by processes that have changed priorities in the user process space, for example: 0.0%ni,
4th Section: id
Idle CPU percentage, for example: 77.1%id,
Section 5: wa
Percentage of CPU time waiting for input and output, For example: 0.0%wa,
Paragraph 6: hi
The total time spent by the CPU serving hardware interrupts, for example: 0.0%hi,
Paragraph 7: si
The total time spent on CPU service soft interrupt, for example: 1.8%si,
st Steal time The CPU time stolen by the virtual machine by the hypervisor (if the vm is currently under a hypervisor, the hypervisor actually consumes part of the CPU processing time)
Mem memory related information (Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers)
Press in the top command Press f to view the displayed column information, and press the corresponding letter to turn on/off the column. An uppercase letter means on, and a lowercase letter means off. The columns marked with * are the default columns.
PID = (Process Id) Process Id;
H: PR
= (Priority) Priority
I: NI
= (Nice value) nice value. Negative values represent high priority, positive values represent low priority
O: VIRT
= (Virtual Image (kb)) Process usage The total amount of virtual memory, unit kb. VIRT=SWAP RES
Q: RES
= (Resident size (kb)) The physical memory used by the process and not swapped out Size, unit kb. RES=CODE DATA
T: SHR
= (Shared Mem size (kb)) Shared memory size, unit kb
W: S
= (Process Status) Process status. D=uninterruptible sleep state, R=running, S=sleep, T=track/stop, Z=zombie process
K: % CPU
= (CPU usage) The percentage of CPU time usage since the last update
N: %MEM
= (Memory usage (RES)) The percentage of physical memory used by the process
TIME = (CPU Time, hundredths ) Total CPU time used by the process, unit 1/100 second
b:
PPID = (Parent Process Pid) Parent Process Id
c:
RUSER = (Real user name)
d:
UID = (User Id) The user ID of the process owner
f:
GROUP = (Group Name) The group name of the process owner
g:
TTY = (Controlling Tty) The terminal name of the startup process. Processes that are not started from the terminal are displayed as?
j:
P = (Last used cpu (SMP)) The last used CPU is only meaningful in a multi-CPU environment
p:
SWAP = (Swapped size (kb)) The size of the virtual memory used by the process that is swapped out, in kb
l:
TIME = (CPU Time) The CPU used by the process Total time, in seconds
r:
CODE = (Code size (kb)) The physical memory size occupied by the executable code, in kb
s:
DATA = ( Data Stack size (kb)) The size of physical memory occupied by parts other than executable code (data segment stack), unit kb
u:
nFLT = (Page Fault count) Number of page faults
v:
nDRT = (Dirty Pages count) The number of pages that have been modified since the last time it was written
y:
WCHAN = (Sleeping in Function) If the process is in Sleep, then display the system function name in sleep
z:
Flags = (Task Flags <sched.h>) Task flags, refer to sched.h
COMMAND = (Command name/line) command name/command line
Note: At this time, the PID is the thread id
If there is an exception in thread 15571 and you need to check it, use jstack to print the stack and check the status of thread 15571 (15571 hexadecimal = 3cd3)
## 2. jstack
Java command learning series (2)-Jstack
Need to go to the JDK installation directory to use it (you can view the java process through ps x , get the jdk installation directory)
./jstack PID (process id) ./jstack 15477
The red box is thread 15571 (hexadecimal = 3cd3) status
Analyze jstack log:
Monitor Monitor:
Monitor is the main means in Java to achieve mutual exclusion and collaboration between threads. It can be regarded as an object or Class lock.
Every object has only one monitor.
The following figure describes the relationship between the thread and the Monitor, as well as the state transition of the thread:
Enter Set: Indicates that the thread requests to acquire the object's lock through synchronized. If the object is locked, enter the owner; otherwise wait in the entry area. Once the object lock is released by other threads, it immediately participates in competition.Owner (The Owner): Indicates that a thread successfully competed for the object lock.
Wait Set: Indicates that the thread releases the object's lock through the object's object.wait() method and waits in the waiting area to be awakened. As can be seen from the figure, a Monitor can only be owned by one thread at a certain moment, and that thread is The thread action waiting in The thread action waiting in (We call the code segment protected by synchronized as the critical section. When a thread applies to enter the critical section, it enters the "Entry Set" queue) NEW: Not started. Will not appear in Dump. RUNNABLE: Executed in the virtual machine, running state. The Owner Area BLOCKED: Blocked and waiting for the monitor lock. Waiting for the lock in the Entry Set area. WATING: Wait indefinitely for another thread to perform a specific operation. In the Wait Set areaWait for a certain condition or monitor to occur, usually staying in statements such as wait(). TIMED_WATING: Time-limited waiting for a specific operation from another thread. In the Wait Set area, the difference between and WAITING is that wait() and other statements add a time limit of wait(timeout). TERMINATED: Exited. locked Target: Use synchronized to apply for object lock successfully, the owner of the monitor. The Owner area. waiting to lock Target: Application for object lock using synchronized failed, Waiting for the lock in the Entry Set area. The thread status is Blocked waiting on Goal: After successfully applying for the object lock using synchronized, release the lock, Wait for the lock in the Wait Set area. The thread status is WAITING or TIMED_WATING parking to wait for Target: park() is called, is in the Wait Set area, waiting for permission. (park is a basic thread blocking primitive that does not block on objects through the monitor. park: Enter the WAITING state, compare wait can make the thread WAITING without acquiring the lock and wake it up through unpark) runnable: The Owner area, status RUNNABLE in Object.wait(): Call wait(), Wait Set area, status is WAITING or TIMED_WAITING, modify waiting on waiting for monitor entry: waiting for lock, Entry Set area, status BLOCKED, modify waiting to lock waiting on condition : Parked due to certain conditions, Wait Set area, status is parking to wait for sleeping: The sleeping thread called Thread.sleep() 1. Check the thread dump. First look at the thread status/thread action (more intuitive) to determine which stage the thread is currently in. Then look at the call modification and lock status, and you can basically determine whether there is a problem with the secondary thread; 2. You can print thread snapshots multiple times in a short period of time (the time period when there may be problems), and then check whether there may be problems This situation of a certain thread can effectively find the problem. Similar to Linux command ps Reference Java command learning series (1) - Jps ./jps ./jps -q ./jps -m ./jps -l ./jps -v [C is a char[] Java Video Tutorial, javaDevelopment Graphic Tutorial, bootstrap Video Tutorial!<span style='font-family: "Microsoft YaHei"'>Active Thread</span>
, while other threads are <span style='font-family: "Microsoft YaHei"'>Waiting</span> <span style='font-family: "Microsoft YaHei"'>Thread</span>
, respectively in two queues <span style='font-family: "Microsoft YaHei"'>Entry</span> ## Wait inside #Set<span style='font-family: "Microsoft YaHei"'></span> and
Wait<span style='font-family: "Microsoft YaHei"'> </span>Set<span style='font-family: "Microsoft YaHei"'></span>.
Entry<span style='font-family: "Microsoft YaHei"'> </span>Set<span style='font-family: "Microsoft YaHei"'></span>
is Waiting for monitor entry<span style='font-family: "Microsoft YaHei"'>. </span>
Wait<span style='font-family: "Microsoft YaHei"'> </span>Set<span style='font-family: "Microsoft YaHei"'></span>
is in Object.wait()<span style='font-family: "Microsoft YaHei"'></span>
. When a thread applies to enter the critical section, it enters the Entry Set queue. Summary
3. jps
[S is a short[ ]
[I is a int[]
[B is a byte[]
[[I is a int[] []
The above is the detailed content of How to use JVM commands in java to troubleshoot servers. For more information, please follow other related articles on the PHP Chinese website!