资讯专栏INFORMATION COLUMN

使用JDK自带的jmap和jhat监控处于运行状态的Java进程

joyqi / 640人阅读

摘要:对于处于运行状态中的进程,自带了很多工具,允许开发人员监控运行进程中的各种状态,比如该进程内部创建了多少个对象实例,消耗了多少内存,等等。下面介绍如何使用和监控这个运行进程。我是直接用自带的任务管理器获得进程的。

对于处于运行状态中的Java进程,JDK自带了很多工具,允许Java开发人员监控运行进程中的各种状态,比如该进程内部创建了多少个对象实例,消耗了多少内存,等等。

本文基于JDK1.8而写成。

我下面写了一个最简单的Java类,包含了一个无限循环,每隔5秒增加一个计数器的值。

package jmap;
class Tool{
    private int count = 0;
    public void Run() throws InterruptedException{
        while(true){
            System.out.println("Hello: " + this.count++);
            Thread.sleep(5000);
        }
    }
}
public class JMapTest {
    public static void main(String[] args) throws InterruptedException {
        Tool tool = new Tool();
        tool.Run();
    }
}

在Eclipse里执行这个应用。

下面介绍如何使用jmap和jhat监控这个运行进程。

1. 首先取得这个Java运行进程的ID:15392。我是直接用Windows自带的任务管理器获得进程ID的。

2. 使用如下命令行:

jmap -dump:format=b,file=c:tempheapstatus.bin 15392

jmap是JDK提供的工具,位于JDK安装目录的bin文件夹下。

执行命令行,会产生一个heap dump文件: headstatus.bin

3. 现在可以用另一个JDK工具,jhat来读取这个dump文件并解析。使用命令行:

jhat c:tempheapstatus.bin

解析完毕后,jhat打印出的输出提示我们Snapshot resolved,可以从本地服务器的7000端口来查看。

访问http://localhost:7000,能看到jmap解析结果。

localhost:7000 in browser:

点击超链接“jmap Tool”进入明细:下图意思是我的Tool类的实例@0x7166babd8的成员变量,即计数器的值已经累加到49了。

4. 如果大家不喜欢命令行,也可以用一个Eclipse的插件,MAT – Memory Analyzer Tool,也能完成和jmap与jhat命令同样的功能。

这个插件安装后,在Eclipse里会多出一个视图:

直接将jmap生成的heap dump文件拖到MAT视图里,就能自动解析并显示结果了。

点按钮“Find object by address”:

同样能够看到之前在localhost:7000里看到的对象实例的明细:

You can get the same result as you get previously in

要获取更多Jerry的原创技术文章,请关注公众号"汪子熙"或者扫描下面二维码:

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/71815.html

相关文章

  • JVM详解3.JDK监控故障处理工具

    摘要:点击进入我的博客命令行工具这些工具大多数是类库的一层薄的包装,它们的主要功能代码是在类库中实现的。可视化工具是到目前为止随发布的功能最强大的运行监视和故障处理程序,并且可以预见在未来一段时间内都是官方主力发展的虚拟机故障处理工具。 点击进入我的博客 3.1 JDK命令行工具 showImg(https://segmentfault.com/img/remote/14600000174...

    Keven 评论0 收藏0
  • 深入理解虚拟机之虚拟机性能监控故障处理工具

    摘要:监控和故障处理工具显示指定系统内所有的虚拟机进程用于收集虚拟机各方面的运行数据。的常用功能选项测试上面输出了我正在运行程序的包名下的类名虚拟机统计信息监视工具使用于监视虚拟机各种运行状态信息的命令行工具。 《深入理解Java虚拟机:JVM高级特性与最佳实践(第二版》读书笔记与常见面试题总结 本节常见面试题(推荐带着问题阅读,问题答案在文中都有提到): JVM调优的常见命令行工具有哪些?...

    jas0n 评论0 收藏0
  • jvm调优-命令篇

    摘要:打印等待回收对象的信息可以看到当前队列中并没有等待线程执行方法的对象。一般情况,会到客户端用工具来分析用于生成虚拟机当前时刻的线程快照。 运用jvm自带的命令可以方便的在生产监控和打印堆栈的日志信息帮忙我们来定位问题!虽然jvm调优成熟的工具已经有很多:jconsole、大名鼎鼎的VisualVM,IBM的Memory Analyzer等等,但是在生产环境出现问题的时候,一方面工具的使...

    Lsnsh 评论0 收藏0
  • 《深入理解Java虚拟机》(四)虚拟机性能监控与故障处理工具

    摘要:虚拟机性能监控与故障处理工具详解概述本文参考的是周志明的深入理解虚拟机第四章,为了整理思路,简单记录一下,方便后期查阅。虚拟机堆转储快照分析工具功能用于分析生成的。 虚拟机性能监控与故障处理工具 详解 4.1 概述 本文参考的是周志明的 《深入理解Java虚拟机》 第四章 ,为了整理思路,简单记录一下,方便后期查阅。 JDK本身提供了很多方便的JVM性能调优监控工具,除了集成式的Vis...

    gself 评论0 收藏0
  • java虚拟机故障处理工具

    摘要:这些工具包括名称主要作用显示指定系统内所有的虚拟机进程。虚拟机堆转存快照分析工具命令用于与搭配使用,用来分析生成的文件。命令格式命令样例线程堆栈跟踪工具用于生成虚拟机当前时刻的线程快照。 概述 给系统定位问题的时候,知识、经验是关键基础,数据是依据,工具是运用知识处理数据的手段。 java开发人员可以在jdk安装的bin目录下找到除了java,javac以外的其他命令。这些命令主要是一...

    loonggg 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<