:::info ·JVisualVM既可以监控Tomcat进程,但是现在大多数都使用springboot,就直接写监控springboot吧 :::

Tomcat

Springboot jar

启动命令加上相关参数

  1. java -Djava.rmi.server.hostname=192.168.1.111 \
  2. -Xmx32M -Xms32M \
  3. -Dcom.sun.management.jmxremote \
  4. -Dcom.sun.management.jmxremote.port=1099 \
  5. -Dcom.sun.management.jmxremote.authenticate=false \
  6. -Dcom.sun.management.jmxremote.ssl=false \
  7. -server \
  8. -jar monitor-jvm-demo-0.0.1-SNAPSHOT.jar

添加JMX连接

image.pngimage.png

效果

image.png

Visual GC无法支持的问题

这样连接的我们发现VIsual GC无法使用
image.png

添加配置文件 jstatd.all.policy

  1. java: /data/java/jdk1.8.0_261/bin/java
  2. [root@localhost ~]# cd /data/java/jdk1.8.0_261/bin/
  3. [root@localhost bin]# vim jstatd.all.policy

jstatd.all.policy内容为

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

:::warning 注:若没有配置 JDK 环境变量,file 后面添加 tool.jar 的绝对路径 :::

启动

  1. ./jstatd \
  2. -J-Djava.security.policy=jstatd.all.policy \
  3. -J-Djava.rmi.server.hostname=192.168.1.111 \
  4. -p 3333 \
  5. -J-Djava.rmi.server.logCalls=true

参数说明:

  • -J-Djava.security.policy=jstatd.all.policy =号后面的是文件的绝对路径;
  • -J-Djava.rmi.server.logCalls=true 打开日志,如果客户端有连接过来的请求,可以监控到,便于排错;
  • -J-Djava.rmi.server.hostname=192.168.134.128 指明本机 hostname 对应的本机地址,确保该地址可以给客户机访问。因为有的服务器 hostname 对应的 ip 不一定是外网能连上的,最好在这里直接明确指定;
  • -p 3333 指定服务的端口号,默认是1099。也是可选参数。 :::info 注:后面两个参数可以省略 :::

    重新启动

    1. java -Djava.rmi.server.hostname=192.168.1.111 \
    2. -Xmx32M -Xms32M \
    3. -Dcom.sun.management.jmxremote \
    4. -Dcom.sun.management.jmxremote.port=1099 \
    5. -Dcom.sun.management.jmxremote.authenticate=false \
    6. -Dcom.sun.management.jmxremote.ssl=false \
    7. -server \
    8. -jar monitor-jvm-demo-0.0.1-SNAPSHOT.jar

    连接

    现在即可以查看VIsual GC内容了
    image.png