JDK自带工具之jhat

Jhat是JDK自带的一个轻量级小工具。jhat位于java的bin目录下,是用来分析java堆的命令,可以将堆中的对象以html的形式显示出来,包括对象的数量,大小等等,并支持对象查询语言,jhat工具一般和jmap工具配合使用。

1、Jstat命令格式

Jhat dumpFile

2、使用步骤

第一步:导出堆

第二步:分析堆文件

第三步:查看html

有时dump出来的堆很大,在启动时会报堆空间不足的错误,可以使用如下参数:

jhat -J-Xmx512m <heap dump file>

3、利用JMAP的源代码导出dump文件

package com.jdkTools;

import java.util.ArrayList;

import java.util.Random;

/**

* 简单的应用,有大量的循环和创建对象,供测试JDK自带的jmap使用

* 参数:-Xms30m -Xmx60m

*

* @author 范芳铭

*/

public class EasyJmap {

public byte[] placeHolder = newbyte[1 * 1024]; //
占位符

public static void main(String[]args) throws Exception {

while (true) {

Random random = newRandom();

int loops =random.nextInt(10000);

EasyJmap jstat = newEasyJmap();

System.out.println("......正在构建对象:" + loops + "(个)");

jstat.getLoop(loops); //多次循环,产生大量对象

Thread.sleep(10);

}

}

public void getLoop(int size) {

ArrayList<EasyJmap>list = new ArrayList<EasyJmap>();

for (int i = 0; i < size;i++) {

EasyJmap jstat = newEasyJmap();

list.add(jstat);

}

}

}

4、导出dump文件

C:\Program Files\Java\jdk1.6.0_25\bin>jmap-dump:format=b,file=d:/ffm83/jmaplog.txt 1668

Dumping heap to D:\ffm83\jmaplog.txt ...

Heap dump file created

5、分析堆文件

C:\ProgramFiles\Java\jdk1.6.0_25\bin>jhat D:/ffm83/jmaplog.txt

Readingfrom D:/ffm83/jmaplog.txt...

Dumpfile created Tue Jan 20 16:47:38 CST 2015

Snapshotread, resolving...

Resolving10893 objects...

Chasingreferences, expect 2 dots..

Eliminatingduplicate references..

Snapshotresolved.

StartedHTTP server on port 7000

Serveris ready.

6、查看堆文件的HTML

默认端口为 7000,可以使用http://localhost:7000/访问

例如:

Packagecom.jdkTools

class com.jdkTools.EasyJmap [0x7d077f8]

OtherQueries

7、jhat中的OQL(对象查询语言) 

如果需要根据某些条件来过滤或查询堆的对象,进入“?   Execute Object Query Language (OQL) query”在jhat的html页面中执行OQL,来查询符合条件的对象

OQL基本语法

select <javascript expression to select>

[from [instanceof] <class name> <identifier>]

[where <javascript boolean expression to filter>]

8、OQL解释

