jstack,用于检测死锁
来源:互联网 发布:网络阅卷注意事项 编辑:程序博客网 时间:2024/05/21 10:06
命令:jstack 进程号
用于检测线程是否存在死锁,通过打印出jvm线程栈来进行跟踪
实例:
Found one Java-level deadlock:
=============================
"Thread-1":
waiting for ownable synchronizer 0x00000007d6e6dab8, (a java.util.concurrent.locks.ReentrantLock$NonfairSync),
which is held by "Thread-0"
"Thread-0":
waiting for ownable synchronizer 0x00000007d6e6dae8, (a java.util.concurrent.locks.ReentrantLock$NonfairSync),
which is held by "Thread-1"
Java stack information for the threads listed above:
===================================================
"Thread-1":
at sun.misc.Unsafe.park(Native Method)
- parking to wait for <0x00000007d6e6dab8> (a java.util.concurrent.locks.ReentrantLock$NonfairSync)
at java.util.concurrent.locks.LockSupport.park(LockSupport.java:186)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.parkAndCheckInterrupt(AbstractQueuedSynchronizer.java:834)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.acquireQueued(AbstractQueuedSynchronizer.java:867)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.acquire(AbstractQueuedSynchronizer.java:1197)
at java.util.concurrent.locks.ReentrantLock$NonfairSync.lock(ReentrantLock.java:214)
at java.util.concurrent.locks.ReentrantLock.lock(ReentrantLock.java:290)
at com.test.jdk.DeadLockTest$2.run(DeadLockTest.java:40)
at java.lang.Thread.run(Thread.java:745)
"Thread-0":
at sun.misc.Unsafe.park(Native Method)
- parking to wait for <0x00000007d6e6dae8> (a java.util.concurrent.locks.ReentrantLock$NonfairSync)
at java.util.concurrent.locks.LockSupport.park(LockSupport.java:186)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.parkAndCheckInterrupt(AbstractQueuedSynchronizer.java:834)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.acquireQueued(AbstractQueuedSynchronizer.java:867)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.acquire(AbstractQueuedSynchronizer.java:1197)
at java.util.concurrent.locks.ReentrantLock$NonfairSync.lock(ReentrantLock.java:214)
at java.util.concurrent.locks.ReentrantLock.lock(ReentrantLock.java:290)
at com.test.jdk.DeadLockTest$1.run(DeadLockTest.java:21)
at java.lang.Thread.run(Thread.java:745)
Found 1 deadlock.
可以发现线程1和线程0形成了死锁。
- jstack,用于检测死锁
- jps,jstack检测java死锁
- Java虚拟机工具之堆栈跟踪工具jstack检测死锁
- jstack分析死锁
- 使用jstack 发现死锁
- Future机制用于并发编程时的死锁检测
- jstack死锁相关线程栈
- 检测死锁
- 检测死锁
- 分析Java死锁:分析jstack日志
- 用jstack分析解决进程死锁问题
- 使用jstack分析解决进程死锁问题
- 死锁模拟和检测
- SQL检测死锁
- ------如何检测死锁---------
- 如何检测死锁
- 检测和结束死锁
- 002 死锁检测
- 5 设计模式之状态模式(五)
- div居中
- RT5350硬件调试总结
- 博客第一天......
- solr DataImportHandler (数据相关操作)
- jstack,用于检测死锁
- ListView的优化
- Unity中用触摸控制物体旋转和放大
- Java的引用类型(附图说明)
- Internal Sorting: Straight selection sort: Sorting by Selection
- TalkingData美国旧金山之行 —— Twitter
- Source Insight上添加svn命令,打开当前文件夹命令
- Python之学习笔记(模块的使用)
- Log4net 初识及简单使用