JMC 是在 JAVA 7u40 发布中加入的性能监控工具。使用过 JDK 6 中 JRockit JVM 的用户并不会陌生,因为它是 Java 7 中 JMC 功能的一部分。启动 JMC 后将会显示当前机器中的所运行的 JVM 进程信息,当然我们也可以选择添加更多的 JVM 进程进行监控。
图 中展示了使用 JMC 监控 GlassFish 应用服务器的画面。图中展示了被监控程序的基本信息,其包括 CPU 使用率和内存堆的使用率,值得注意的是,JMC 监控图中显示的是当前机器的 CPU 的使用情况,可以看到的是 JMC 监控的是整个系统,而并非只是被选中的 JVM 对 CPU 的使用情况。通过自定义设置上方仪表盘中显示的信息,既可以查看 被监控 JVM 的详细信息,例如垃圾回收,类的加载,线程的使用,以及内存堆的使用率,等等。也可以查看指定操作系统信息,例如系统的 CPU 和内存的使用率,磁盘的交换信息,平均负载等相关信息。
1.准备阶段
远程服务器IP
- 检查服务器
如果匹配的结果无法识别或者是127.0.0.1,需要手动配置主机名和IP 映射。$ hostname -i
$ vi /etc/host 添加一行 192.168.120.161 mylinux
2.配置JMX
2.1 添加JVM初始化启动参数
- 编辑catalina.sh
CATALINA_OPTS="-Djava.rmi.server.hostname=192.168.200.136 -Dcom.sun.management.jmxremote.port=18888 -Dcom.sun.management.jmxremote=true -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.managementote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false"
2.2 在server.xml中添加listener
- 编辑server.xml
<Listener className="org.apache.catalina.mbeans.JmxRemoteLifecycleListener" rmiRegistryPortPlatform="10001" rmiServerPortPlatform="10002" />
- 防火墙开放设定的端口号
2.3 JMX访问控制文件
- 复制文件到tomcat/conf目录下
cp $JAVA_HOME/jre/lib/management/jmxremote.password.template jmxremote.passwordcp $JAVA_HOME/jre/lib/management/jmxremote.access jmxremote.access
- 编辑jmxremote.password,取消下两行注释
#monitorRole QED #controlRole R&D
- 修改权限
chmod 600 jmxremote.password chmod 600 jxmremote.access
2.4 添加catalina-jmx-remote.jar
复制到tomcat/lib目录下
3.配置jstatd
3.1 配置安全策略
- 编辑$JAVA_HOME/jre/lib/security/java.policy
添加permission java.security.AllPermissiongrant codeBase "file:${{java.ext.dirs}}/*" { permission java.security.AllPermission; };
- 防火墙开放设定的端口号
4. JMC连接
4.1 JMC连接
-
新建连接
4.2 开启JFR (Java Flight Recorder)
- 编辑 jxmremote.access,修改controRole账号权限
create com.sun.management.*,com.oracle.jrockit.*
-
启动飞行器
总结
使用jmc和jfr可以对程序进行更加详细的全面的监控,对于性能优化和性能测试有着非常大的帮助,下一节会继续介绍jfr的详细使用方式。
本文参考:
[1]. 使用VisualVM监控远程服务器JVM
[2]. Java 性能分析工具