博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java VisualVM远程监控JVM
阅读量:6342 次
发布时间:2019-06-22

本文共 2266 字,大约阅读时间需要 7 分钟。

   VisualVM是一个以监控、显示本地或者远程服务器JVM工作情况,进行性能调优的工具。借助VisualVM,我们可以实现对JVM内存各个子池、CPU、垃圾收集器等方面进行监控,从而发现程序代码中潜在的泄露点和配置问题。

远程监控Linux JVM有两种连接方式:

CentOS6.5安装:yum install java-1.8.0-openjdk java-1.8.0-openjdk-devel

Ubuntu12.04安装:sudo apt-get install java-7-openjdk

方式1:通过Jstatd启动RMI服务

1.开启远程监控访问,将下面注释去掉,Ubuntu和CentOS JAVA安装路径不同,其他配置基本一样。

 Ubuntu:

1
2
3
# vi /etc/java-7-openjdk/management/jmxremote.password 
monitorRole  QED      
controlRole   R&D

 CentOS:

1
2
3
4
5
6
# cd /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.31-1.b13.el6_6.x86_64/jre/lib/management/
# cp jmxremote.password.template jmxremote.password
# chmod 644 jmxremote.password
# vi jmxremote.password
monitorRole  QED      
controlRole   R&D

2.jstatd以守护进程启动

1
2
3
4
5
6
7
8
9
# jstatd -J-Djava.rmi.server.hostname=192.168.1.156 &
# Could not create remote object
access denied (
"java.util.PropertyPermission" 
"java.rmi.server.ignoreSubClasses" 
"write"
)
java.security.AccessControlException: access denied (
"java.util.PropertyPermission" 
"java.rmi.server.ignoreSubClasses" 
"write"
)
        
at java.security.AccessControlContext.checkPermission(AccessControlContext.java:372)
        
at java.security.AccessController.checkPermission(AccessController.java:559)
        
at java.lang.SecurityManager.checkPermission(SecurityManager.java:549)
        
at java.lang.System.setProperty(System.java:783)
        
at sun.tools.jstatd.Jstatd.main(Jstatd.java:139)

出现错误,说没有权限,于是百度一下,找到解决办法,就可以正常启动了,如下:

1
2
3
4
5
6
# cd /tmp
# vi jstatd.all.policy
grant codebase 
"file:${java.home}/../lib/tools.jar" 
   
permission java.security.AllPermission; 
};
# jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.hostname=192.168.1.156 &

打开JVisualVM工具(默认端口1099)-->添加远程主机-->双机主机IP,即可监控

CPU图形没有显示,不受此JVM支持,目前还没找到原因,有知道的博友,还请告知下,谢谢!

方式2:JMX方式监控应用程序,我们以Tomcat为例(常用)

1
2
3
4
5
6
7
8
9
10
# cd /root/apache-tomcat-8.0.17/bin
# vi catalina.sh   #找到JAVA_OPTS,在下面添加,添加的位置并没要要求
#JAVA_OPTS="$JAVA_OPTS -Dorg.apache.catalina.security.SecurityListener.UMASK=`umask`"
JAVA_OPTS="$JAVA_OPTS-Dcom.sun.management.jmxremote 
        
-Dcom.sun.management.jmxremote.port=9999 
        
-Dcom.sun.management.jmxremote.authenticate=
false 
        
-Dcom.sun.management.jmxremote.ssl=
false 
        
-Djava.rmi.server.
hostname
=192.168.1.156"
# ./startup.sh 
# netstat -antp |grep 9999    #查看端口是否监听

打开JVisualVM工具-->添加远程主机-->在远程主机添加JMX连接-->补全端口,确认即可

转载地址:http://rdyla.baihongyu.com/

你可能感兴趣的文章
SpringMVC 拦截器 筛选
查看>>
CronExpression介绍
查看>>
第十八章:MVVM(八)
查看>>
点击表头切换升降序排序方式
查看>>
“Fintech加持下,传统信贷发生革命性变化,但难说已经成功”
查看>>
Coding and Paper Letter(三十二)
查看>>
第26天,Django之include本质
查看>>
Java中静态变量和实例变量的区别
查看>>
秋名山老司机(详解)——bugku
查看>>
RED | Robot Framework集成开发环境
查看>>
Oracle 和SQL Server 中的SQL语句使用区别
查看>>
JS 中 this 关键字详解
查看>>
有关css栅格系统的故事
查看>>
kubernetes 0.18.1 安装 & 部署 & 初试
查看>>
ubuntu10.0.4 virtualenv 创建虚拟Python环境
查看>>
【七牛弯区课堂】Ruby服务间通信模式
查看>>
Rust基础笔记之浅谈Ownership
查看>>
怎么让你的代码更Pythonic?光有技巧可不行,你还需要看这些……
查看>>
springboot+jjwt+security完美解决restful接口无状态鉴权
查看>>
小记 小狗与北京
查看>>