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,因此局限性很大,还是应该使用本地的方式比较稳妥

  • 相关阅读:
    数据库优化方案之分库分表
    聊聊ThreadLocal源码(基于JDK1.8)
    HashMap扩容死循环问题
    Synchronized偏向锁和轻量级锁的升级
    【Java并发编程之深入理解】Synchronized的使用
    ConcurrentHashMap 1.8为什么要使用CAS+Synchronized取代Segment+ReentrantLock
    面试必备技能:HashMap哪些技术点会被经常问到?
    序列键生成器及单例多例模式
    Effective.Java第1-11条
    抽象工厂(AbstractFactory)模式
  • 原文地址:https://www.cnblogs.com/liugh/p/7620336.html
Copyright © 2011-2022 走看看