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)

 

posted on 2018-11-07 17:11  进_进  阅读(2809)  评论(0)    收藏  举报