linux查询cpu过高原因–java
一、查看线程级别的cpu占用情况
-
查询java pid top -c
-
查询java进程下,线程情况
# 方法一
ps H -eo user,pid,ppid,tid,time,%cpu,cmd --sort=%cpu | grep PID
# 方法二
ps -mp PID -o THREAD,tid,time
# 方法三(这个简单,一目了然)
top -Hp pid #查询显示问题进程PID 对应的线程列表(threadIdList)
#-H :Threads-mode operation
#-p :Monitor-PIDs
二、如何将问题定位到代码行级别?
查看堆栈信息的强大工具:gstack/pstack(c/c++程序)
gstack/pstack 进程号
- 将10进制线程id转为16进制
printf "%x \n" threadId(tid)
- 查询线程情况
jstack 【进程ID PID】 | grep 【线程ID十六进制】 -A 10 -B 10
jstack pid|grep '0xtid' -C5 --color
或者jstack pid > a.txt。在a.txt查询 nid=0xtid
- $yum install gdb #安装gstack
$gstack 进程id > stack.txt #将进程信息输出到文件中