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)