visualvm远程jvm监控方法

最近新上线的Java服务上线一段时间后性能严重下降,希望通过压测排查出问题原因,顺便研究了一下利用JDK自带的visualvm工具监控JVM的运行状况,进行问题排查

通过jstatd启动RMI服务

配置java安全访问,将如下的代码存为文件 jstatd.all.policy,放到JAVA_HOME/bin中,其内容如下:

    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.8 &

(192.168.1.8 为你服务器的ip地址,&表示用守护线程的方式运行)

jstatd命令详解 :http://hzl7652.iteye.com/blog/1183182

配置开启JMX

采用jstatd启动RMI服务这种方式时,visualvm并不能监控到CPU信息,如果想要监控到CPU则需开启JMX。开启JMX的方法很

set JAVA_OPTS=-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=9008 -Dcom.sun.management.jmxremote.authenticate=false -    Dcom.sun.management.jmxremote.ssl=false

需要用户名和密码访问:

    JAVA_OPTS='-Xms128m -Xmx256m -XX:MaxPermSize=128m
    -Djava.rmi.server.hostname=192.168.1.8
    -Dcom.sun.management.jmxremote.port=8088
    -Dcom.sun.management.jmxremote.ssl=false
    -Dcom.sun.management.jmxremote.authenticate=true
    -Dcom.sun.management.jmxremote.password.file=/usr/java/default/jre/lib/management/jmxremote.password
    -Dcom.sun.management.jmxremote.access.file=/usr/java/default/jre/lib/management/jmxremote.access'
      (jmxremote.access 在JAVA_HOME\jre\lib\management下有模板)
     jmxremote.access 中显示
     monitorRole   readonly
     controlRole   readwrite

    jmxremote.password中显示
    monitorRole  QED            (QED为密码)
    controlRole   R&D
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值