线上某台runtime机器(windows Server)cpu报警,这种情况初步就是代码里面死循环了,先把机器下线了保证不再有新的任务分配进来,然而cpu使用依然不降这是正常的因为程序未结束死循环一直在运行。
把Java进程导出快照。
jstack -l pid > c:/31372.stack
在windows下只能查看进程的cpu占用率,要查看线程的cpu占用率要借助其他的工具,可以使用微软提供的 Process Explorer(点击前往下载页面)
使用如下命令找到最耗CPU的进程,然后再按一下 1,就会显示你服务器逻辑CPU的数量以及现在服务器CPU各个参数。占用最高的排在前面,我们可以看到占用高的ava进程
top -c
找出占用高的Java线程,显示一个进程的线程运行信息列表,按一下P查看最高占用
top -Hp pid
jstack pid > error.log
目标线程pid转16进制
printf “%x\n” pid
查找error.log中pid16进制转化后的位置
grep pid error.log –color
原文:https://www.cnblogs.com/lyhero11/p/11408988.html