Jmeter和VisualVM

99 阅读2分钟

一、JVisualVM 简介

参考资料:www.cnblogs.com/xifengxiaom…

二、使用Java VisualVM监控远程JVM

参考资料:

www.cnblogs.com/kms1989/p/5…

www.jianshu.com/p/2a6658e94…

使用Java VisualVM监控远程JVM

我们经常需要对我们的开发的软件做各种测试, 软件对系统资源的使用情况更是不可少, 目前有多个监控工具, 相比JProfiler对系统资源尤其是内存的消耗是非常庞大,JDK1.6开始自带的VisualVM就是不错的监控工具.

这个工具就在JAVA_HOME\bin\目录下的jvisualvm.exe, 双击这个文件就能看到一个比较直观的界面

从左边Applications树中可以知道,不光可以监控本地JVM运行情况, 还可以监控远程机器上的JVM运行情况.

本地监控:只要打开某个JAVA程序就会自动的加入到本地监控中.

因为本地监控无需配置, 所以这里主要介绍监控远程JVM

要进行远程监控, 本机的VisualVM就必须和远程的JVM要进行通信, Visualvm目前支持两种remote connection方式.

分别是jstatd和JMX方式: 这里我主要介绍的是通过JMX方式.

通过JMX连接远程机器, 需要经过下面的配置:

  1. 修改远程机器JDK配置文件 (我这里远程机器是linux).

   a.进入JAVA_HOME\jre\lib\management\目录

   b.拷贝jmxremote.password.template这个文件到当前目录, 并改名为jmxremote.password

     c.打开jmxremote.password文件,去掉 # monitorRole  QED 和 # controlRole  R&D 这两行前面的注释符号

  1. 修改远程机器上需要被监控的程序的配置文件 (我这里是监控Tomcat容器内部署的应用).

   a.进入TOMCAT_HOME\bin目录

     b.打开catalina.sh文件,加入如下信息:

        JAVA_OPTS="$JAVA_OPTS -Djava.rmi.server.hostname=192.168.0.237

                                                     -Dcom.sun.management.jmxremote.port=18999

                                                     -Dcom.sun.management.jmxremote.ssl=false

                                                     -Dcom.sun.management.jmxremote.authenticate=false"

   c.重启Tomcat服务.

  1. 客户端VisualVM配置 (我客户端用的是WinXP).

     a.直接反键点击Remote,选择Add Remote Host...

     b.在弹出的界面中输入远程机器的IP地址(192.168.0.237),这个IP地址会加入到Remote节点下.

     c.反键点击这个IP地址,选择Add JMX Connection, 在弹出的界面中输入刚配置的端口号(18999), 这个连接会加入到该IP节点下.

     d.反键点击这个连接,选择Open.

此时就可以看到监控的界面, 从界面上我们可以看到CPU信息, 内存信息, 统计加载类数量,线程信息.

4、运行jar包的方式启动(推荐使用这种)

java -Djava.rmi.server.hostname=129.204.74.228 -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=1077 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -jar eureka-server-0.0.1-SNAPSHOT.jar > nohup.out 2>&1&

三、二种启动方式区别

参考方式:www.jianshu.com/p/2a6658e94…

JMX连接与JStatD连接方式的区别

  • JMX

    * 使用JMX需要远程JVM在启动的时候开启远程访问支持,设定JMX端口等,示例参数如下

java demo.Demo1 -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=10011 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false

    * 每一个JMX连接一个远程JVM

  • JStatD

    * 使用jstatd连接方式时,需要在远程主机上创建安全策略文件然后启动jstatd进程,并且此进程需要一直保持运行状态

    * 客户端可以看到远程主机上当前用户的所有JVM的信息,即只要创建一个jstatd连接

四、jstatd启动方式

1、创建文件jstatd.all.policy#

grant codebase "file:${java.home}/../lib/tools.jar" {   

    permission java.security.AllPermission;

};

2、启动jstatd后台应用

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

(我是在/usr/local/jdk1.8.0_161/bin路径下运行的下面的命令,该路径下就有jstatd.all.policy文件。如果是在其他地方执行,记得指定绝对或相对路径)

其中,

-J-Djava.security.policy=jstatd.all.policy 指定路径

-J-Djava.rmi.server.logCalls=true  打印日志

-J-Djava.rmi.server.hostname=192.168.19.114  指定主机名,主机名应该和你用hostname -i命令执行出来的结果一致。

3、如需要修改端口(默认为1099)

jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.hostname=192.168.19.114 -J-Djava.rmi.server.logCalls=true -J-Djava.net.preferIPv4Stack=true -p 5555

其中:

-p 5555 ----------修改端口为5555

4、启动效果

[root@pas bin]# jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.hostname=192.168.19.114 -J-Djava.rmi.server.logCalls=true

Jun 27, 2018 4:20:03 PM sun.rmi.server.UnicastServerRef logCall

FINER: RMI TCP Connection(1)-192.168.19.114: [192.168.19.114: sun.rmi.registry.RegistryImpl[0:0:0, 0]: void rebind(java.lang.String, java.rmi.Remote)]

Jun 27, 2018 4:20:03 PM sun.rmi.server.UnicastServerRef logCall

FINER: RMI TCP Connection(2)-192.168.19.114: [192.168.19.114: sun.rmi.transport.DGCImpl[0:0:0, 2]: java.rmi.dgc.Lease dirty(java.rmi.server.ObjID[], long, java.rmi.dgc.Lease)]