(1)class name是java类的完全限定名,如:java.lang.String, java.util.ArrayList, [C是char数组, [Ljava.io.File是java.io.File[]

(2)类的完全限定名不足以唯一的辨识一个类,因为不同的ClassLoader载入的相同的类,它们在jvm中是不同类型的

(3)instanceof表示也查询某一个类的子类,如果不明确instanceof,则只精确查询class name指定的类

(4)from和where子句都是可选的

(5)java域表示:obj.field_name;java数组表示:array[index]

9、OQL常用示例

(1)查询长度大于100的字符串

select s from java.lang.String s where s.count > 100

(2)查询长度大于256的数组

select a from [I a where a.length > 256

(3)显示匹配某一正则表达式的字符串

select a.value.toString() from java.lang.String s where /java/(s.value.toString())

(4)显示所有文件对象的文件路径

select file.path.value.toString() from java.io.File file

(5)显示所有ClassLoader的类名

select classof(cl).name from instanceof java.lang.ClassLoader cl

(6)通过引用查询对象

select o from instanceof 0xd404d404 o

OQL-built-in对象 -- heap 

(1)heap.findClass(class name) -- 找到类

select heap.findClass("java.lang.String").superclass

(2)heap.findObject(object id) -- 找到对象

select heap.findObject("0xd404d404")

(3)heap.classes -- 所有类的枚举

select heap.classes

(4)heap.objects -- 所有对象的枚举

select heap.objects("java.lang.String")

(5)heap.finalizables -- 等待垃圾收集的java对象的枚举

(6)heap.livepaths -- 某一对象存活路径

select heaplivepaths(s) from java.lang.String s

(7)heap.roots -- 堆根集的枚举

OQL-辨识对象的函数 

(1)classof(class name) -- 返回java对象的类对象

select classof(cl).name from instanceof java.lang.ClassLoader cl

(2)identical(object1,object2) -- 返回是否两个对象是同一个实例

select identical(heap.findClass("java.lang.String").name,heap.findClass("java.lang.String").name)

(3)objectid(object) -- 返回对象的id

select objectid(s) from java.lang.String s

(4)reachables -- 返回可从对象可到达的对象

select reachables(p) from java.util.Properties p -- 查询从Properties对象可到达的对象

select reachables(u, "java.net.URL.handler") from java.net.URL u -- 查询从URL对象可到达的对象,但不包括从URL.handler可到达的对象

(5)referrers(object) -- 返回引用某一对象的对象

select referrers(s) from java.lang.String s where s.count > 100

(6)referees(object) -- 返回某一对象引用的对象

select referees(s) from java.lang.String s where s.count > 100

(7)refers(object1,object2) -- 返回是否第一个对象引用第二个对象

select refers(heap.findObject("0xd4d4d4d4"),heap.findObject("0xe4e4e4e4"))

(8)root(object) -- 返回是否对象是根集的成员

select root(heap.findObject("0xd4d4d4d4"))

(9)sizeof(object) -- 返回对象的大小

select sizeof(o) from [I o

(10)toHtml(object) -- 返回对象的html格式

select "<b>" + toHtml(o) + "</b>" fromjava.lang.Object o

(11)选择多值

select {name:t.name?t.name.toString():"null",thread:t} frominstanceof java.lang.Thread t

OQL-数组、迭代器等函数 

(1)concat(enumeration1,enumeration2) -- 将数组或枚举进行连接

select concat(referrers(p),referrers(p)) from java.util.Properties p

(2)contains(array, expression) -- 数组中元素是否满足某表达式

select p from java.util.Properties where contains(referres(p),"classof(it).name == ‘java.lang.Class‘")

返回由java.lang.Class引用的java.util.Properties对象

built-in变量

it -- 当前的迭代元素

index -- 当前迭代元素的索引

array -- 被迭代的数组

(3)count(array, expression) -- 满足某一条件的元素的数量

select count(heap.classes(), "/java.io./(it.name)")

(4)filter(array, expression) -- 过滤出满足某一条件的元素

select filter(heap.classes(), "/java.io./(it.name)")

(5)length(array) -- 返回数组长度

select length(heap.classes())

(6)map(array,expression) -- 根据表达式对数组中的元素进行转换映射

select map(heap.classes(),"index + ‘-->‘ + toHtml(it)")

(7)max(array,expression) -- 最大值, min(array,expression)

selectmax(heap.objects("java.lang.String"),"lhs.count>rhs.count")

built-in变量

lhs -- 左边元素

rhs -- 右边元素

(8)sort(array,expression) -- 排序

select sort(heap.objects(‘[C‘),‘sizeof(lhs)-sizeof(rhs)‘)

(9)sum(array,expression) -- 求和

select sum(heap.objects(‘[C‘),‘sizeof(it)‘)

(10)toArray(array) -- 返回数组

(11)unique(array) -- 唯一化数组

时间: 2024-08-27 22:26:08

JDK自带工具之jhat的相关文章

JDK自带工具之jmap

Jmap是JDK自带的一个轻量级小工具.位于java的bin目录下,它能够打印出某个java进程(使用pid)内存中所有'对象'的情况(如:产生那些对象,及其数量).它不仅可以输出所有内存中对象的工具,甚至可以将VM 中的heap,以二进制输出成文本.使用方法 jmap -histo pid.也可以将其保存到文本中去,在一段时间后,使用文本对比工具,可以对比出GC回收了哪些对象.还可以和jhat (Java Heap Analysis Tool)一起使用,能够以图像的形式直观的展示当前内存是否有

JDK自带工具之jstack

jstack是java虚拟机自带的一种堆栈跟踪工具.jstack位于java的bin目录下,主要利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对Heap size和垃圾回收状况的监控. Jstat可以用来监视VM内存内的各种堆和非堆的大小及其内存使用量. 1.Jstack命令格式 jstack [ option ] pid 2.常用参数 -F当'jstack [-l] pid'没有相应的时候强制打印栈信息 -l长列表. 打印关于锁的附加信息,例如属于java.u

JDK自带工具之jstat

Jstat是JDK自带的一个轻量级小工具.全称"Java Virtual Machine statistics monitoring tool". Jstat位于java的bin目录下,主要利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对Heap size和垃圾回收状况的监控. Jstat可以用来监视VM内存内的各种堆和非堆的大小及其内存使用量. 1.Jstat命令格式 jstat [optionsvmid [interval[s|ms]  [coun

JDK自带工具之jinfo

Jinfo是JDK自带Java配置信息工具.位于java的bin目录下,jinfo的作用是实时地查看和调整虚拟机的各项参数,虽然使用Jps命令的-v参数可以查看虚拟机启动时显示指定的参数列表.但是如果想要知道没有被明确指出的系统默认值,就需要用到jinfo. Jinfo还能够修改一部分运行期间能够调整的虚拟机参数. 1.Jinfo命令格式 jinfo [ option ] pid 2.常用参数 Usage: jinfo <option> <pid> (to connect to a

JDK自带工具之JPS

jps(Java Virtual Machine Process Status Tool)是JDK提供的一个显示当前所有java进程pid的命令,简单实用,非常适合在linux/unix/windows平台上简单察看当前java进程的一些简单情况. jps它的作用是显示当前JAVA进程的id号,并可通过opt来查看这些进程的详细启动参数. jps位于jdk的bin目录下. 1.JPS命令格式 jps [ options ] [ hostid ]  2.常用参数 -q 只显示pid,不显示clas

JDK 自带工具试用(一)

简述: 运维监控会用到JDK的小工具 说明: 1. jps 用来查看当前运行的Java进程 我在eclipse中起了一个web 应用 或者用jps -l 可以查看的更清楚一点 jps -v 看到10376之后用taskkill指令关闭 2. jstat 虚拟机统计信息监视工具 先用jps查看当前启动的应用 于是使用 [plain] view plaincopy cd C:\Users\Administrator\Desktop\jvm monitor gcutil 监视Java堆状况,主要关注已

如何使用JDK自带工具JConsole

前言 jconsole.exe为jdk自带的监控工具,操作简便,比较容易上手.jconsole可以实时的监控Java程序在运行过程中的内存,cpu,线程的使用情况,并可以对加载的相关类进行分析.下面开始一起看看如何使用jconsole吧! 打开jconsole步骤: 1.首先进入到jdk的安装目录bin目录下:双击"jconsole.exe"打开jconsole 双击jconsole打开,并进入管理控制页面,如果本地有正在运行的Java进程的话会自动检测出来:这里分为监控本地进程或远程

JDK自带工具列表

JDK是一个功能强大的Java开发套装,它不仅仅为我们提供了Java运行环境,还给开发人员提供了许多有用的开发组件(位于bin目录中,如下图所示).仅仅使用JDK,就能够解决我们在Java开发过程中遇到的许多问题. 下图是JDK1.7版本下的工具列表:后续会针对每一个工具 下面,我们就按照工具文件名称的英文顺序来逐一介绍JDK内置的工具. 工具名称 描述 appletviewer.exe 用于运行并浏览applet小程序. apt.exe 注解处理工具(Annotation Processing

第七章:JDK自带工具

JDK内置的工具 工具名称 描述 appletviewer.exe 用于运行并浏览applet小程序. apt.exe 注解处理工具(Annotation Processing Tool),主要用于注解处理. extcheck.exe 扩展检测工具,主要用于检测指定jar文件与当前已安装的Java SDK扩展之间是否存在版本冲突. idlj.exe IDL转Java编译器(IDL-to-Java Compiler),用于为指定的IDL文件生成Java绑定.IDL意即接口定义语言(Interfac