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