本文转发来自博主figo_2009的博客,这里有地址可以链接过去:https://blog.csdn.net/figo_2009/article/details/84395703。内容一样。我拿过来的目的是在从写一遍加深记忆,也可以做个保留,为以后解决,分析内存,线程问题做一些技术储备。
--------------------------------------------------------------------分割线--------------------------------------------------------------------
公司内部同事分享的一篇文章周末看到一个用jstack查看死锁的例子。昨天晚上总结了一下jstack(查看线程)、jmap(查看内存)和jstat(性能分析)命令。供大家参考
1.jstack(查看线程)
1.1 jstack能得到运行java程序的java stack和native stack的信息。可以轻松得知当前线程的运行情况。如下所示,注:这个和thread dump是同样的结果。但是thread dump是用kill -3 pid命令,还是服务器上面少用kill为妙
RMI TCP Connection(267865)-172.16.5.25" daemon prio=10 tid=0x00007fd508371000 nid=0x55ae waiting for monitor entry [0x00007fd4f8684000]
java.lang.Thread.State: BLOCKED (on object monitor)
at org.apache.log4j.Category.callAppenders(Category.java:201)
- waiting to lock <0x00000000acf4d0c0> (a org.apache.log4j.Logger)
at org.apac