`
lmdxr
  • 浏览: 42097 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

一次让人难以忘怀的排查频繁Full GC过程

    博客分类:
  • jvm
 
阅读更多

      我们的Java应用因频繁FULL GC导致性能降低很多,经过多人的定位也没有结论,于是我自主请命,经过一天的研究终于搞定了,现把经验与大家共享,相关的gc日志如下:

4.758: [Full GC [PSYoungGen: 464K->0K(71936K)] [PSOldGen: 37949K->33994K(68672K)] 38413K->33994K(140608K) [PSPermGen: 33221K->33221K(66560K)], 0.1887540 secs] [Times: user=0.20 sys=0.00, real=0.19 secs]

32.324: [Full GC [PSYoungGen: 12025K->0K(176320K)] [PSOldGen: 57570K->65642K(128256K)] 69595K->65642K(304576K) [PSPermGen: 35548K->35548K(76544K)], 0.2467320 secs] [Times: user=0.22 sys=0.02, real=0.25 secs]

50.133: [Full GC [PSYoungGen: 20999K->0K(437248K)] [PSOldGen: 118647K->114524K(198528K)] 139647K->114524K(635776K) [PSPermGen: 49637K->49637K(84224K)], 0.3302180 secs] [Times: user=0.32 sys=0.00, real=0.33 secs]

149.586: [Full GC [PSYoungGen: 44223K->0K(411712K)] [PSOldGen: 190278K->185382K(296064K)] 234501K->185382K(707776K) [PSPermGen: 50674K->50208K(85248K)], 0.6151800 secs] [Times: user=0.62 sys=0.00, real=0.61 secs]

260446.223: [Full GC [PSYoungGen: 31393K->0K(436032K)] [PSOldGen: 1006486K->396428K(1021312K)] 1037880K->396428K(1457344K) [PSPermGen: 61093K->61093K(61440K)], 1.3636610 secs] [Times: user=1.36 sys=0.00, real=1.52 secs]

260630.161: [Full GC (System) [PSYoungGen: 40410K->0K(424768K)] [PSOldGen: 991397K->721859K(1021312K)] 1031808K->721859K(1446080K) [PSPermGen: 61100K->61100K(61440K)], 2.1272130 secs] [Times: user=2.14 sys=0.00, real=2.13 secs]

260720.146: [Full GC (System) [PSYoungGen: 4949K->0K(439360K)] [PSOldGen: 1004066K->833610K(1021312K)] 1009015K->833610K(1460672K) [PSPermGen: 61108K->61108K(61440K)], 2.8408660 secs] [Times: user=2.72 sys=0.10, real=2.84 secs]

260810.150: [Full GC (System) [PSYoungGen: 33459K->0K(463552K)] [PSOldGen: 949989K->245655K(1021312K)] 983448K->245655K(1484864K) [PSPermGen: 61117K->61088K(61184K)], 1.1344010 secs] [Times: user=1.12 sys=0.02, real=1.14 secs]

03430.144: [Full GC (System) [PSYoungGen: 7390K->0K(489024K)] [PSOldGen: 871871K->393481K(976704K)] 879262K->393481K(1465728K) [PSPermGen: 64306K->64295K(64640K)], 1.3848850 secs] [Times: user=1.34 sys=0.06, real=1.38 secs]

403794.982: [Full GC [PSYoungGen: 9352K->0K(454144K)] [PSOldGen: 963758K->426051K(991744K)] 973110K->426051K(1445888K) [PSPermGen: 64298K->64298K(64640K)], 1.3783510 secs] [Times: user=1.32 sys=0.06, real=1.38 secs]

404120.149: [Full GC (System) [PSYoungGen: 6846K->0K(467648K)] [PSOldGen: 943642K->440168K(991744K)] 950489K->440168K(1459392K) [PSPermGen: 64300K->64300K(64640K)], 1.1605070 secs] [Times: user=1.12 sys=0.04, real=1.16 secs]

404466.698: [Full GC [PSYoungGen: 9719K->0K(472768K)] [PSOldGen: 980355K->442899K(1021312K)] 990074K->442899K(1494080K) [PSPermGen: 64303K->64303K(64640K)], 1.1729280 secs] [Times: user=1.14 sys=0.04, real=1.18 secs]

 

经过日志分析,我找到两个突破点,重点关注红色字体部分的日志,分析过程如下:

1
FULL GC前后Java堆大小有变化;经研究发现是由于Java应用JVM参数XMS设置为默认值,在我们的系统环境下,HotspotXms默认值为50M(-Xms默认是物理内存的1/64);每次GC时,JVM会根据各种条件调节Java堆的大小,Java堆的取值范围为[Xms, Xmx]。根据以上分析,修改Xms值与Xmx相等,这样就不会因为所使用的Java堆不够用而进行调节,经过测试后发现FULL GC次数从四位数减少至个位数。


2
)关键词“System”让我想到了System.gc调用,System.gc调用只是建议JVM执行年老代GC,而年老代GC触发FULL GCJVM会根据系统条件决定是否执行FULL GC,正因为系统条件不好判断,所以很难构造System.gc调用触发FULL GC,几经周折终于成功,当System.gc触发FULL  GC时都会有关键词System,而 JVM自动触发的FULL GC却不带关键词System,可以断定是Java应用存在“System.gc”代码。经过本次测试我也发现System.gc的真正含义,通俗言之,“System.gc” 就是FULL GC触发的最后一根稻草。

从本次分析中,我们可以得出如下的经验:

1
Java应用的jvm参数XmsXmx保持一致,避免因所使用的Java堆内存不够导致频繁full gc以及full gc中因动态调节Java堆大小而耗费延长其周期。


2
)建议不要调用System.gc或者Runtime.getRuntime().gc,否则本次调用可能会成为压死骆驼的最后一根稻草。当然我们可以通过设置jvm参数禁止这种调用生效,但是除非特别有把握该参数有必要添加,否则不推荐这么设置。

分享到:
评论
2 楼 zhangyou1010 2012-11-06  
我们的gc.log中有
Full GC (System)
  但是,代码没有调用System.gc

1 楼 aronlulu 2012-05-07  
引用
当System.gc触发FULL  GC时都会有关键词“(System)”,而 JVM自动触发的FULL GC却不带关键词“(System)”

很有用的信息,最好能有官方的说明文档就更有说服力了。

相关推荐

    人教六年级下册难忘的第一次作文PPT学习教案.pptx

    这篇PPT的学习教案主要针对的是小学六年级下册的一次作文教学,主题是“难忘的第一次”。这个教学活动旨在引导学生们回忆并记录他们生活中的重要瞬间,尤其是那些第一次的经历,以此来锻炼他们的写作技巧和表达情感...

    [难忘的一次抢救]难忘的一次活动400.rar

    [难忘的一次抢救]难忘的一次活动400.rar

    六年级下册难忘的第一次习作PPT学习教案.pptx

    首先,这个习作要求学生们以《难忘的“第一次”》为题,详细描绘他们在经历这些第一次时的具体情况,不仅要让读者了解事情的经过,还要让学生们深入思考这些经历带给他们的启示。这是写作的核心目标,即在叙述事件的...

    难忘的第一次作文指导.doc

    【标题】:“难忘的第一次作文指导.doc” 【描述】:“难忘的第一次作文指导.doc” 【标签】:“文档” 本文档提供了关于如何撰写以“难忘的第一次”为主题的作文的指导,帮助学生选择合适的题材并提供写作要点。...

    难忘的一次活动.docx

    - 运动员在比赛中往往会遇到巨大的心理压力,如何调整心态,克服紧张情绪,保持冷静和专注成为一项重要的能力。 ### 科学实验 1. **滑翔机模型**: - 滑翔机模型的制作涉及到空气动力学原理,通过调整翼型、翼展...

    那是一次难忘的尝试作文.doc

    【标题解析】:“那是一次难忘的尝试”这个标题表明文章讲述了一次作者记忆深刻的、具有挑战性的体验,这次尝试给作者留下了深刻的印象,并从中获得了某种教训或感悟。 【描述分析】:描述中的“那是一次难忘的尝试...

    一次难忘的选择600字一次难忘的选择600字作文范例.pdf

    一次难忘的选择600字一次难忘的选择600字作文范例.pdf

    难忘的第一次作文(合集11篇).docx

    【部分内容】中的四篇文章实际上都是描述作者生活中的“难忘的第一次”经历,而非直接的技术知识。尽管如此,我们可以将这些故事与技术学习和成长过程中的第一次尝试相联系,从而创建一个关于技术学习经验的话题。 ...

    六年级下册《难忘的第一次》习作课课件.ppt

    这篇六年级下册《难忘的第一次》习作课课件主要涵盖了如何引导学生进行有效的写作训练,特别是关于个人成长中的特殊经历。以下是一些关键的知识点: 1. **写作技巧**: - **修辞方法的应用**:如使用拟人等修辞...

    难忘的第一次中考优秀作文.docx

    【标题】与【描述】提及的是一个关于难忘的第一次中考作文的文档,而【标签】为"技术",这似乎存在一定的不匹配。不过,我们可以从文档内容中找到与技术相关的知识点,即在写作过程中使用的技术,如信息组织、表达...

    难忘的第一次初中作文800字.docx

    从给定的信息来看,本文主要围绕“难忘的第一次”这一主题展开叙述,通过两段具体的经历,即做饭和喝咖啡,向读者展示了作者在面对新挑战时的成长与体会。接下来,我们将从技术角度出发,结合文章内容,提炼并扩展...

    难忘的第一次作文.doc

    这篇文档标题为“难忘的第一次作文.doc”,描述和标签中提到了“范文”,说明这是一个关于个人经历的写作示例,特别讲述了作者初次学习游泳的过程。文章通过生动的叙述,展现了作者从不会游泳到掌握蛙泳技能的心路...

    难忘的第一次作文11篇_1.docx

    根据给定的信息,这里主要涉及的是“难忘的第一次”的主题,但由于题目要求从技术角度进行分析,我们将尝试从写作技巧和技术应用的角度来解读这些作文片段。 ### 技术视角下的“难忘的第一次” #### 一、标题与...

    语文:第7课《短文两篇-第一次真好》课件10(人教版七年级上册).ppt

    学生会被要求找出文中的关键句子,如“第一次的感觉真奇妙,新鲜而刺激,使人回味无穷”,这揭示了“第一次”带来的独特体验和难忘记忆。同时,通过“第一次愈多,生命愈多姿多彩,愿你珍重第一次”的引申,强调积累...

    难忘的第一次作文汇编11篇.docx

    “难忘的第一次作文汇编11篇.docx”中的内容如果能够被转化为适合社交媒体的形式进行分享,将有助于扩大受众范围,让更多人了解到作者的故事。这不仅是一种情感上的交流,也是个人记忆的一种扩展。从技术角度来看,...

    难忘的第一次作文11篇.docx

    文档标题与描述均为“难忘的第一次作文11篇.docx”,标签为“技术”,但从实际内容来看,文档讲述的是关于个人经历中的“第一次”的故事集,与技术标签不符。因此,我们将重点放在文档的实际内容上,提取并总结其中...

    【小学生作文】小学生难忘的第一次作文【五篇】.doc

    【小学生难忘的第一次作文】这个标题以及描述的内容是关于小学生写作的实例,主要讲述了孩子们初次体验各种生活场景时的感受和体验。这些文章集中反映了“第一次”经历对于个人成长的重要性,以及如何通过这些初次...

    六年级下册难忘第一次口语交际习作PPT教案学习.pptx

    4. 审题与构思:在习作过程中,学生需学会审题,理解“难忘的第一次”这一主题的内涵,收集相关材料,精心构思,并提前草拟文章,以养成良好的写作习惯。 5. 事件叙述:强调事件叙述的完整性,包括时间、地点、人物...

    【小学生作文】小学生难忘的一个人作文300字【八篇】.doc

    【小学生难忘的一个人作文300字【八篇】】这个文档主要包含了八篇小学生写的关于他们生活中难忘的一个人的作文。这些作文展现了孩子们对于生活中的重要人物的情感记忆,包括老师、陌生人以及朋友。 第一篇作文中,...

    六年级下册口语交际一难忘的第一次PPT教案学习.pptx

    这个PPT教案是针对小学六年级下册的一次口语交际活动,主题为“难忘的第一次”。这次活动旨在引导学生们回忆并分享他们生活中的重要“第一次”,这些初次体验可能包括第一次做饭、竞选班干部、走夜路、表演、得奖等...

Global site tag (gtag.js) - Google Analytics