jvm系列(5)性能监控工具

简介: 在平时的开发当中我们总是会遇到各种各样的问题,比如说内存泄漏、死锁、CPU等。遇到问题不可怕,关键是我们如何去排查这些错误,对症下药才是根本。不过对于很多人来说,往往找不到这些问题的根本所在,因此这篇文章主要是让我们掌握一些工具来分析到底是哪里出现了问题。在之前的文章中,主要是分析了JVM的内存结构、类加载机制和垃圾回收机制。文章的顺序也是循序渐进的,从这篇文章当中我们主要是分析JDK自带的工具,把理论应用于实践。首先我们先对几种要讲的工具进行一个概述,然后再分别分析

一、性能监控工具概述


工具主要是为了解决问题而生的,就是由于我们的程序存在着一些性能问题,才有了这些工具。其实当我们在下载完成JDK之后,那些工具就被SUN公司随之送给我们了。

我们可以在我们的JDK安装目录,下看看会有很多这样的工具。

v2-960d491c2fddcb497ece01600dc88b42_1440w.jpg我们会发现很多这样的exe文件,这里面有很多都是性能监控工具。我们就抽出来几个进行讲解。


工具名称主要作用jps(JVM Process Status Tool)显示指定系统中所有的HotSpot虚拟机进程jstat(JVM Statistics Monitoring Tool)收集HotSpot虚拟机各方面的运行数据jinfo(Configuration Info for Java)显示虚拟机配置信息jmap(Memory Map for Java)生成虚拟机的内存转储快照(heapdump文件)jhat(JVM Heap Dump Browser)分析内存转储快照,不推荐使用,消耗资源而且慢jstack(Stack Trace for Java)显示虚拟机的线程快照JConsoleJMX的可视化管理工具VisualVM多合一故障管理工具


常见的几个工具都已经列出来了,还有一些其他的工具,其实用起来比JDK自带的还要好,我会在今后的文章中列出来。OK,我们就一个一个去分析一下这些工具是干嘛的,以及如何去使用的。


二、工具


1、jps:虚拟机进程状况工具


jps主要用来输出JVM中运行的进程状态信息。语法格式如下:


jps [options] [hostid]


第一个参数:options


-q 不输出类名、Jar名和传入main方法的参数-m 输出传入main方法的参数-l 输出main类或Jar的全限名-v 输出传入JVM的参数


第二个参数:hostid


主机或者是服务器的id,如果不指定,就默认为当前的主机或者是服务器。

我是在Windows10系统下测试的,当然你可以在linux下试验,方式是一样的,结果可能有不同。你可以选择不同的参数选项来进行测试。打开CMD输入相应命令

v2-b62877cdab56ed8092c93ad68ea85ec0_1440w.png


2、jstack:堆栈跟踪工具


jstack用于生成虚拟机当前时刻的线程快照。语法格式如下:

jstack [option] vmid


第一个参数:option

选项作用-F当正常输出的请求不被相应时候,强制输出线程堆栈-l出堆栈外,显示关于锁的附加信息-m如果调用本地方法的话,可以显示C/C++的堆栈


第二个参数:vmid

vmid是Java虚拟机ID,在Linux/Unix系统上一般就是进程ID。

我们直接在CMD中操作一下:

v2-f9af33de2d0333f2b7cf4506bf513cbc_1440w.jpg


3、jstat:虚拟机统计信息监控工具


jstat监视虚拟机各种运行状态信息,可以显示本地或者是远程虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据。语法格式如下:


jstat [ generalOption | outputOptions vmid [interval] [count]] ]

第一个参数:generalOption | outputOptions


这个参数表示的option,代表着用户希望查询的虚拟机信息,分为类加载、垃圾收集、运行期编译状况3类。

v2-ed02daf1a450483ed8e17bc4b3444dd5_1440w.jpg

第二个参数:vmid

vmid是Java虚拟机ID,在Linux/Unix系统上一般就是进程ID。


第三个参数:interval

interval是采样时间间隔,


第四个参数:count

count表示的是采样数。

下面我们就是用一下这个工具,打开我们的CMD,输入相应的命令:

v2-0f76f2f30e6ef1014d193b0bfa5be843_1440w.jpg


4、jinfo:实时地查看和调整虚拟机各项参数


命令格式:

jinfo [option] pid


第一个参数:option

