jmap命令(Java Memory Map)

开发 后端
jmap命令:打印出某个java进程(使用pid)内存内的,所有‘对象’的情况(如:产生那些对象,及其数量)。

1、介绍


打印出某个java进程(使用pid)内存内的,所有‘对象’的情况(如:产生那些对象,及其数量)。

可以输出所有内存中对象的工具,甚至可以将VM 中的heap,以二进制输出成文本。使用方法 jmap -histo pid。如果连用SHELL jmap -histo pid>a.log可以将其保存到文本中去,在一段时间后,使用文本对比工具,可以对比出GC回收了哪些对象。jmap -dump:format=b,file=outfile 3024可以将3024进程的内存heap输出出来到outfile文件里,再配合MAT(内存分析工具(Memory Analysis Tool),使用参见:http://blog.csdn.net/fenglibing/archive/2011/04/02/6298326.aspx)或与jhat (Java Heap Analysis Tool)一起使用,能够以图像的形式直观的展示当前内存是否有问题。

64位机上使用需要使用如下方式:

jmap -J-d64 -heap pid

2、命令格式


SYNOPSIS

       jmap [ option ] pid

       jmap [ option ] executable core

       jmap [ option ] [server-id@]remote-hostname-or-IP

3、参数说明


1)options: 

executable Java executable from which the core dump was produced.

(可能是产生core dump的java可执行程序)

core 将被打印信息的core dump文件

remote-hostname-or-IP 远程debug服务的主机名或ip

server-id ***id,假如一台主机上多个远程debug服务 

2)基本参数:

-dump:[live,]format=b,file=<filename> 使用hprof二进制形式,输出jvm的heap内容到文件=. live子选项是可选的,假如指定live选项,那么只输出活的对象到文件. 

-finalizerinfo 打印正等候回收的对象的信息.

-heap 打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况.

-histo[:live] 打印每个class的实例数目,内存占用,类全名信息. VM的内部类名字开头会加上前缀”*”. 如果live子参数加上后,只统计活的对象数量. 

-permstat 打印classload和jvm heap长久层的信息. 包含每个classloader的名字,活泼性,地址,父classloader和加载的class数量. 另外,内部String的数量和占用内存数也会打印出来. 

-F 强迫.在pid没有相应的时候使用-dump或者-histo参数. 在这个模式下,live子参数无效. 

-h | -help 打印辅助信息 

-J 传递参数给jmap启动的jvm. 

pid 需要被打印配相信息的java进程id,创业与打工的区别 - 博文预览,可以用jps查问.

4、使用示例


1)[fenglb@ccbu-156-5 ~]$ jmap -histo 4939

[输出较多这里不贴了]

2)[fenglb@ccbu-156-5 ~]$ jmap -dump:format=b,file=test.bin 4939

Dumping heap to /home/fenglb/test.bin ...

Heap dump file created

原文链接:http://blog.csdn.net/fenglibing/article/details/6411953

【编辑推荐】

  1. 同一段程序在Java和C中的不同结果
  2. Java中Runnable和Thread的区别
  3. Java对存储过程的调用方法
  4. Java初学者都必须理解的六大问题
  5. 深入Java关键字null
责任编辑:林师授 来源: fenglibing的博客
相关推荐

2013-04-09 12:41:33

Java Map遍历法Java

2023-10-09 08:44:51

JDK命令行工具

2024-11-11 17:20:52

2016-12-13 16:20:22

solr索引数据

2021-09-15 16:05:41

map.putJavaMap

2021-05-08 10:36:31

开发Java Map

2009-06-25 15:20:28

CollectionMap

2021-03-26 00:00:05

​JavaMap设计

2010-04-20 16:17:03

Oracle In-M

2021-12-27 09:33:12

内存泄漏程序

2012-10-08 09:50:45

2021-07-12 09:17:54

Memory Comp系统内存

2022-11-17 15:17:12

Java数据结构Map

2010-02-04 10:55:12

ibmdwPowerVM虚拟化

2014-07-30 14:22:41

AndroidWebView内存泄漏

2011-02-22 09:40:18

HashMap

2023-10-08 08:46:29

Java遍历方式

2023-05-11 07:41:03

Java 8tMap方法

2009-09-22 11:52:49

ibmdwPowerVM

2010-04-23 09:13:08

Oracle In-M
点赞
收藏

51CTO技术栈公众号