欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

jvisualvm 连接 jstatd 远程监控 jvm 或 Visual GC提示"不受此JVM支持“

程序员文章站 2023-03-31 22:25:17
Visual GC提示"不受此JVM支持“,可以使用此方法解决。 一、添加配置文件 jstatd.all.policy 注:若没有配置 JDK 环境变量,file 后面添加 tool.jar 的绝对路径 二、启动 jvisualvm 下执行以下命令(前台)启动,也可以后台启动命令,默认监听 1099 ......

visual gc提示"不受此jvm支持“,可以使用此方法解决。

jvisualvm 连接 jstatd 远程监控 jvm 或 Visual GC提示"不受此JVM支持“


一、添加配置文件 jstatd.all.policy


[root@localhost /]# cd /usr/local/src/jdk1.8.0_131/bin/
[root@localhost bin]# vim jstatd.all.policy

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

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

二、启动 jvisualvm


$java_home/bin下执行以下命令(前台)启动,也可以后台启动命令,默认监听 1099 端口。

[root@localhost bin]# ./jstatd -j-djava.security.policy=jstatd.all.policy -j-djava.rmi.server.hostname=192.168.134.128 -p 3333 -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。也是可选参数。

注意:后面两个参数可以省略

三、使用 lsof -i:3333 查看端口是否正常被监听


[root@localhost bin]# lsof -i:3333
command   pid user   fd   type device size/off node name
jstatd  22376 root   14u  ipv6  78014      0t0  tcp *:dec-notes (listen)
jstatd  22376 root   15u  ipv6  78015      0t0  tcp localhost:53042->localhost:dec-notes (established)
jstatd  22376 root   16u  ipv6  78016      0t0  tcp localhost:dec-notes->localhost:53042 (established)
jstatd  22376 root   21u  ipv6  78020      0t0  tcp localhost.localdomain:dec-notes->192.168.134.1:53733 (established)

四、使用 visualvm 连接


jvisualvm 添加 ip 为192.168.134.128 端口为 3333 的远程机器,这样可以使用 jstatd 方式远程监控 jvm。

jvisualvm 连接 jstatd 远程监控 jvm 或 Visual GC提示"不受此JVM支持“

jvisualvm 连接 jstatd 远程监控 jvm 或 Visual GC提示"不受此JVM支持“