jvisualvm 連接 jstatd 遠程監控 jvm 或 Visual GC提示"不受此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。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM