JVM监控工具介绍

JVM监控工具介绍

VisualVM是一种集成了多个JDK命令行工具的可视化工具,它能为您提供强大的分析能力。所有这些都是免费的!它囊括的命令行工具包括jps,jstat,jmap,jinfo,jstack,JConsole,这些工具与JDK的标准版本是一致的。

jps:与unix上的ps类似,用来显示本地的java进程,可以查看本地运行着几个java程序,并显示他们的进程号。

jstat:一个极强的监视VM内存工具。可以用来监视VM内存内的各种堆和非堆的大小及其内存使用量。

jmap:打印出某个java进程(使用pid)内存内的,所有‘对象’的情况(如:产生那些对象,及其数量)。

jinfo:此JVM监控工具可以输出并修改运行时的java进程的opts。

jsatck:如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的javastack和nativestack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题。

jconsole:一个javaGUI监视工具,可以以图表化的形式显示各种数据。并可通过远程连接监视远程的服务器VM。

JVM监控工具的详细介绍:

1)   jps工具:

与unix系统里的ps命令类似,作用是显示当前系统的java进程情况,及其id号。可以通过jps查看启动了几个java进程(因为每个java程序都会独占一个java虚拟机实例),和他们的进程号(为下面几个程序做准备),并可通过opt来查看这些进程的详细启动参数。

使用方法:在当前命令行下打jps(需要JAVA_HOME,没有的话,到改程序的目录下打)

2)   jstat工具:

jstat工具特别强大,有众多的可选项,详细查看堆内各个部分的使用量,以及加载类的数量。使用时,需加上查看进程的进程id,和所选参数。以下详细介绍各个参数的意义。

http://blog.csdn.net/zhaozheng7758/article/details/8623549

jstat -class pid:显示加载class的数量,及所占空间等信息。

jstat -compiler pid:显示VM实时编译的数量等信息。

jstat –gc pid:可以显示gc的信息,查看gc的次数,及时间。其中最后五项,分别是younggc的次数,younggc的时间,fullgc的次数,fullgc的时间,gc的总时间。

jstat –gc capacity:可以显示,VM内存中三代(young,old,perm)对象的使用和占用大小,如:PGCMN显示的是最小perm的内存使用量,PGCMX显示的是perm的内存最大使用量,PGC是当前新生成的perm内存占用量,PC是但前perm内存占用量。其他的可以根据这个类推,OC是old内纯的占用量。

jstat -gcnew pid:new对象的信息。
jstat -gcnewcapacity pid:new对象的信息及其占用量。
jstat -gcold pid:old对象的信息。
jstat  -gcoldcapacity pid:old对象的信息及其占用量。
jstat  -gcpermcapacity pid:perm对象的信息及其占用量。
jstat -gcutil pid:统计gc信息统计。
jstat –printcompilation pid:当前VM执行的信息。
除了以上一个参数外,还可以同时加上两个数字,如:

jstat -printcompilation 3024 250 6是每250毫秒打印一次,一共打印6次,还可以加上-h3每三行显示一下标题。

3)   jmap工具:

是一个可以输出所有内存中对象的工具,可以将VM中的heap,以二进制输出成文本。

使用方法jmap-histopid。如果连用SHELLjmap-histopid>a.log可以将其保存到文本中去,在一段时间后,使用文本对比工具,可以对比出GC回收了哪些对象。jmap-dump:format=b,file=String3024可以将3024进程的内存heap输出出来到String文件里。

4)   jinfo工具:

能输出并修改运行时的java进程的运行参数。使用方法 jmap -histo pid。如果连用 SHELL jmap -histo pid>a.log可以将其保存到文本中去(windows下也可以使用),在一段时间后,使用文本对比工具,可以对比出GC回收了哪些对象。 jmap -dump:format=b,file=f1 3024可以将3024进程的内存heap输出出来到f1文件里

5)   jstack工具:

可以观察到jvm中当前所有线程的运行情况和线程当前状态
jstack 2083

6)   jconsole工具:

是一个用java写的GUI程序,用来监控VM,并可监控远程的VM,非常易用,而且功能非常强。由于是GUI程序,不会的地方可以参考SUN的官方文档。
使用方法:命令行里打jconsole,选则进程就可以了。http://swiftlet.net/archives/658

使用参考:    http://jiajun.iteye.com/blog/810150

使用参考:http://blog.csdn.net/arkblue/article/details/6229637

时间: 2024-08-24 13:18:23

JVM监控工具介绍的相关文章

JVM监控工具介绍jstack, jconsole, jinfo, jmap, jdb, jstat(复制)