选项作用-v查看虚拟机启动时显示指定的参数列表-flag查看虚拟机启动时未被指定的参数的默认值-sysprops打印虚拟机进程的System.getProperties()的内容


第二个参数:pid

指定显示的进程id。

在CMD中进行测试:

v2-f9af33de2d0333f2b7cf4506bf513cbc_1440w.jpg


5、jmap:生成虚拟机的内存转储快照(heapdump文件)


jmap(Memory Map for Java,内存映像工具),用于生成堆转存的快照,一般是heapdump或者dump文件。如果不适用jmap命令,可以使用-XX:+HeapDumpOnOutOfMemoryError参数,当虚拟机发生内存溢出的时候可以产生快照。或者使用kill -3 pid也可以产生。jmap的作用并不仅仅是为了获取dump文件,它可以查询finalize执行队列,java堆和永久代的详细信息,如空间使用率,当前用的哪种收集器。命令格式如下:


jmap [option] vmid


第一个参数:

v2-6df802a07f0558de293a4d182ba07028_1440w.jpg

第二个参数:vmid

vmid是Java虚拟机ID,在Linux/Unix系统上一般就是进程ID.

在cmd中测试:

v2-fa0f96756b4c569fb7a0d607e9717344_1440w.jpg


6、jhat:分析内存转储快照,不推荐使用,而且慢


由于这个工具功能比较简陋,运行起来也比较耗时,所以这个工具不推荐使用,推荐使用MAT。


7、JConsole:JMX的可视化管理工具


这个工具相比较前面几个工具,使用率比较高,很重要。它是一个java GUI监视工具,可以以图表化的形式显示各种数据。并可通过远程连接监视远程的服务器VM。用java写的GUI程序,用来监控VM,并可监控远程的VM,非常易用,而且功能非常强。

在cmd里面输入 jconsole,选则进程就可以了。(前提是在IDE工具先建立一个线程运行着)

v2-d2bc10a2c85219316c0492c335de030c_1440w.jpg

然后我们选择了相应的选项之后,进入这个工具就会出现下面这个界面

v2-4fdc24f8e9a9923f36b650280d502ba1_1440w.jpg

在上面有菜单,我们可以选择其中一个进行查看,就可以了,这个用具用起来很方便,也是我之前用的比较多的工具。


8、VisualVM:多合一故障管理工具


这个工具也很牛bility。它同jconsole都是一个基于图形化界面的、可以查看本地及远程的JAVA GUI监控工具,Jvisualvm同jconsole的使用方式一样,直接在命令行打入jvisualvm即可启动,jvisualvm界面更美观一些,数据更实时:

v2-a517c78a08b909dab9463dd73a6fba45_1440w.jpg

最上面也有菜单,你可以选择不同的选项来展示。自己动手试一遍是最好的。


三、总结


这些工具就先写这么多,在文章一开始我们其实已经发现了,jdk自带的工具那是超级的多,而且随着jdk版本的不断更新,工具还有不断加强增多的趋势,想要每一个都掌握那太费时间了,我们遇到哪些问题去搜索一下,看看能用到哪些工具就可以了,列出的这几种工具,对于初学者来说还是比较适用的。

谢谢大家,如有问题还请批评指正。

