一、查看CPU 内存使用情况
命令列表:top top -Hp pid
1、top
shfit+M 可以按内存使用大小排序
p.s. top -Hp pid 查看进程下的线程使用情况
2、如果是JAVA进程可使用 jps
二、jstack pid 查看线程堆栈信息
命令列表: jstack pid jstack pid >>xx.log
把以下文件在linux服务器上执行
public class WaitNotifyCase {
public static void main(String[] args) {
final Object lock = new Object();
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("thread A is waiting to get lock");
synchronized (lock) {
try {
System.out.println("thread A get lock");
TimeUnit.MINUTES.sleep(1);
System.out.println("thread A do wait method");
lock.wait();
System.out.println("wait end");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("thread B is waiting to get lock");
synchronized (lock) {
System.out.println("thread B get lock");
try {
TimeUnit.MINUTES.sleep(5);
} catch (InterruptedException e) {
e.printStackTrace();
}
lock.notify();
System.out.println("thread B do notify method");
}
}
}).start();
}
}
命令如下:
javac -d . WaitNotifyCase.java
java com.hank.samples.WaitNotifyCase
step1: jps
step2: jstack 31341 >>jstack.log
step3: top -Hp 31341
jstack.log
可以看到- waiting to lock <0x00000000e345bb00> 对应的线程是nid=0x7a8a,nid为十六进制,可以转到十进制与top -Hp 31341出来的线程pid对应。对应pid=31325
三、jmap查询指定java进程的所有对象使用内存情况
命令列表:
jmap -histo pid 展示class的内存情况
jmap -histo:live pid>a.log 可以观察heap中所有对象的情况(heap中所有生存的对象的情况)
jmap -heap pid 展示pid的整体堆信息,堆空间使用情况
jmap -dump:live,format=b,file=xx.hprof pid dump将内存使用的详细情况输出到文件
p.s. jvisualvm可以查看.hprof文件
1、jmap -histo 31341 或 jmap -histo 31341 >>jmap.log
2、jmap -heap 3779
[root@localhost ~]# jmap -heap 27900
Attaching to process ID 27900, please wait...
Debugger attached successfully.
Client compiler detected.
JVM version is 20.45-b01
using thread-local object allocation.
Mark Sweep Compact GC
Heap Configuration: #堆内存初始化配置
MinHeapFreeRatio = 40 #-XX:MinHeapFreeRatio设置JVM堆最小空闲比率
MaxHeapFreeRatio = 70 #-XX:MaxHeapFreeRatio设置JVM堆最大空闲比率
MaxHeapSize = 100663296 (96.0MB) #-XX:MaxHeapSize=设置JVM堆的最大大小
NewSize = 1048576 (1.0MB) #-XX:NewSize=设置JVM堆的‘新生代’的默认大小
MaxNewSize = 4294901760 (4095.9375MB) #-XX:MaxNewSize=设置JVM堆的‘新生代’的最大大小
OldSize = 4194304 (4.0MB) #-XX:OldSize=设置JVM堆的‘老年代’的大小
NewRatio = 2 #-XX:NewRatio=:‘新生代’和‘老年代’的大小比率
SurvivorRatio = 8 #-XX:SurvivorRatio=设置年轻代中Eden区与Survivor区的大小比值
PermSize = 12582912 (12.0MB) #-XX:PermSize=<value>:设置JVM堆的‘持久代’的初始大小
MaxPermSize = 67108864 (64.0MB) #-XX:MaxPermSize=<value>:设置JVM堆的‘持久代’的最大大小
Heap Usage:
New Generation (Eden + 1 Survivor Space): #新生代区内存分布,包含伊甸园区+1个Survivor区
capacity = 30212096 (28.8125MB)
used = 27103784 (25.848182678222656MB)
free = 3108312 (2.9643173217773438MB)
89.71169693092462% used
Eden Space: #Eden区内存分布
capacity = 26869760 (25.625MB)
used = 26869760 (25.625MB)
free = 0 (0.0MB)
100.0% used
From Space: #其中一个Survivor区的内存分布
capacity = 3342336 (3.1875MB)
used = 234024 (0.22318267822265625MB)
free = 3108312 (2.9643173217773438MB)
7.001809512867647% used
To Space: #另一个Survivor区的内存分布
capacity = 3342336 (3.1875MB)
used = 0 (0.0MB)
free = 3342336 (3.1875MB)
0.0% used
tenured generation: #当前的Old区内存分布
capacity = 67108864 (64.0MB)
used = 67108816 (63.99995422363281MB)
free = 48 (4.57763671875E-5MB)
99.99992847442627% used
Perm Generation: #当前的 “持久代” 内存分布
capacity = (13.75MB)
used = 14339216 (13.674942016601562MB)
free = 78704 (0.0750579833984375MB)
99.45412375710227% used
以下来自网络数据仅作参考:
1)查看eden区:225M
2)两个存活区大小:都为37.5M
3)年轻代大小:300M
4)老年代大小:400M
5)持久代大小:100M
6)最大堆内存大小:年轻代大小+老年代大小=700M
7)java应用程序占用内存大小:最大堆内存大小+持久代大小=700M+100M=800M
四、jstat 进程的GC情况
jstat -gcutil 30996 3000
p.s. 30996为进程ID
即:每3秒一次显示进程号为30996的java进程的GC情况
S0 — Heap上的 Survivor space 0 区已使用空间的百分比
S1 — Heap上的 Survivor space 1 区已使用空间的百分比
E — Heap上的 Eden space 区已使用空间的百分比
O — Heap上的 Old space 区已使用空间的百分比
P — Perm space 区已使用空间的百分比
YGC — 从应用程序启动到采样时发生 Young GC 的次数
YGCT– 从应用程序启动到采样时 Young GC 所用的时间(单位秒)
FGC — 从应用程序启动到采样时发生 Full GC 的次数
FGCT– 从应用程序启动到采样时 Full GC 所用的时间(单位秒)
GCT — 从应用程序启动到采样时用于垃圾回收的总时间(单位秒)