zoukankan      html  css  js  c++  java
  • Java VisualVM远程监控JVM——转

    原文地址:http://ihuangweiwei.iteye.com/blog/1219302

    1. 测试环境

    Ubuntu Server 10.01

     

    2.  在服务器上安装 jstatd 组件

    使用apt-get 命令安装 openjdk 即可 :

    Java代码 复制代码 收藏代码
    1. sudo apt-get install openjdk-6-jdk  
    sudo apt-get install openjdk-6-jdk

    3. 在服务器上配置 jstatd security policy 文件

     

       jstatd是一个监控 JVM 从创建到销毁过程中资源占用情况并提供远程监控接口的 RMI Remote Method Invocation ,远程方法调用)服务器程序,它是一个 Daemon 程序,要保证远程监控软件连接到本地的话需要 jstatd 始终保持运行。 

       jstatd运行需要通过 -J-Djava.security.policy=*** 指定安全策略,因此我们需要在服务器上建立一个指定安全策略的文件 jstatd.all.policy ,文件内容如下:

     

    grant codebase "file:${java.home}/../lib/tools.jar" {
       permission java.security.AllPermission;
    };
    4. 修改服务器 hosts 文件中的 IP 地址

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

     

    5. 运行 jstatd 守护程序

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

    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 命令即可。

     

    6. 通过Java VisualVM 连接到服务器监控 Java 程序

       在Java VisualVM 程序窗口左侧 远程 项目右键选择 添加远程主机 ,在弹出的对话框中输入远程主机的 IP 地址,确认提交后即可看到相应的远程主机和在上面运行的 Java 程序,连接成功后应该会显示 Jstatd 及其 PID

     

     

     

     

      通过以上方式连接服务器发现一个问题,不能监控CPU 。提示我们建立 JMX ,建立 JMX 提示要求端口号。( JMX Java Management Extensions ,即 Java 管理扩展 , 是一个为应用程序、设备、系统等植入管理功能的框架。 JMX 可以跨越一系列异构操作系统平台、系统体系结构和 网络传输协议,灵活的开发无缝集成的系统、网络和服务管理应用 。而 Visual VM是通过 JMX 来和远程 Java 应用联系的 )。

     

     

    7. T omcat中配置

      下面我们为54 服务器的 tomcat 配置 jvm 启动参数。 tomcat catalina.sh 中添加如下参数:

    JAVA_OPTS='-Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false' 
     或:
    JAVA_OPTS=’-Dcom.sun.management.jmxremote.port=1099 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=192.168.1.54  其他配置’
     

     

     

    注: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

     

    连接成功,现在我们可以远程监控服务器性能,可以配合 jmeter 进行了一个长时间的加压,在加压过程中重点关注了系统资源的使用情况

     

    三.参考博客

    http://mahuihuang.blog.163.com/blog/static/745292520113202321494/

     

    http://wolfdream.iteye.com/blog/1032712

    http://sjsky.iteye.com/blog/705323

  • 相关阅读:
    3星|《全球电商进化史》:全球电商亲历记
    2星|陈春花《共生》:逻辑差语文差缺证据。不敢相信知名商学院教授的书居然这么差
    3星|《第五次开始》:考古学家写的人类简史与未来简史
    4星|《财经》2018年第21期:互联网处方能解决药品质量和价格问题
    2.5星|托夫勒《权力的转移》;30年旧书,现在看理论有点牵强肤浅,预测有的准有的不准
    2018左其盛好书榜(截至9月15日)
    沟通交流技巧相关的11本书点评
    没睡好觉的上级更容易辱骂下属:3.5星|《哈佛商业评论》第9期
    3星|《利润模式》:20年旧书,30种模式
    在 C# 中通过 P/Invoke 调用Win32 DLL
  • 原文地址:https://www.cnblogs.com/wangchy0927/p/2827490.html
Copyright © 2011-2022 走看看