JVisualVM对内存线程的分析使用

来源:互联网 发布:没有网站怎么做seo 编辑:程序博客网 时间:2024/05/22 03:07

简介

JVisualVM是jdk自带的工具在jdk的安装目录的bin目录下,直接双击就能运行
这里写图片描述

点击运行后,能自动监视到 tomcat 、idea、eclipse等工具的进程
这里写图片描述

安装gc 线程插件
这里写图片描述

jvm内存模型一目了然
这里写图片描述

监测远程服务器

启动RMI服务

在需要被监控的服务器上面,通过jstatd来启动RMI服务
首先,配置java安全访问,在服务器jdk路径(/java_home/bin)下新建文件
名称: jstatd.all.policy
内容:

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

然后在进入jstatd.all.policy所在目录下,通过如下的命令启动RMI服务:

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

或者

./jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.hostname=192.168.22.11

修改服务器 hosts 文件中的 IP 地址

要使Java VisualVM 成功连接到远程服务器上,服务器端应该在 /etc/hosts 文件中把本机地址设为本机的 IP 地址。使用 hostname -i 命令查看,如果显示的是 127.0.0.1 或者与本机实际 IP 不一致的话,需要把 /etc/hosts 文件中相应的地址改为本机实际 IP 。

这里写图片描述

这里写图片描述
这里写图片描述

运行 jstatd 守护程序

由于 jstatd 需要保持一直运行,所以建议使用 screen 命令执行 jstatd 程序,命令如下:
Java代码 收藏代码

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

如果需要RMI 日志功能的话,还可以在启动参数中加入 -J-Djava.rmi.server.logCalls=true 。

screen jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.logCalls=true  

jstatd开始运行后,使用 CTRL+A+D 断开 screen 界面,回到 shell 界面。如果想切换回 jstatd 运行界面的话,使用 screen -r -d 命令即可。

监测远程tomcat

1、修改catalina.sh,在 tomcat 的 catalina.sh 中添加如下参数

JAVA_OPTS='-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 的端口号的,要确定这个端口没有被占用
2. -Dcom.sun.management.jmxremote.ssl=false 指定了 JMX 是否启用 ssl
3. -Dcom.sun.management.jmxremote.authenticate=false 指定了JMX 是否启用鉴权(需要用户名,密码鉴权)
2,3两个是固定配置,是 JMX 的远程服务权限的
4. -Djava.rmi.server.hostname :这个是配置 server 的 IP 的

最后可以监测到tomcat
这里写图片描述

0 0
原创粉丝点击