java 程序消耗 cpu 100% 查找方法

http://sishuok.com/forum/blogPost/list/5653.html

问题原因:由于HashMap是非线程安全的,在多线程访问时,造成死循环。  

查找问题方法:  
1.

Java代码     收藏代码
  1. top  

找出最耗费cpu的进程号 如:27377  

2.
Java代码     收藏代码
  1. top -p 27377 -H  

找出此进程下的所有线程,然后找出最耗cpu线程号 如:27433  

3.
Java代码     收藏代码
  1. python  hex(27433)   

将十进制数转为16进制 如:0x6b29  

4.
Java代码     收藏代码
  1. jstack 27377 >cpu.log  

将此进程号的Java堆栈信息打印到文件中  

5.
Java代码     收藏代码
  1. grep 0x6bz8 cpu.log  

查看java堆栈中的线程nid 如:  
"foundationTaskExecutor-2" prio=10 tid=0x00007f064c041000 nid=0x6b28 runnable [0x00007f069f5da000]  

6.
Java代码     收藏代码
  1. vim cpu.log  

查找nid=0x6b28的内容 如:  
Java代码     收藏代码
  1. "foundationTaskExecutor-2" prio=10 tid=0x00007f064c041000 nid=0x6b28 runnable [0x00007f069f5da000]  
  2.    java.lang.Thread.State: RUNNABLE  
  3.         at java.util.HashMap.get(HashMap.java:320)  
  4.         at ***********************************(WareServiceImpl.java:64)  
  5.         at ***********************************(Mid2FoundationTask.java:127)  
  6.         at ***********************************(Mid2FoundationTask.java:27)  
  7.         at ***********************************$FoundationThreadImpl.run(Mid2FoundationTask.java:86)  
  8.         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)  
  9.         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)  
    1.         at java.lang.Thread.run(Thread.java:722

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值