昨天组里的新人小朋友问是不是每执行一次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;生成一个关于此进程的堆栈使用情况;使用工具做出对比
npm install -g jmap-server 用法 首先启动服务器: jmap-server 然后,您可以在测试一些请求: curl -d "@examples/mailboxes/setMailboxes.json" -H "Content-Type: application/json" http://127.0.0.1:3000...
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内存泄漏定位实战 verbosegc,将GC输出到gc.log文件中 ... jmap -dump:live,format = b,file = 94223.bin 94223 用Eclipse Memory Analyzer:转储文件,通过内存泄漏分析,得到这样一个分析报告
1.问题提出的背景 Doris集群的角色分为FE和BE。在存储层面FE负责存储和维护集群的元数据。...2.1通过jmap-histo:live统计当前JVM堆内对象信息执行"jmap-histo:live pid"命令可以查看堆内对象的统计信息。具体实战
通过jmap 导出文件,对jvm...JVM 内存分析软件,查看jvm 内存是否泄漏,那个class 内存泄漏,通过java 命令 jmap -dump:live,format=b,file=${文件路径}/xxx.bin 进程ID 导出bin 文件,用该软件进行对bin文件进行分析
jmap-client-ts 用编写的 Client。 如何使用它 导入项目(在package.json ),您可以引用提交或分支以使用快照版本。 创建客户端 let client = new Client ( { accessToken : 'myToken' , sessionUrl : '...
jmap-perl 是 JMAP 代理服务器的 Perl 实现,Perl JMAP 后端可以与 IMAP 和 SMTP 服务器通许,允许在邮件系统上替换 JMAP 接口。为了高效,初始化实现要求所有服务器支持 CONDSTORE 扩展(RFC4551/FRC7162)。提供一个...
java内存分析工具, 使用命令jmap -dump:format=b,file=/home/apps.dump 进程号 可以生成dump文件,用MAT打开dump文件分析java进程的内存信息。
我们也调小New Generation的,但是这样会使full gc时间加长。 后来我们就用CMS gc(-XX:+UseConcMarkSweepGC),当时的总heap还是3g,新生代1.5g后,观察不是很理想,改为jvm heap为2g新生代设置-Xmn1g,在这样的...
JMAP-JS 是 JMAP 邮件,联系人和日历模型的 JavaScript 实现,是 JMAP 的 JavaScript 客户端。 标签:JMAPJS
jcmd <PID> GC.heap_dump <PATH>-堆转储到指定文件 jcmd <PID> Thread.print-线程转储 jcmd 帮助-可用命令列表 jmap -histo-直方图 jmap -dump:活动,文件= <PATH> <PID>-堆转储 ps -eLf-具有其线程的进程列表 kill...
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`
java内存分析工具,可用于查看内存,分析...jmap -dump:format=b,file=D:/dump.hprof pid 然后打开MemoryAnalyzer.exe左上角菜单File-->open File... 选择你生成的dump.hprof文件 加载dump.hprof文件后会生成内存泄露报告
自卸车以下两篇文章结合了基本的Java类,以允许从正在运行的Java进程中转储.hprof: 此类可完成jmap -dump:live,format=b,file=/tmp/jvm.hprof工作,但可以在jmap由于某些原因无法工作的情况下工作。配置运行该类的...
JDK本身提供了很多方便的JVM性能调优监控工具,除了集成式的VisualVM和jConsole外,还有jps、jstack、jmap、jhat、jstat等小巧的工具,下面这篇文章主要给大家介绍了关于jvm信息jmap使用的基本方法教程,需要的朋友...
pod 'JMapiOSSDK' , :git => 'https://github.com/Jibestream/JMap-iOS-SDK-Pod.git' 对于首次安装,请运行: pod install 要获取最新版本的Pod,请执行以下操作: pod update 作者 路易(Louie),
java程序性能分析thread dump和heap dump,dump文件:在故障定位(尤其是out of memory)和性能分析的时候,dump文件记录了JVM运行期间的内存占用、线程执行等情况。 heap dump:记录某一时刻JVM堆中对象使用情况,哪些...
JVM性能调优监控工具jps、jstack、jmap、jhat、jstat使用详解.docx
Java OOM分析工具,Linux下使用jmap -heap:format=b pid,导出发生OOM进程的内存快照,使用该工具分析OOM发生原因