当前位置:网站首页>JVM常用监控工具解释以及使用
JVM常用监控工具解释以及使用
2022-08-09 12:22:00 【Java技术债务】
目录
jps进程状况工具
jps:JVM Process Status Tool
jps [options] [hostId]
jps工具的主要选项options
jstat统计信息监控工具
jstat:JVM Statistics Monitoring Tool
可以显示本地或者远程虚拟机进程中的类加载、内存、垃圾手机、即时编译等运行时数据。
jstat [options vmid [interval [s/ms] [count] ] ]
注意:本地虚拟机VMID和LVMID是一致的,
远程虚拟机的VMID格式为: [protocol : ] [//] lvmid [@hostname [:port] /servername]
参数interval和count代表查询间隔和次数,如果省略代表查询一次。
选项options代表用户查询的虚拟机信息,主要分为三类:
1、类加载 2、垃圾收集 3、运行期编译情况
jstat工具的主要选项options
如图所示,每秒监控进程ID为1的gc情况以及内存使用情况
如下所示,是图中标题名的解释:
堆内存 = 年轻代 + 年老代 + 永久代 年轻代 = Eden区 + 两个Survivor区(From和To) S0C、S1C、S0U、S1U:Survivor 0/1区容量(Capacity)和使用量(Used) EC、EU:Eden区容量和使用量 OC、OU:年老代容量和使用量 PC、PU:永久代容量和使用ssss量 YGC、YGT:年轻代GC次数和GC耗时 FGC、FGCT:Full GC次数和Full GC耗时 GCT:GC总耗时
jmap堆内存使用状况
jmap用来查看堆内存使用状况,一般结合jhat使用。 jmap语法格式如下:
jmap [option] pid
jmap [option] executable core
jmap [option] [[email protected]]remote-hostname-or-ip
如果运行在64位JVM上,可能需要指定-J-d64命令选项参数。
jmap -permstat pid
- 使用jmap -heap pid查看进程堆内存使用情况,包括使用的GC算法、堆配置参数和各代中堆内存使用情况。
- 使用jmap -histo[:live] pid [| more]查看堆内存中的对象数目、大小统计直方图,如果带上live则只统计活对象
#instance
是对象的实例个数#bytes
是总占用的字节数 class name 对应的就是 Class 文件里的 class 的标识 B 代表 byte C 代表 char D 代表 double F 代表 float I 代表 int J 代表 long Z 代表 boolean 前边有 [ 代表数组, [I 就相当于 int[] 对象用 [L+ 类名表示
用jmap把进程内存使用情况dump到文件中,再用jhat分析查看。jmap进行dump命令格式如下:
jmap -dump:format=b,file=/tmp/dump.dat pid
dump出来的文件可以用MAT、VisualVM等工具查看,这里用jhat查看:
jhat -port 9998 /tmp/dump.dat
注意:如果Dump文件太大,可能需要加上-J-Xmx512m这种参数指定最大堆内存,即jhat -J-Xmx512m -port 9998 /tmp/dump.dat。然后就可以在浏览器中输入主机地址:9998查看了
jstack线程堆栈信息
jstack主要用来查看某个Java进程内的线程堆栈信息。语法格式如下:
jstack [option] pid jstack [option] executable core jstack [option] [[email protected]]remote-hostname-or-ip
- -l long listings,会打印出额外的锁信息,在发生死锁时可以用jstack -l pid来观察锁持有情况
- -m mixed mode,不仅会输出Java堆栈信息,还会输出C/C++堆栈信息(比如Native方法)
jstack可以定位到线程堆栈,根据堆栈信息我们可以定位到具体代码,所以它在JVM性能调优中使用得非常多。下面我们来一个实例找出某个Java进程中最耗费CPU的Java线程并定位堆栈信息,用到的命令有ps、top、printf、jstack、grep。
边栏推荐
- 新起之秀 DPU,正在掀起数据中心变革!
- 在北极都可以穿短袖了,温度飙升至32.5℃
- Go 事,如何成为一个Gopher ,并在7天找到 Go 语言相关工作,第1篇
- AQS Synchronization Component - FutureTask Analysis and Use Cases
- 罗振宇折戟创业板/ B站回应HR称用户是Loser/ 腾讯罗技年内合推云游戏掌机...今日更多新鲜事在此...
- Flutter入门进阶之旅(一)-初识Flutter
- 注释、关键字、标识符的区别你知道吗?
- The batch size does not have to be a power of 2!The latest conclusions of senior ML scholars
- WeChat payment development process
- Intranet penetration tool ngrok usage tutorial
猜你喜欢
Common gadgets of Shell (sort, uniq, tr, cut)
Fragment中嵌套ViewPager数据空白页异常问题分析
史上最猛“员工”,疯狂吐槽亿万富翁老板小扎:那么有钱,还总穿着同样的衣服!...
ansible-cmdb友好展示ansible收集主机信息
Report: The number of students who want to learn AI has increased by 200%, and there are not enough teachers
Data Mining-05
1-hour live broadcast recruitment order: industry big names share dry goods, and enterprise registration opens丨qubit·viewpoint
两分钟录音就可秒变语言通!火山语音音色复刻技术如何修炼而成?
ABAP 报表中如何以二进制方式上传本地文件试读版
API调用,API传参,面向对接开发,你真的会写接口文档吗?
随机推荐
造自己的芯,让谷歌买单!谷歌再度开源 180nm 工艺的芯片
MongoDB-查询中$all的用法介绍
Compensation transaction and idempotency guarantee based on CAP components
如何修改data work上jdbc驱动的版本
大佬们,请教一下,我看官方文档中,sqlserver cdc只支持2012版之后的,对于sqlser
Golang学习之路(五):Golang的函数
The latest interview summary in 20022 brought by Ali senior engineer is too fragrant
Customize VIEW to realize in-app message reminder to rotate up and down
Flutter入门进阶之旅(七)GestureDetector
1小时直播招募令:行业大咖干货分享,企业报名开启丨量子位·视点
注:检测到当前使用的ADB不是HBuilder内置或自定义ADB:PID为:9544进程名称为:adb.exe 路径为:c:\users\administrator\appdata\local\and
二叉树的序列化和反序列化
在“Extend the Omniverse”比赛中构建用于 3D 世界的工具
GPT-3组合DALL·E,60秒内搞定游戏设定和原型动画!网友看后:这游戏想玩
超越CLIP的多模态模型,只需不到1%的训练数据!南加大最新研究来了
【无标题】
【Untitled】
API调用,API传参,面向对接开发,你真的会写接口文档吗?
两个链表相加
ABAP 面试题:如何使用 ABAP 编程语言的 System CALL 接口,直接执行 ABAP 服务器所在操作系统的 shell 命令?