zoukankan      html  css  js  c++  java
  • 使用jvisualvm的jstatd方式远程监控Java程序

      使用Java自带的jvisualvm调试Java程序,可以查看CPU、内存、类及线程等信息,还可以进行Dump,无疑是一个利器

      由于客户端是Windows、服务端是Linux,并且是最小安装的Linux,没有图形界面,因此需要进行远程调试

    一、客户端:Windows

        打开%JAVA_HOME%/bin/jvisualvm.exe,在“远程”节点,右键,“添加远程主机”,如下所示:

    输入主机IP地址,修改显示名,点击确定,如下所示:

    二、服务端:Linux

      在$JAVA_HOME/bin/下新建策略文件:

    [teld@T-SHA1-FLK-01 bin]$ touch jstatd.all.policy
    [teld@T-SHA1-FLK-01 bin]$ vi jstatd.all.policy 

     输入如下内容:

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

    启动jstatd:

    [teld@T-SHA1-FLK-01 bin]$./jstatd -J-Djava.security.policy=./jstatd.all.policy

    这时在客户端即可看到服务端上运行的所有Java程序了,如下所示:

    双击某一个Java程序节点,可以看具体的CPU、内存、类及线程信息

    三、遇到的坑

      3.1 插件安装

       jvisualvm可以安装插件,但是使用时,发现默认的插件提供网站已经不能用了:

      通过浏览器直接访问,发现网站已经不能用了:

    http://www.oracle.com/splash/java.net/maintenance/index.html

       新地址已经迁移到github:

    https://visualvm.github.io/pluginscenters.html

      根据版本下载对应的插件到本地,然后通过本地安装即可,以安装Visual GC为例,如下所示:

    安装完后,可以发现多了一个Visual GC的Tab页:

      可以很直观的观察JVM里的内存分配

     3.2 CPU查看、抓取Dump

       使用这种远程的方式,没法查看CPU、没法抓取Dump,因此局限性很大,还是应该使用本地的方式比较稳妥

  • 相关阅读:
    supermall遇到的问题
    github建立仓库
    【Teradata】9794 ERRAMPOUTOFPHYSPACE error解决方法
    MPP大规模并行计算数据库与分布式数据库的区别
    【English】20190515
    商业数据分析的四个层次
    学会学习(Learning how to learn)
    【English】20190513
    【Teradata】DEL语句产生的锁
    【Teradata】开启LockLogger与dumplocklog工具使用(含lokdisp工具说明)
  • 原文地址:https://www.cnblogs.com/liugh/p/7620336.html
Copyright © 2011-2022 走看看