700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > Java JVM 读书笔记 - 虚拟机性能监控和故障处理工具

Java JVM 读书笔记 - 虚拟机性能监控和故障处理工具

时间:2023-01-20 01:03:42

相关推荐

Java JVM 读书笔记 -  虚拟机性能监控和故障处理工具

给系统定位问题,知识、经验是关键基础,数据时依据,工具是运用知识处理数据的手段。

数据:运行日志 异常堆栈 GC日志 线程快照(threaddump/javacore文件) 堆转储快照(heapdump/hprof文件)

一 JDK命令行工具

1 jps 虚拟机进程状况工具

常用的几个参数:

-l 输出java应用程序的main class的完整包

-q仅显示pid,不显示其它任何相关信息

-m输出传递给main方法的参数

-v输出传递给JVM的参数。在诊断JVM相关问题的时候,这个参数可以查看JVM相关参数的设置

2 jstat 虚拟机统计信息监视工具

jstat[generalOption|outputOptionsvmid[interval[s|ms][count]]]

vmid是虚拟机ID,在Linux/Unix系统上一般就是进程ID。interval是采样时间间隔。count是采样数目。比如下面输出的是GC信息,采样时间间隔为250ms,采样数为4:

要明白上面各列的意义,先看JVM堆内存布局:

现在来解释各列含义:

3 jinfo java配置信息工具

观察运行中的java程序的运行环境参数:参数包括Java System属性和JVM命令行参数

实例:jinfo 2083

其中2083就是java进程id号,可以用jps得到这个id号。

输出内容太多了,不在这里一一列举,大家可以自己尝试这个命令。

4 jmap Java内存映像工具

jmap(Memory Map)和 jhat(Java Heap Analysis Tool)

jmap用来查看堆内存使用状况,一般结合jhat使用。

jmap语法格式如下:

打印进程的类加载器和类加载器加载的持久代对象信息,输出:类加载器名称、对象是否存活(不可靠)、对象地址、父类加载器、已加载的类大小等信息

使用jmap -heap pid查看进程堆内存使用情况,包括使用的GC算法、堆配置参数和各代中堆内存使用情况。

使用jmap -histo[:live] pid查看堆内存中的对象数目、大小统计直方图,如果带上live则只统计活对象

还有一个很常用的情况是:用jmap把进程内存使用情况dump到文件中,再用jhat分析查看。jmap进行dump命令格式如下:

dump出来的文件可以用MAT、VisualVM等工具查看,这里用jhat查看

然后就可以在浏览器中输入主机地址:9998查看

5 jstack命令(Java Stack Trace)

jstack主要用来查看某个Java进程内的线程堆栈信息。语法格式如下:

命令行参数选项说明如下:

jstack可以定位到线程堆栈,根据堆栈信息我们可以定位到具体代码,所以它在JVM性能调优中使用得非常多。下面我们来一个实例找出某个Java进程中最耗费CPU的Java线程并定位堆栈信息,

用到的命令有ps、top、printf、jstack、grep。

第一步先找出Java进程ID,我部署在服务器上的Java应用名称为mrf-center:

得到进程ID为21711

第二步找出该进程内最耗费CPU的线程top -Hp pid

输出如下:

TIME列就是各个Java线程耗费的CPU时间,CPU时间最长的是线程ID为21742的线程

得到21742的十六进制值为54ee,下面会用到。

OK,下一步终于轮到jstack上场了,它用来输出进程21711的堆栈信息,然后根据线程ID的十六进制值grep,如下:

可以看到CPU消耗在PollIntervalRetrySchedulerThread这个类的Object.wait(),我找了下我的代码,定位到下面的代码:

它是轮询任务的空闲等待代码,上面的sigLock.wait(timeUntilContinue)就对应了前面的Object.wait()。

一 JDK的可视化工具

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。