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

源:http://kevin1.iteye.com/blog/1532716
问题原因:由于HashMap是非线程安全的,在多线程访问时,造成死循环。

查找问题方法:
1.
Java代码  收藏代码

    top 


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

2.
Java代码  收藏代码

    top -p 27377 -H 


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

3.
Java代码  收藏代码

    python  hex(27433)  


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

4.
Java代码  收藏代码

    jstack 27377 >cpu.log 


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

5.
Java代码  收藏代码

    grep 0x6bz8 cpu.log 


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

6.
Java代码  收藏代码

    vim cpu.log 


查找nid=0x6b28的内容 如:
Java代码  收藏代码

    "foundationTaskExecutor-2" prio=10 tid=0x00007f064c041000 nid=0x6b28 runnable [0x00007f069f5da000] 
       java.lang.Thread.State: RUNNABLE 
            at java.util.HashMap.get(HashMap.java:320) 
            at ***********************************(WareServiceImpl.java:64) 
            at ***********************************(Mid2FoundationTask.java:127) 
            at ***********************************(Mid2FoundationTask.java:27) 
            at ***********************************$FoundationThreadImpl.run(Mid2FoundationTask.java:86) 
            at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) 
            at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) 
            at java.lang.Thread.run(Thread.java:722) 

猜你喜欢

转载自mauersu.iteye.com/blog/2334494
今日推荐