jstack -- 如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题.另外,jstack工具还可以附属到正在运行的java程序中,看到 当时运行的java程序的java stack和native stack的信息, 如果现在运行的java程序呈现hung的状态,jstack是非常有用的.目前只有在Solaris和Linux的JDK版本里面才有. jco

JVM监控工具用法指导

JVM监控工具用法指导 2010-09-27 15:39 dolphin-ygj javaeye.com 字号:T | T 通过JVM监控工具的使用可以及时发现问题,剔除安全隐患,这里向大家描述一下常用的几个JVM监控工具的用法,希望对你的学习有所帮助. AD:51CTO 网+首届APP创新评选大赛火热启动——超百万资源等你拿! 这里向大家描述一下JVM监控工具的用法,比如jstatd,启动jvm监控服务.它是一个基于rmi的应用,向远程机器提供本机jvm应用程序的信息.默认端口1099. JV

JVM监控工具--几种常用工具简介

JVM监控工具介绍 jdk中已提供了功能强大基于GUI界面的jvm监控工具,在jdk bin目录下可以看到,例如:jconsole.jvisualvm和oracle jrockit jvm's jrmc.exe 简介如下: GUI工具 支持类型 GUI本地运行版本(JRE) 被测JVM版本 jconsole jvm,jrockit jvm 1.5及以上 1.5及以上 jvisualvm jvm 1.5及以上 1.5及以上 jrmc jrockit jvm 1.4.2及以上 1.4.2及以上 1.

Java监控工具介绍,VisualVm ,JProfiler,Perfino,Yourkit,Perf4J,JProbe,Java微基准测试

本文是本人前一段时间做一个简单Java监控工具调研总结,主要包括VisualVm ,JProfiler,Perfino,Yourkit,Perf4J,JProbe,以及对Java微基准测试的简单介绍,总结下来比较推荐,Visualvm,Perfino,yourkit和Jprofiler(推荐值按顺序依次递减),其它工具不太推荐使用.下面是文章目录结构:  一.VisualVm  1.简介 2 2.安装插件并启动VisualVM 2 3.内存分析 3 4.CPU分析 5 5.线程分析 6 6.连接

Java线程及Jvm监控工具

Java线程状态 线程的五种状态 * 新建:new(时间很短) * 运行:runnable * 等待:waitting(无限期等待),timed waitting(限期等待) * 阻塞:blocked * 结束:terminated(时间很短) Jvm监控工具 一.jstack 介绍: jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息.如果是在64位机器上,需要指定选项"-J-d64",Windows的jstack使用方式只支持以下的这种

nmon性能监控工具介绍与部署指南

1.nmon简要介绍 nmon是IBM开发,对操作系统层的性能监控工具,有aix和linux两种版本 2.nmon下载地址 2.1.nmon for aix下载地址 https://www.ibm.com/developerworks/community/wikis/home?lang=en#!/wiki/Power%20Systems/page/nmon 2.2 .nmonfor linux下载地址 http://nmon.sourceforge.net/pmwiki.php?n=Site.D

Linux操作系统下Oracle主要监控工具介绍

Oracle监控包括有效且完全地监控Oracle数据库的性能.可用性和使用率等统计量,还包括即时的错误通知和纠正措施,并提供全面的报表和图表.本文中主要介绍几种Linux操作系统下Oracle主要监控工具. top top命令可实时地显示Linux系统的进程.CPU.内存.负载等的信息.它是我们了解系统整体状态最好的工具. top命令的运行状态是一个实时的显示过程,我们可在这个界面监控系统运行情况.我们可通过几个按键来控制top命令,如按q可退出top命令状态,按s可输入信息的更新频率等.这些命

Java之JVM监控工具分享

Java之JVM监控工具分享 JVM的基本知识常用的也就是类加载机制,内存区域.分配.OOM,GC,JVM参数调优 几个链接自己看: 内存区域&类加载机制 分配策略&垃圾回收算法.收集器 今天结合代码讲一讲常用的java自带工具讲解,这些命令一般都是jdk/lib/tools.jar中.用来监控诊断我们的Java环境. 官方说明: https://docs.oracle.com/en/java/javase/11/tools/ 1. jps 显示当前用户的所有java进程的PID 以及主类

jvm监控工具

jvm中除了集成式的VisualVM和jConsole外,还有jps.jstack.jmap.jhat.jstat等小巧的工具 开发中可能遇到的问题 OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争用(Lock Contention) Java进程消耗CPU过高 这些问题在日常开发中可能被很多人忽视(比如有的人遇到上面的问题只是重启服务器或者调大内存,而不会深究问题根源),但能够理解并解决这些问题是Java程序员进阶的必备要求.本文将对一些常用的JVM性能调优监控工具进行介绍