1、top命令按内存占用排序【大写M】
这里我们选取进程号为
13144
来走一遍流程。请忽略jvm内存分配情况哈,jvm调优过段时间贴出来。
我没打马赛克,别攻击我服务器哈。
2、查看该进程中对象的大小及个数
jmap命令是JDK自带的一个,查看jvm内存使用详情的命令。
jmap -histo:live 13144 | head -23
3、获取该进程中堆栈的使用信息
jstack -l 13144 > jstack.log
4、获取该进程下的线程
使用ps命令获取该进程下的所有线程,我们这里取第一条的TID
13233
。
ps p 13144 -L -o pcpu,pmem,pid,tid,time,tname,cmd | sort -r -t ' ' -k 1 | head -20
5、获取该线程对应的16进制
printf "%x\n" 13233
6、查看该线程的使用资源的具体信息vim jstack.log
java.lang.Thread.State: WAITING (parking):一直等某个条件发生唤醒自己;
java.lang.Thread.State: TIMED_WAITING (parking或sleeping):定时的,某个条件不到来,也将定时唤醒自己。