相关文章
|
6月前
|
Arthas 监控 Java
(十一)JVM成神路之性能调优篇:GC调优、Arthas工具详解及各场景下线上最佳配置推荐
“在当前的互联网开发模式下,系统访问量日涨、并发暴增、线上瓶颈等各种性能问题纷涌而至,性能优化成为了现时代开发过程中炙手可热的名词,无论是在开发、面试过程中,性能优化都是一个常谈常新的话题”。
592 3
|
2月前
|
Arthas Prometheus 监控
监控堆外使用JVM工具
监控堆外使用JVM工具
54 7
|
3月前
|
JavaScript 前端开发 Java
jvm的jshell,学生的工具
本文介绍了JVM的jshell工具,它为Java平台添加了REPL(读取-评估-打印循环)功能,使得学习、探索编码和原型代码变得更加便捷,但作者认为其在实际开发中较为鸡肋。
54 1
jvm的jshell,学生的工具
|
3月前
|
Arthas 监控 数据可视化
JVM进阶调优系列(7)JVM调优监控必备命令、工具集合|实用干货
本文介绍了JVM调优监控命令及其应用,包括JDK自带工具如jps、jinfo、jstat、jstack、jmap、jhat等,以及第三方工具如Arthas、GCeasy、MAT、GCViewer等。通过这些工具,可以有效监控和优化JVM性能,解决内存泄漏、线程死锁等问题,提高系统稳定性。文章还提供了详细的命令示例和应用场景,帮助读者更好地理解和使用这些工具。
|
3月前
|
存储 监控 算法
JVM调优深度剖析:内存模型、垃圾收集、工具与实战
【10月更文挑战第9天】在Java开发领域,Java虚拟机(JVM)的性能调优是构建高性能、高并发系统不可或缺的一部分。作为一名资深架构师,深入理解JVM的内存模型、垃圾收集机制、调优工具及其实现原理,对于提升系统的整体性能和稳定性至关重要。本文将深入探讨这些内容,并提供针对单机几十万并发系统的JVM调优策略和Java代码示例。
74 2
|
3月前
|
小程序 Oracle Java
JVM知识体系学习一:JVM了解基础、java编译后class文件的类结构详解,class分析工具 javap 和 jclasslib 的使用
这篇文章是关于JVM基础知识的介绍,包括JVM的跨平台和跨语言特性、Class文件格式的详细解析,以及如何使用javap和jclasslib工具来分析Class文件。
68 0
JVM知识体系学习一:JVM了解基础、java编译后class文件的类结构详解,class分析工具 javap 和 jclasslib 的使用
|
5月前
|
缓存 监控 算法
吃透 JVM 诊断方法与工具使用
【8月更文挑战第4天】深入了解并掌握JVM诊断需把握几大要点:1) 熟悉JVM内存模型,如堆、栈及方法区;2) 掌握垃圾回收机制与算法;3) 运用工具如`jps`(查看Java进程)、`jstat`(监控运行状态)、`jmap`(生成堆快照)、`jhat`(分析堆快照)、`jstack`(检查线程栈); 4) 利用专业工具如Eclipse Memory Analyzer分析堆转储文件查找内存泄漏; 5) 动态监控与调整JVM参数; 6) 结合日志分析性能瓶颈。通过实战案例加深理解,有效应对JVM性能问题。
|
5月前
|
监控 Java 开发者
揭秘Struts 2性能监控:选对工具与方法,让你的应用跑得更快,赢在起跑线上!
【8月更文挑战第31天】在企业级应用开发中,性能监控对系统的稳定运行至关重要。针对流行的Java EE框架Struts 2,本文探讨了性能监控的工具与方法,包括商用的JProfiler、免费的VisualVM以及Struts 2自带的性能监控插件。通过示例代码展示了如何在实际项目中实施这些监控手段,帮助开发者发现和解决性能瓶颈,确保应用在高并发、高负载环境下稳定运行。选择合适的监控工具需综合考虑项目需求、成本、易用性和可扩展性等因素。
54 0
|
5月前
|
Java 开发者 前端开发
Struts 2、Spring MVC、Play Framework 上演巅峰之战,Web 开发的未来何去何从?
【8月更文挑战第31天】在Web应用开发中,Struts 2框架因强大功能和灵活配置备受青睐,但开发者常遇配置错误、类型转换失败、标签属性设置不当及异常处理等问题。本文通过实例解析常见难题与解决方案,如配置文件中遗漏`result`元素致页面跳转失败、日期格式不匹配需自定义转换器、`<s:checkbox>`标签缺少`label`属性致显示不全及Action中未捕获异常影响用户体验等,助您有效应对挑战。
113 0
|
5月前
|
SQL 监控 关系型数据库
SQL性能监控与调优工具的神奇之处:如何用最佳实践选择最适合你的那一个,让你的数据库飞起来?
【8月更文挑战第31天】在现代软件开发中,数据库性能监控与调优对应用稳定性至关重要。本文对比了数据库内置工具、第三方工具及云服务工具等几种常用SQL性能监控与调优工具,并通过示例代码展示了如何利用MySQL的EXPLAIN功能分析查询性能。选择最适合的工具需综合考虑功能需求、数据库类型及成本预算等因素。遵循了解工具功能、试用工具及定期维护工具等最佳实践,可帮助开发者更高效地管理和优化数据库性能,迎接未来软件开发中的挑战与机遇。
73 0