博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java 定位工具
阅读量:6341 次
发布时间:2019-06-22

本文共 912 字,大约阅读时间需要 3 分钟。

#查看JVM所有进程及启动类信息以及PID

jps -mlvV

#查看JVM运行各种状态信息,包括GC,类加载,堆内存信息,jit编译信息等
jstat -gcutil <PID> (堆内存信息,已使用内存占比)

 

#查看JVM堆中存活对象详细占用情况

jmap -histo:live <PID>

#导出整个JVM 中内存信息

jmap -dump:format=b,file=文件名 [pid]

#用于分析JVM DUMP 文件的工具,基于此工具可分析JVM HEAP 中对象的内存占用情况

jhat -J-mx1024m heap.bi

 

#查看堆栈

jstack

可以看到JVM 中线程的运行状况,包括锁等待,线程是否在运行

执行 jstack [pid] ,线程的所有堆栈信息

"http-8080-10" daemon prio=10 tid=x0a949bb60 nid=0x884  waiting for monitor entry [...]

"http-8080-10" 这个线程处于等待状态。 waiting for monitor entry 如果在连续几次输出线程堆栈信息都存在于同一个或多个线程上时,则说明系统中有锁竞争激烈,死锁,或锁饿死的想象。

“http-8080-11” daemon prio=10 tix=xxx nid=xxx in object.wait() [...]
 java.lang.Thread.State:waiting (on object monitor)
该表示http-8080-11的线程处于对象的Wait 上,等待其他线程的唤醒,这也是线程池的常见用法。

“Low Memory Detector”daemon prio=10 tix=xx nid=xxx runnable [...] java.lang.Thread.State:runnable

表示“Low Memory Detector” 的线程处于Runable状态,等待获取CPU的使用权.

 

转载于:https://www.cnblogs.com/lwcoding/p/6651669.html

你可能感兴趣的文章
android实现gif图与文字混排
查看>>
安卓新标准出台_告别乱弹窗_你的手机真会省电么?
查看>>
hdu1384Intervals(差分约束)
查看>>
python 字符编码
查看>>
269D Maximum Waterfall
查看>>
C++11 多线程
查看>>
sed-加速你在Linux的文件编辑
查看>>
HttpServer发送数据到kafka
查看>>
phpcms站---去除域名绑定目录中的HTML
查看>>
2017-5-3 打印控件、MDI 窗体容器
查看>>
20155303 2016-2017-2 《Java程序设计》第九周学习总结
查看>>
一次很失败的抄底
查看>>
数据结构C++(10)二叉树——链表实现(linkBinaryTree)
查看>>
利用Condition实现多线程交替执行
查看>>
里氏替换原则(设计模式原则2)
查看>>
lamp一键安装
查看>>
解决“iOS 7 app自动更新,无法在app中向用户展示更新内容”问题
查看>>
OpenCV——Haar-like特征
查看>>
HttpWebResponse发送post请求并接收
查看>>
python 相对路径和绝对路径的区别
查看>>