VisualVM监控java应用内存状态

使用JAVA VisualVM 来监控应用

VisualVM连接远程服务器有两种方式:JMX和jstatd,两种方式都不能完美支持所有功能,例如JMX不支持VisualGC,jstatd不支持CPU监控,实际使用可同时配置上并按需选用。
jdk下可以使用jre不行,而且只支持1.5以上的jdk版本。
- jstatd模式连接
- JMX方式连接
- 关于内存区域OOM


一. jstatd启动方法:

首先在目标远程主机上添加jstatd.all.policy文件。
文件内容

grant codebase "file:${java.home}/../lib/tools.jar" {
    permission java.security.AllPermission;
};

然后执行命令,启动jstatd:

jstatd -J-Djava.security.policy=jstatd.all.policy

如果是linux环境注意机器ip配置
使用 hostname -i 命令查看,如果显示的是 127.0.0.1 或者与本机实际 IP 不一致的话,需要把 /etc/hosts 的地址改为本机实际 IP 。

启动之后若jvisualvm连接不上,可以使用:

jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.hostname=IP地址

一. JMX配置:

jmx的权限文件通常在 /usr/lib/jvm/java-1.8.0-openjdk-版本号/jre/lib/management/

jmxremote.password 及 jmxremote.access 两个文件,一个用于记录账号密码,一个用于设置权限

jmxremote.password 文件默认没有,复制jmxremote.password.template文件即可,最下面这两行反注释掉即可启用

# monitorRole  QED
# controlRole   R&D

账号为monitorRole,密码为QED,注意:jmxremote.password权限需为600

权限级别观察jmxremote.access文件底部。

java的启动语句里添加
-Dcom.sun.management.jmxremote.port=3000 \
-Dcom.sun.management.jmxremote.authenticate=true \
-Dcom.sun.management.jmxremote.ssl=false \

-Dcom.sun.management.jmxremote.port=3000 \
-Dcom.sun.management.jmxremote.authenticate=true \
-Dcom.sun.management.jmxremote.ssl=false \

即可启动jmx监听3000端口。

tomcat的catalina.sh添加配置:

JAVA_OPTS='-Djava.rmi.server.hostname=192.168.0.237
           -Dcom.sun.management.jmxremote.port=8999   
           -Dcom.sun.management.jmxremote.ssl=false 
          -Dcom.sun.management.jmxremote.authenticate=false'   

注:1. -Dcom.sun.management.jmxremote.port :这个是配置远程 connection 的端口号的,要确定这个端口没有被占用

  1. -Dcom.sun.management.jmxremote.ssl=false 指定了 JMX 是否启用 ssl

  2. -Dcom.sun.management.jmxremote.authenticate=false 指定了JMX 是否启用鉴权(需要用户名,密码鉴权)

    2,3两个是固定配置,是 JMX 的远程服务权限的

  3. -Djava.rmi.server.hostname :这个是配置 server 的 IP 的

.进入JAVA_HOME\jre\lib\management\目录
b.拷贝jmxremote.password.template这个文件到当前目录, 并改名为jmxremote.password
c.打开jmxremote.password文件,去掉 # monitorRole QED 和 # controlRole R&D 这两行前面的注释符号

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值