记一次项目运行cpu过高处理

第一次处理这种问题,新手不懂的从何下手走了不少弯路,记录一下,以后借鉴.

对于cpu运行过高的问题,首先要打印堆栈信息,和线程运行cpu使用情况:

   1.打印堆栈信息:

      先通过top -c找到自己的线程对应的id值:

     

   jstack -l pid值 > new.txt 把当前线程的栈打到文件中

   ps -mp pid值 -o THREAD,tid,time >a.txt  把当前线程的cpu使用情况打到文件中,通过分析找到占用cpu最高的线程

  

通过printf "%x\n" 线程id来获取线程对应的16进制的值,通过16进制的值获取其对应的堆栈信息,例如28605对应的16进制为6fbd,对应的栈信息为:

对应的是一个jetty的进程,对于这种,一般情况下就不是程序的问题,可以通过升级jar包来解决,如果无法确定的话可以只起一个jetty服务,避免加入自己的代码,自己发请求进行测试。

如果是定位到了自己的代码里那可能是存在死循环,需要自行进行判断.

推荐一个好用的工具,可以看导出的堆栈文件:jca.jar,通过java -Xmx200m -jar jca457.jar来运行.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值