`
langzi_xl
  • 浏览: 22371 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

jmap -dump:live为啥会触发Full GC

    博客分类:
  • Java
阅读更多

昨天组里的新人小朋友问是不是每执行一次jmap -dump:live都会触发一次Full GC,因为当时他在做性能测试时某应用已经好几个小时没有一次FGC了,结果他执行了下dump就增加了次FGC。

我当时模糊回答应该会,以前看过哪篇文章好像提过^-^,不过本着严谨不误导新人小朋友的原则,还是找时间抽空验证实践了把:

测试环境:linux , sun jdk 1.6.07 , 32位

测试结果: jmap -dump:live 以及 jmap -histo:live都会触发Full GC,即使加上JVM参数-XX:+DisableExplicitGC也不影响结果

那么为什么呢? 其实大概猜也能知道,live选项的,如果FGC后,看到的活的对象比没有FGC的自然更精确。

我们来通过源码验证学习一下:

入口自然是$j2se/src/share/classes/sun/tools/JMap.java

关键点是

VirtualMachine vm = attach(pid);
InputStream in = ((HotSpotVirtualMachine)vm).
heapHisto(live ? LIVE_OBJECTS_OPTION : ALL_OBJECTS_OPTION);

以及

InputStream in = ((HotSpotVirtualMachine)vm).
dumpHeap((Object)filename,
(live ? LIVE_OBJECTS_OPTION : ALL_OBJECTS_OPTION));

于是找到这里

HotSpotVirtualMachine.java:

public InputStream dumpHeap(Object … args) throws IOException {
return executeCommand(“dumpheap”, args);

}


public InputStream heapHisto(Object … args) throws IOException {
return executeCommand(“inspectheap”, args);
}

接着看到

LinuxVirtualMachine.java:

先是创建UNIX socket,然后连到target VM,把dumpheap或inspectheap命令通过socket发过去。

那么具体的inspectheap在sun hotspot核心代码里是如何处理的呢?

看这个 $hotspot/src/share/vm/services/attachListener.cpp

heap_inspection函数有如下关键代码:

VM_GC_HeapInspection heapop(out, live_objects_only /* request full gc */, true /* need_prologue */);

同样dumpheap在hotspot里也是这个文件里处理的:

jint dump_heap(AttachOperation* op, outputStream* out) {

// Request a full GC before heap dump if live_objects_only = true
// This helps reduces the amount of unreachable objects in the dump
// and makes it easier to browse.
HeapDumper dumper(live_objects_only /* request GC */);
int res = dumper.dump(op->arg(0));

这下我们就明白了,与实验结果也对上号了

参考资料: http://forums.java.net/jive/message.jspa?messageID=115907

分享到:
评论

相关推荐

    jmap -dump:format=b,file=heapdump.hprof Pid堆栈文件分析工具

    jmap -dump:format=b,file=heapdump.hprof Pid;生成一个关于此进程的堆栈使用情况;使用工具做出对比

    JMAP-Server:如http所指定的JMAP服务器的实现

    npm install -g jmap-server 用法 首先启动服务器: jmap-server 然后,您可以在测试一些请求: curl -d "@examples/mailboxes/setMailboxes.json" -H "Content-Type: application/json" http://127.0.0.1:3000...

    MemoryAnalyzer-1.9.1.20190826-linux.gtk.x86_64.zip

    jmap -dump:live,format=b,file= java_pid1089.hprof PID 然后,在linux解压后执行以下命令,就生成一个报告: ./ParseHeapDump.sh java_pid1089.hprof org.eclipse.mat.api:suspects org.eclipse.mat.api:overview ...

    学习tomcat的内存泄漏

    Tomcat内存泄漏定位实战 verbosegc,将GC输出到gc.log文件中 ... jmap -dump:live,format = b,file = 94223.bin 94223 用Eclipse Memory Analyzer:转储文件,通过内存泄漏分析,得到这样一个分析报告

    如何快速定位线上Doris FE内存使用过高问题? (1).pdf

    1.问题提出的背景 Doris集群的角色分为FE和BE。在存储层面FE负责存储和维护集群的元数据。...2.1通过jmap-histo:live统计当前JVM堆内对象信息执行"jmap-histo:live pid"命令可以查看堆内对象的统计信息。具体实战

    MemoryAnalyzer-1.10.0.20200225-win32.win32.x86_64.zip

    通过jmap 导出文件,对jvm...JVM 内存分析软件,查看jvm 内存是否泄漏,那个class 内存泄漏,通过java 命令 jmap -dump:live,format=b,file=${文件路径}/xxx.bin 进程ID 导出bin 文件,用该软件进行对bin文件进行分析

    jmap-client-ts:TypeScript中的JMAP 1.0客户端库

    jmap-client-ts 用编写的 Client。 如何使用它 导入项目(在package.json ),您可以引用提交或分支以使用快照版本。 创建客户端 let client = new Client ( { accessToken : 'myToken' , sessionUrl : '...

    JMAP代理服务器jmap-perl.zip

    jmap-perl 是 JMAP 代理服务器的 Perl 实现,Perl JMAP 后端可以与 IMAP 和 SMTP 服务器通许,允许在邮件系统上替换 JMAP 接口。为了高效,初始化实现要求所有服务器支持 CONDSTORE 扩展(RFC4551/FRC7162)。提供一个...

    MemoryAnalyzer

    java内存分析工具, 使用命令jmap -dump:format=b,file=/home/apps.dump 进程号 可以生成dump文件,用MAT打开dump文件分析java进程的内存信息。

    JVM参数设置详细说明

    我们也调小New Generation的,但是这样会使full gc时间加长。 后来我们就用CMS gc(-XX:+UseConcMarkSweepGC),当时的总heap还是3g,新生代1.5g后,观察不是很理想,改为jvm heap为2g新生代设置-Xmn1g,在这样的...

    JMAP的JavaScript客户端JMAP-JS.zip

    JMAP-JS 是 JMAP 邮件,联系人和日历模型的 JavaScript 实现,是 JMAP 的 JavaScript 客户端。 标签:JMAPJS

    codepot-dumps

    jcmd <PID> GC.heap_dump <PATH>-堆转储到指定文件 jcmd <PID> Thread.print-线程转储 jcmd 帮助-可用命令列表 jmap -histo-直方图 jmap -dump:活动,文件= <PATH> <PID>-堆转储 ps -eLf-具有其线程的进程列表 kill...

    shell:我在unixlinux下积累的常用工具

    unixtools 我在unixtools下积累的常用工具 PS,这里所有的工具都是给淘宝环境下使用,如果你不能理解脚本中.../opt/taobao/java/bin/jmap -dump:live,format=b,file=heap-`date +%Y%m%d%H%M`.bin `pgrep -u admin java`

    MemoryAnalyzer-1.12.0.20210602-win32.win32.x86_64.zip

    java内存分析工具,可用于查看内存,分析...jmap -dump:format=b,file=D:/dump.hprof pid 然后打开MemoryAnalyzer.exe左上角菜单File-->open File... 选择你生成的dump.hprof文件 加载dump.hprof文件后会生成内存泄露报告

    dumper:用于在jvm进程上执行堆转储的简单类

    自卸车以下两篇文章结合了基本的Java类,以允许从正在运行的Java进程中转储.hprof: 此类可完成jmap -dump:live,format=b,file=/tmp/jvm.hprof工作,但可以在jmap由于某些原因无法工作的情况下工作。配置运行该类的...

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

    JDK本身提供了很多方便的JVM性能调优监控工具,除了集成式的VisualVM和jConsole外,还有jps、jstack、jmap、jhat、jstat等小巧的工具,下面这篇文章主要给大家介绍了关于jvm信息jmap使用的基本方法教程,需要的朋友...

    JMap-iOS-SDK-Pod

    pod 'JMapiOSSDK' , :git => 'https://github.com/Jibestream/JMap-iOS-SDK-Pod.git' 对于首次安装,请运行: pod install 要获取最新版本的Pod,请执行以下操作: pod update 作者 路易(Louie),

    java性能分析 jmap jstack

    java程序性能分析thread dump和heap dump,dump文件:在故障定位(尤其是out of memory)和性能分析的时候,dump文件记录了JVM运行期间的内存占用、线程执行等情况。 heap dump:记录某一时刻JVM堆中对象使用情况,哪些...

    JVM性能调优监控工具jps、jstack、jmap、jhat、jstat使用详解.docx

    JVM性能调优监控工具jps、jstack、jmap、jhat、jstat使用详解.docx

    IBM HeapAnalyzer

    Java OOM分析工具,Linux下使用jmap -heap:format=b pid,导出发生OOM进程的内存快照,使用该工具分析OOM发生原因

Global site tag (gtag.js) - Google Analytics