最近在Linux服务器上部署java程序,头几天java程序还是在正常运作,然后就开始发现程序在cpu使用率上非常高,所以,程序侦探马对此问题展开追查。
追查过程:
1.查看资源占用情况# 使用top命令进行查看各个进程的资源占用情况,发现果然是java程序占用cpu使用率最高 # 根据发现,占用CPU使用率高的java程序的pid为:26357 top2.查看该进程的线程情况
# 根据该命令可以查看到该进程的每一条线程的情况 # 通过以上线程切片,可以发现一条线程的cpu使用率和运行时间的状况 # 可以发现 耗时00:50:28,cpu使用率为99.9%的线程tid为26541 ps -mp 26357 -o THREAD,tid,time3.查看该线程的状况
# 获取到tid后需要将tid转换成16进制,方便在jvm堆栈中查找 printf "%xn" 26541 # 可以获得结果为67ad # 通过jstack命令来查看该线程当前的内存状态 【jstack pid|grep 转换为16进制的tid -A 30】 jstack 26357|grep 67ad -A 30 # 可以发现cpu使用率高的原因: # 1.程序死循环 # 2.IO读写太高4.查看进程中的各个线程状况的方法二:
# 1.首先使用top命令查看各进程状况 top # 2.然后根据进程的pid查看该进程的状况 top -p 26357 # 3.然后将键盘切换为大写,点击H,就可以查看到各线程的状况 # 可以根据各线程的tid进行查看该线程当前的内存状态 【返回执行第3步】4.1 top 4.2 top -p 26356 4.3点击大写H 4.4 16进制转换 4.5 查看线程当前的内存状态



