Java Mission Control (一):远程监控

JMC 是在 JAVA 7u40 发布中加入的性能监控工具。使用过 JDK 6 中 JRockit JVM 的用户并不会陌生,因为它是 Java 7 中 JMC 功能的一部分。启动 JMC 后将会显示当前机器中的所运行的 JVM 进程信息,当然我们也可以选择添加更多的 JVM 进程进行监控。

jmc.png

图 中展示了使用 JMC 监控 GlassFish 应用服务器的画面。图中展示了被监控程序的基本信息,其包括 CPU 使用率和内存堆的使用率,值得注意的是,JMC 监控图中显示的是当前机器的 CPU 的使用情况,可以看到的是 JMC 监控的是整个系统,而并非只是被选中的 JVM 对 CPU 的使用情况。通过自定义设置上方仪表盘中显示的信息,既可以查看 被监控 JVM 的详细信息,例如垃圾回收,类的加载,线程的使用,以及内存堆的使用率,等等。也可以查看指定操作系统信息,例如系统的 CPU 和内存的使用率,磁盘的交换信息,平均负载等相关信息。

1.准备阶段

远程服务器IP

  • 检查服务器
    $ hostname -i
    
    如果匹配的结果无法识别或者是127.0.0.1,需要手动配置主机名和IP 映射。
    $ 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
       
    
  • 防火墙开放设定的端口号

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

  • 下载地址
    catalina-jmx-remote.jar

  • 复制到tomcat/lib目录下

3.配置jstatd

3.1 配置安全策略

  • 编辑$JAVA_HOME/jre/lib/security/java.policy
    添加permission java.security.AllPermission
    grant codeBase "file:${{java.ext.dirs}}/*" {
          permission java.security.AllPermission;
    };
    
  • 防火墙开放设定的端口号

4. JMC连接

4.1 JMC连接

  • 新建连接


    创建连接.png

4.2 开启JFR (Java Flight Recorder)

  • 编辑 jxmremote.access,修改controRole账号权限
    create  com.sun.management.*,com.oracle.jrockit.*      
    
  • 启动飞行器


    飞行器.png

总结

使用jmc和jfr可以对程序进行更加详细的全面的监控,对于性能优化和性能测试有着非常大的帮助,下一节会继续介绍jfr的详细使用方式。
本文参考:
[1]. 使用VisualVM监控远程服务器JVM
[2]. Java 性能分析工具

你可能感兴趣的:(Java Mission Control (一):远程监控)