java 手動jstack,獲取堆棧信息


java 手動jstack,獲取堆棧信息:

利用jstack找出 Jmeter在 linux 卡死的具體原因

(1)利用 top 找出占用 cpu 最高的 java 進程id: 8536

(2)利用下面命令占用CPU 最高的線程Id: 8542

     top -Hp 8536 -d 1 -n 1 

(3)打印出java 進程 8536 的堆棧信息:

     jstack 8536 > javadump.txt

(4)  把線程id 8542 轉換為十六進制 215e (命令:echo "obase=16;8542" |bc)

     在javadump.txt 中查找 215e, 然后就發現下面的堆棧信息:

   "StandardJMeterEngine" prio=10 tid=0x00002b94ec4a3000 nid=0x215e runnable [0x00002b9536fe0000]java.lang.Thread.State: RUNNABLE

         at org.apache.jmeter.protocol.java.sampler.AbstractJavaSamplerClient.teardownTest(AbstractJavaSamplerClient.java:66)

         at com.wangyin.jmeter.HessianRequest.teardownTest(HessianRequest.java:140)

        at org.apache.jmeter.protocol.java.sampler.JavaSampler.testEnded(JavaSampler.java:287)

         - locked<0x0000000740139670> (a java.util.HashSet)

         at org.apache.jmeter.engine.StandardJMeterEngine.notifyTestListenersOfEnd(StandardJMeterEngine.java:221)

        at org.apache.jmeter.engine.StandardJMeterEngine.run(StandardJMeterEngine.java:437)

        at java.lang.Thread.run(Thread.java:662)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM