JAVA诊断监控工具

原创 2016年05月30日 14:46:53

jvisualvm功能:监控内存泄露,跟踪垃圾回收,运行时内存分析,线程分析...

jvm使用:jvisualvm已经被集成在jdk1.6以上的版本中(不是jre),正常安装完jdk后,至jdk的bin目录下,运行jvisualvm.exe即可



jvisualvm概述:Local标签下的第一个VisualVM为本机的eclipse监控,第二个为jvisualvm对自身的监控



监控类型:Overview,Monitor,Threads和一个Sampler。

1.Overview(jvm启动参数,系统参数)



2.Monitor


左上:cpu利用率,gc状态的监控

右上:堆利用率,永久内存区的利用率(JDK7以前叫PermGen,JDK8移除PermGen,类数据存在Metaspace)

左下:类的监控

右下:线程的监控

performGC:gc的详细运行状态

HeapDump:堆的详细状态(可以看到堆的概况,里面所有的类,还能点进具体的一个类查看这个类的状态)



3.Threads


能够显示线程的名称和运行的状态,在调试多线程时必不可少,而且可以点进一个线程查看这个线程的详细运行情况


监控服务器上的java程序

相较于监控tomcat要麻烦很多,要预先启动jstatd服务(${java_home}/bin目录下)

jstatd是一个监控JVM从创建到销毁过程中资源占用情况并提供远程监控接口的RMI(Remote Method Invocation,远程方法调用)服务器程序,它是一个Daemon程序(后台进程),要保证远程监控软件连接到本地的话需要jstatd始终保持运行。

jstatd运行需要通过-J-Djava.security.policy=***指定安全策略,因此我们需要在服务器上建立一个指定安全策略的文件jstatd.all.policy(我放在了${java_home}/bin目录下),文件内容如下:

[plain] view plain copy
  1. grant codebase "file:/home/123/123/jdk1.5.0_15/lib/tools.jar" {   
  2.     permission java.security.AllPermission;   
  3. };   

然后使用这个策略文件启动jstatd服务

[plain] view plain copy
  1. [123@123 bin]$ pwd  
  2. /home/123/123/jdk1.5.0_15/bin  
  3. [123@123 bin]$ ./jstatd -J-Djava.security.policy=./jstatd.all.policy &  

因为监控的过程中需要jstatd服务一直运行,所以加上了&,如果需要日志也可使用:

[plain] view plain copy
  1. ./jstatd -J-Djava.security.policy=./jstatd.all.policy -J-Djava.rmi.server.logCalls=true  

接下来就可以在jvisualvm中配置监控该服务器上运行的java程序了,和在jvisualvm中配置监控tomcat服务器的操作过程是一样的

需要特别注意的是,有时在配置远程监控java程序的时候jvisualvm会报一个错误

点击查看错误详情:

 connection refused to host:127.0.0.1初步判断和主机名有关系

[plain] view plain copy
  1. [123@123 bin]# hostname -i  
  2. 127.0.0.1  
[plain] view plain copy
  1. [123@123 bin]# hostname 192.168.58.168  

修改完重启jstatd服务(网上很多人说要修改主机的/etc/hosts文件,但是我自己测试修改/etc/hosts文件是没有效果的,必须要修改主机名

填写主机名:


这里要选添加一个jstatd连接:

直接选择默认配置即可(默认使用1099端口):

点击ok后,168上的所有java程序就会自动列出:


PS:

jvisualvm也是可以安装插件的,具体步骤为tool -> plugin ->aviable plugin,推荐一个非常好用的插件VisualGC

安装完这个插件后,将会增加新的监控条目Visual GC,可以看到虚拟机内存各个区的使用情况





相关文章推荐

java监控工具

  • 2016年06月23日 08:52
  • 14.85MB
  • 下载

Java内存泄露_JVM监控工具介绍

  • 2013年03月20日 01:48
  • 1.49MB
  • 下载

Java 自带性能监控工具:监视和管理控制台 jconsole 的使用

想验证你对 jvm 配的一些调优参数有没有起作用吗?想不想实时监控你自定义的线程池的在实际运行时的线程个数、有没有死锁?想不想实时监控你的 Java 应用的堆内存使用情况,并根据峰值等数据设置最适合你...
  • defonds
  • defonds
  • 2015年04月15日 20:45
  • 20587

JAVA JVM性能调优监控工具详解

  • 2017年04月18日 15:06
  • 232KB
  • 下载

java内存监控工具jvisualvm

  • 2014年05月06日 15:38
  • 46KB
  • 下载

Java内存泄露_JVM监控工具介绍jstack_jconsole_jinfo_jmap_jdb_jstat

jstack -- 如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程...
  • WQ560
  • WQ560
  • 2012年05月22日 09:16
  • 740

Java虚拟机学习 - JDK可视化监控工具

1.JConsole JConsole工具在JDK/bin目录下,启动JConsole后,将自动搜索本机运行的jvm进程,不需要jps命令来查询指定。双击其中一个jvm进程即可开始监控,也可使用...

java可视化监控工具

1.JConsole  JConsole工具在JDK/bin目录下,启动JConsole后,将自动搜索本机运行的jvm进程,不需要jps命令来查询指定。双击其中一个jvm进程即可开始监控,也...

Java监控工具、调优、调试辅助函数

JVM监控工具 Java的安装包自带了很多优秀的工具,善用这些工具对于监控和调试Java程序非常有帮助。常用工具如下: jps  用途:jps用来查看JVM里面所有进程的具体状态, 包括进程ID...
  • boonya
  • boonya
  • 2016年01月15日 16:49
  • 586

Java虚拟机 - JDK可视化监控工具

 1.JConsole  JConsole工具在JDK/bin目录下,启动JConsole后,将自动搜索本机运行的jvm进程,不需要jps命令来查询指定。双击其中一个jvm进程即可开始监控...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JAVA诊断监控工具
举报原因:
原因补充:

(最多只允许输入30个字)