码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2015-01-20 13:40:55      阅读:274      评论:0      收藏:0      [点我收藏+]

标签:

问题原因:由于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)  
    10.         at java.lang.Thread.run(Thread.java:722)  

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

标签:

原文地址:http://www.cnblogs.com/gisblogs/p/4235811.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!