`

java-jvm-jmap(高内存排查)

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

-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的数量和占用内存数也会打印出来.


1、-heap
打印当前heap的概要信息:heap的总量,年轻代,老年代,Perm Generation的量
GC使用的算法
heap的配置:总量
当前heap的使用情况:占用量,总量,百分比
.
sudo jmap -heap 27409

输出:
Attaching to process ID 27409, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 24.45-b08

using thread-local object allocation.
Parallel GC with 4 thread(s)

Heap Configuration:
   MinHeapFreeRatio = 40
   MaxHeapFreeRatio = 70
   MaxHeapSize      = 2147483648 (2048.0MB)
   NewSize          = 268435456 (256.0MB)
   MaxNewSize       = 17592186044415 MB
   OldSize          = 5439488 (5.1875MB)
   NewRatio         = 2
   SurvivorRatio    = 8
   PermSize         = 268435456 (256.0MB)
   MaxPermSize      = 268435456 (256.0MB)
   G1HeapRegionSize = 0 (0.0MB)

Heap Usage:
PS Young Generation
Eden Space:
   capacity = 704643072 (672.0MB)
   used     = 429546320 (409.6472930908203MB)
   free     = 275096752 (262.3527069091797MB)
   60.959418614705406% used
From Space:
   capacity = 5767168 (5.5MB)
   used     = 4327344 (4.1268768310546875MB)
   free     = 1439824 (1.3731231689453125MB)
   75.03412420099431% used
To Space:
   capacity = 5767168 (5.5MB)
   used     = 0 (0.0MB)
   free     = 5767168 (5.5MB)
   0.0% used
PS Old Generation
   capacity = 1431830528 (1365.5MB)
   used     = 574251648 (547.6490478515625MB)
   free     = 857578880 (817.8509521484375MB)
   40.106118480524536% used
PS Perm Generation
   capacity = 268435456 (256.0MB)
   used     = 72128064 (68.78668212890625MB)
   free     = 196307392 (187.21331787109375MB)
   26.869797706604004% used

31742 interned Strings occupying 3432376 bytes.


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

输出:
Object Histogram:

num       #instances    #bytes  Class description
--------------------------------------------------------------------------
1:              164294  173445488       byte[]
2:              4426453 106234872       java.util.concurrent.ConcurrentSkipListMap$Node
3:              448524  74384360        char[]
4:              2215688 53176512        java.lang.Double
5:              96356   33816408        int[]
6:              965084  23162016        java.util.concurrent.ConcurrentSkipListMap$Index
7:              125211  18655880        * ConstMethodKlass
8:              733892  17613408        java.lang.Long
9:              125211  16039712        * MethodKlass
10:             444730  14231360        java.util.HashMap$Entry
11:             11617   13094656        * ConstantPoolKlass
12:             426560  10237440        java.lang.String
13:             11611   8346592 * InstanceKlassKlass
14:             115808  7411712 com.mysql.jdbc.ConnectionPropertiesImpl$BooleanConnectionProperty
15:             9526    7374880 * ConstantPoolCacheKlass
。。。。

另外继续分析日志,每个对象存在的数量以及占用内存的大小:
grep "qunar" data.txt |grep "afare"

输出:
17:             28137   4051728 com.gym.afare.dubbo.model.AfareBlackList
664:            30      1680    com.gym.afare.dubbo.model.AfareBlackListPlus
977:            10      720     com.gym.flight.afare.model.RefreshCmRequest
1055:           12      576     com.gym.flight.afare.model.ErrorEnum
1099:           6       528     com.gym.afare.dubbo.model.request.AfareResultRequest
1146:           12      480     com.gym.flight.afare.model.RefreshTask
1151:           10      480     com.gym.flight.afare.model.RefreshPriceRequest
1206:           13      416     com.gym.flight.afare.model.ApiResponse
1480:           4       224     com.gym.afare.dubbo.model.AfareBlackList$FlightType[]
1544:           5       200     com.gym.afare.dubbo.model.AfareBlackList$UnLockTypeEnum
1574:           3       192     com.gym.afare.dubbo.model.AfareBlackList$UnLockTypeEnum[]
1596:           4       192     com.gym.afare.dubbo.model.AfareBlackList$FlightType
1666:           3       168     com.gym.afare.dubbo.model.AfareBlackList$LockTypeEnum[]
1841:           4       160     com.gym.afare.dubbo.model.AfareBlackList$LockTypeEnum
2015:           3       120     com.gym.afare.dubbo.model.AfareBlackList$LockStatusEnum[]
2022:           1       120     com.gym.flight.afare.model.ErrorEnum[]
2305:           2       80      com.gym.afare.dubbo.model.AfareBlackList$LockStatusEnum
2669:           1       56      com.gym.flight.afare.task.DeleteUnlockBlackListTask
2713:           1       48      com.gym.flight.afare.dubbo.provider.AfareBlackListServiceImpl
2952:           1       40      com.gym.flight.afare.dao.impl.AfareBlackListDAOImpl
2961:           1       40      com.gym.flight.afare.service.impl.RefreshPriceServiceImpl
3012:           1       40      com.gym.flight.afare.service.impl.RefreshPriceServiceImpl$RefreshThreadFactory
3036:           1       40      com.gym.flight.afare.dao.impl.AfareBlackListPlusDAOImpl
3182:           1       32      com.gym.flight.afare.dubbo.provider.AfareResultQueryServiceImpl
3197:           1       32      com.gym.flight.afare.dao.CacheManager
3282:           1       32      com.gym.flight.afare.dao.impl.AfareResultDaoImpl
3289:           1       32      com.gym.flight.afare.dubbo.provider.AfareResultUpdateServiceImpl
3292:           1       32      com.gym.flight.afare.service.Qc
3297:           1       32      com.gym.flight.afare.web.RefreshPriceController
3476:           1       24      com.gym.flight.afare.model.TaskListener
3479:           1       24      com.gym.flight.afare.task.ReloadBlacklistCacheTask
3543:           1       24      com.gym.flight.afare.task.ArchiveAfareResultTask
3676:           1       24      com.gym.flight.afare.dao.CacheManager$1
3720:           1       24      com.gym.flight.afare.web.BackController
4058:           1       16      com.gym.flight.afare.web.interceptor.TraceInterceptor
4119:           1       16      com.gym.flight.afare.util.SpringUtil

从中不难看出,SpringUtil 等类都是单例的,所以只有一个对象,而AfareBlackList 是系统内的对象,数量存在较多

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


输出到heap.bin文件里
eg
class C{
	byte b = 100;
}

class B {
	List<C[]> d = new ArrayList<C[]>();

	public B() {
		for (int i = 0; i < 100000; i++) {
			d.add(new C[i]);
		}
	}

}

class A {
	List<B> bList = new ArrayList<B>();

	public A() {
		for (int i = 0; i < 1000; i++) {
			bList.add(new B());
		}
	}
}

public class Test {
	public static void main(String[] args) throws Exception {
		A a = new A();
		new Thread() {}.start();

		a.toString();
		
	}
}



运行参数:
-server -Xms1024m -Xmx1024m -Xmn512m -XX:+UseParallelOldGC -XX:+PrintGCApplicationStoppedTime -XX:+PrintGCDateStamps -XX:+PrintGCDetails  -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=c:/heap.bin








其他:
-permstat 打印classload和jvm heap长久层的信息. 包含每个classloader的名字,活泼性,地址,父classloader和加载的class数量. 另外,内部String的数量和占用内存数也会打印出来.
-dump:[live,]format=b,file=<filename> 使用hprof二进制形式,输出jvm的heap内容到文件=. live子选项是可选的,假如指定live选项,那么只输出活的对象到文件. 

参考资料:
http://www.tuicool.com/articles/VzYziu
  • 大小: 129.5 KB
  • 大小: 1.1 MB
0
1
分享到:
评论

相关推荐

    Java虚拟机-jvm故障诊断与性能优化-源码

    在《实战Java虚拟机——JVM故障诊断与性能优化》一书中,作者深入探讨了如何对JVM进行故障排查和性能调优,通过源码分析来帮助读者理解其内部工作原理。下面我们将根据书中的主题,详细阐述相关的知识点。 1. **JVM...

    练习JVM调优-jvm_demo.zip

    在Java开发领域,JVM(Java Virtual Machine)是至关重要的组成部分,它负责解析并执行Java程序。JVM调优是一项核心技能,可以帮助我们优化应用程序的性能,减少内存消耗,提高响应速度,以及避免可能出现的垃圾收集...

    1. JVM 内存结构的组成、各部分功能作用,学会利用内存诊断工具排查内存相关问题;2. JVM 的招牌-jvm.zip

    了解JVM内存结构及其功能对于优化Java应用程序的性能和排查内存问题至关重要。 首先,我们来详细探讨JVM的内存结构。在Java中,内存主要分为以下几个区域: 1. **程序计数器(Program Counter Register)**:每个...

    jvm问题排查

    在日常的软件开发与维护过程中,针对JVM(Java虚拟机)的性能调优和问题排查是非常关键的一环。本手册旨在提供一套全面且实用的JVM问题排查方法和技术,帮助开发者快速定位并解决JVM相关的性能瓶颈或异常情况。 ###...

    整理-JVM相关面试题2024

    - **定义**:JVM(Java Virtual Machine)即Java虚拟机,是一种抽象的计算机,它提供了一个运行环境,使Java代码可以在任何安装了JVM的操作系统上运行,而无需重新编译。 - **作用**:通过字节码执行机制,实现了...

    带你全面理解JVM,掌握常规JVM调优-JVM.zip

    Java源代码被编译成字节码后,JVM将其加载到内存中,经过验证确保代码安全,解析方法表,初始化类变量,最后通过解释器或即时编译器(JIT)转化为机器码执行。 二、JVM内存模型 1. 堆内存:所有对象都在堆中创建,...

    jvm调优-jvm.zip

    Java虚拟机(JVM)是Java程序运行的基础,它负责解释和执行字节码,管理内存,以及优化代码性能。JVM调优是一项关键技能,它涉及到调整JVM的配置参数,以达到最佳的程序运行效率,防止内存泄漏,以及确保应用程序的...

    jvm信息jmap使用的基本方法教程

    jmap是JDK自带的一个命令行工具,用于收集和分析JVM内存信息,主要包括堆内存、类加载器统计和对象 finalize 队列等。本文将详细介绍jmap的使用方法。 ### 前言 在Java性能调优过程中,开发者通常会使用各种开源...

    jvm原理机器调优-jvm.zip

    JVM原理和调优是每个Java开发人员必须掌握的关键技能,这涉及到内存管理、垃圾收集、性能优化等多个方面。在深入理解JVM的工作机制后,我们可以更好地调整和优化应用程序,提升系统的性能和稳定性。 一、JVM结构与...

    java IBM websphere 内存溢出 javacore deapdump CPU内存分析工具

    总结来说,面对Java IBM WebSphere的内存溢出问题,我们需要结合`javacore`和`deapdump`等诊断工具,通过分析脚本和相关库文件,理解内存管理原理,调整JVM配置,并优化代码,才能有效地排查和解决问题。

    java内存泄露、溢出检查方法和工具

    长期的内存泄露会导致Java虚拟机(JVM)的堆内存耗尽,引发OutOfMemoryError。 检查Java内存泄露的方法主要包括以下几个步骤: 1. **生成堆转储文件**:在Linux环境中,可以使用JVM提供的`jmap`命令生成堆转储文件...

    jvm瓶颈定位 java jvm 学习

    Java虚拟机(JVM)是Java开发中的核心组成部分,它负责执行字节码,管理内存,以及优化程序性能。在Java应用的运行过程中,如果出现性能问题,JVM瓶颈定位就显得至关重要。本文将深入探讨如何理解和解决Java JVM的...

    java-虚拟机 操作系统监控工具-源码

    支持Java虚拟机监控:GC信息、内存使用情况、内存池信息、类加载器、线程堆栈 支持生成火焰图(采样事件包括CPU、内存分配、线程栈、Java方法调用栈等) 支持Java代码反编译生成 支持Java代码热更新(可指定...

    jvm日志解读

    《JVM日志解读——揭示Java虚拟机的秘密》 在Java开发中,JVM(Java Virtual Machine)扮演着至关重要的角色。它负责运行我们的代码,管理内存,执行垃圾收集等。当程序出现异常或者性能问题时,JVM生成的日志文件...

    JVM 基础 JAVA 并发 JVM 性能调优 LeetCode 算法 .......

    "JVM 基础知识点" JVM(Java Virtual Machine)是 Java 语言的运行环境,负责执行 Java 字节码。...排查 JVM 问题可以使用 jmap 查看 JVM 中各个区域的使用情况,可以使用 jstack 查看 JVM 中的线程信息。

    【JAVA WEB实用技巧与优化方案】如何排查JVM线程和内存相关问题

    在Java Web开发中,性能优化和问题排查是关键任务,特别是涉及到JVM(Java虚拟机)的线程和内存管理。本文将详细讲解如何利用`javacore`和`heapdump`分析工具来解决相关问题。 `javacore`文件是JVM在特定时刻生成的...

    java-1.8.0_121.tar.gz

    6. **jcmd**: jcmd是Java诊断命令工具,提供了大量用于性能分析和故障排查的命令,如GC日志、线程堆栈转储、JVM配置信息查看等。它是Java 7及更高版本引入的,大大增强了开发者对JVM的控制和调试能力。 7. **安全性...

    Java虚拟机调优及问题排查手册.docx

    本手册主要介绍Java虚拟机(JVM)的调优和问题排查解决方案。该手册涵盖了JVM排查、数据库连接排查、堆栈快照排查等多方面的内容。 JVM排查 JVM排查是指通过各种命令和工具来排查JVM的状态和性能问题。常用的命令...

    实战JAVA虚拟机 JVM故障诊断与性能优化

    JDK自带了一系列强大的诊断工具,如jps(Java进程查看器)、jstat(统计信息工具)、jinfo(配置信息工具)、jmap(内存映射工具)、jhat(堆转储分析工具)和jstack(线程堆栈跟踪工具)。熟练掌握这些工具的使用,...

    ha456.jar(IBMHeapAnalyzer)JVM内存分析工具

    【ha456.jar(IBMHeapAnalyzer)JVM内存分析工具】是一款由IBM开发的专业工具,主要用于诊断Java虚拟机(JVM)的内存问题。它能够解析和分析JVM生成的内存转储文件(通常称为heap dump或hprof文件),帮助开发者识别...

Global site tag (gtag.js) - Google Analytics