【JVM 工具命令】JAVA程序线上问题诊断,JVM工具命令的使用,jstat, jstack,jmap命令的使用

【JVM 工具命令】JAVA程序线上问题诊断,JVM工具命令的使用,jstat, jstack,jmap命令的使用

1. JVM监控工具: Jstat命令

通过这个命令查询java程序,gc的情况

jstat -gcutil {pid} 5000 12

· 5000 表示5000毫秒刷新一次

· 12 表示统计12次

· O这一列 达到100就会触发fgc,我们优化jvm就是尽量减少jvm 进行fgc的次数

· FGC这一列表示fullgc的次数

· FGCT这一列表示累计进行fullgc的耗时,第三次fgc的时间减去第二次fgc的时间就是第三次fgc花费的时间。0.152-0.125

通过jstat命令我们发现问题后就可以通过下面的jstack命令来定位java的哪个线程导致的具体问题。

2. JVM监控工具:Jstack命令

Jstack {pid} -- 查看堆栈信息

Jstack {pid} | grep {xid} -A 30 -- 查看堆栈中指定的某个线程的日志信息。 {xid} 必须是十六进制的线程id

Jstack命令只会打印一次信息,可以写下面的一个脚本,来持续输出线程日志信息

3. JVM监控工具: JMap Histo

JMap命令会触发 full gc,生产环境中需要注意使用。

jmap -histo:live {pid} 通过这个命令观察内存中最多的对象, 判断内存中积累的数据,监视内存中当前存活的对象内存占用情况。

jmap -histo:live pid 命令却不知道这些对象具体的值,可以通过 jmap -heapdump 命令

4. JVM监控工具: JMap -heapdump

jmap -dump:live, format=b, file=/root/tomcat.data {pid} 通过这个命令 输出当前内存中的对象数据。

jmap命令都会出发fgc。 jvm优化就是优化减少fgc次数,同时减少fgc的时间。

相关推荐
24k小善34 分钟前
Flink TaskManager详解
java·大数据·flink·云计算
杜小暑38 分钟前
动态内存管理
c语言·开发语言·动态内存管理
想不明白的过度思考者39 分钟前
Java从入门到“放弃”(精通)之旅——JavaSE终篇(异常)
java·开发语言
我真的不会C1 小时前
QT窗口相关控件及其属性
开发语言·qt
CodeCraft Studio1 小时前
Excel处理控件Aspose.Cells教程:使用 Python 在 Excel 中进行数据验
开发语言·python·excel
.生产的驴1 小时前
SpringBoot 封装统一API返回格式对象 标准化开发 请求封装 统一格式处理
java·数据库·spring boot·后端·spring·eclipse·maven
火柴盒zhang1 小时前
websheet之 编辑器
开发语言·前端·javascript·编辑器·spreadsheet·websheet
猿周LV1 小时前
JMeter 安装及使用 [软件测试工具]
java·测试工具·jmeter·单元测试·压力测试
景天科技苑1 小时前
【Rust】Rust中的枚举与模式匹配,原理解析与应用实战
开发语言·后端·rust·match·enum·枚举与模式匹配·rust枚举与模式匹配
晨集1 小时前
Uni-App 多端电子合同开源项目介绍
java·spring boot·uni-app·电子合同