午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

Java full gc觸發(fā)情況實例解析

瀏覽:17日期:2022-09-02 17:13:01

前言

近期被問及這個問題,在此記錄整理一下。

System.gc()方法的調(diào)用

此方法的調(diào)用是建議JVM進(jìn)行Full GC,雖然只是建議而非一定,但很多情況下它會觸發(fā) Full GC,從而增加Full GC的頻率,也即增加了間歇性停頓的次數(shù)。強烈影響系建議能不使用此方法就別使用,讓虛擬機自己去管理它的內(nèi)存,可通過通過-XX:+ DisableExplicitGC來禁止RMI調(diào)用System.gc。

老年代空間不足

老年代空間只有在新生代對象轉(zhuǎn)入及創(chuàng)建為大對象、大數(shù)組時才會出現(xiàn)不足的現(xiàn)象,當(dāng)執(zhí)行Full GC后空間仍然不足,則拋出如下錯誤:

java.lang.OutOfMemoryError: Java heap space

為避免以上兩種狀況引起的Full GC,調(diào)優(yōu)時應(yīng)盡量做到讓對象在Minor GC階段被回收、讓對象在新生代多存活一段時間及不要創(chuàng)建過大的對象及數(shù)組。

永生區(qū)空間不足

JVM規(guī)范中運行時數(shù)據(jù)區(qū)域中的方法區(qū),在HotSpot虛擬機中又被習(xí)慣稱為永生代或者永生區(qū),Permanet Generation中存放的為一些class的信息、常量、靜態(tài)變量等數(shù)據(jù),當(dāng)系統(tǒng)中要加載的類、反射的類和調(diào)用的方法較多時,Permanet Generation可能會被占滿,在未配置為采用CMS GC的情況下也會執(zhí)行Full GC。如果經(jīng)過Full GC仍然回收不了,那么JVM會拋出如下錯誤信息:java.lang.OutOfMemoryError: PermGen space為避免Perm Gen占滿造成Full GC現(xiàn)象,可采用的方法為增大Perm Gen空間或轉(zhuǎn)為使用CMS GC。

CMS GC時出現(xiàn)promotion failed和concurrent mode failure

對于采用CMS進(jìn)行老年代GC的程序而言,尤其要注意GC日志中是否有promotion failed和concurrent mode failure兩種狀況,當(dāng)這兩種狀況出現(xiàn)時可能會觸發(fā)Full GC。

promotion failed是在進(jìn)行Minor GC時,survivor space放不下、對象只能放入老年代,而此時老年代也放不下造成的;concurrent mode failure是在

執(zhí)行CMS GC的過程中同時有對象要放入老年代,而此時老年代空間不足造成的(有時候“空間不足”是CMS GC時當(dāng)前的浮動垃圾過多導(dǎo)致暫時性的空間不足觸發(fā)Full GC)。

對措施為:增大survivor space、老年代空間或調(diào)低觸發(fā)并發(fā)GC的比率,但在JDK 5.0+、6.0+的版本中有可能會由于JDK的bug29導(dǎo)致CMS在remark完畢后很久才觸發(fā)sweeping動作。對于這種狀況,可通過設(shè)置-XX: CMSMaxAbortablePrecleanTime=5(單位為ms)來避免。

統(tǒng)計得到的Minor GC晉升到舊生代的平均大小大于老年代的剩余空間這是一個較為復(fù)雜的觸發(fā)情況,Hotspot為了避免由于新生代對象晉升到舊生代導(dǎo)致舊生代空間不足的現(xiàn)象,在進(jìn)行Minor GC時,做了一個判斷,如果之前統(tǒng)計所得到的Minor GC晉升到舊生代的平均大小大于舊生代的剩余空間,那么就直接觸發(fā)Full GC。

例如程序第一次觸發(fā)Minor GC后,有6MB的對象晉升到舊生代,那么當(dāng)下一次Minor GC發(fā)生時,首先檢查舊生代的剩余空間是否大于6MB,如果小于6MB,則執(zhí)行Full GC。

當(dāng)新生代采用PS GC時,方式稍有不同,PS GC是在Minor GC后也會檢查,例如上面的例子中第一次Minor GC后,PS GC會檢查此時舊生代的剩余空間是否大于6MB,如小于,則觸發(fā)對舊生代的回收。

除了以上4種狀況外,對于使用RMI來進(jìn)行RPC或管理的Sun JDK應(yīng)用而言,默認(rèn)情況下會一小時執(zhí)行一次Full GC。可通過在啟動時通過- java -

Dsun.rmi.dgc.client.gcInterval=3600000來設(shè)置Full GC執(zhí)行的間隔時間或通過-XX:+ DisableExplicitGC來禁止RMI調(diào)用System.gc。

堆中分配很大的對象

所謂大對象,是指需要大量連續(xù)內(nèi)存空間的java對象,例如很長的數(shù)組,此種對象會直接進(jìn)入老年代,而老年代雖然有很大的剩余空間,但是無法找到足夠大的連續(xù)空間來分配給當(dāng)前對象,此種情況就會觸發(fā)JVM進(jìn)行Full GC。

為了解決這個問題,CMS垃圾收集器提供了一個可配置的參數(shù),即-XX:+UseCMSCompactAtFullCollection開關(guān)參數(shù),用于在“享受”完Full GC服務(wù)之后額外免費贈送一個碎片整理的過程,內(nèi)存整理的過程無法并發(fā)的,空間碎片問題沒有了,但提頓時間不得不變長了,JVM設(shè)計者們還提供了另外一個參數(shù) -XX:CMSFullGCsBeforeCompaction,這個參數(shù)用于設(shè)置在執(zhí)行多少次不壓縮的Full GC后,跟著來一次帶壓縮的。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 极品盗摄国产盗摄合集 | 免费91| aaa一区二区 | 九九热这里只有精品6 | 成人激情免费视频 | 可以看的毛片 | 岛国av免费观看 | 国产免费一区二区三区免费视频 | 欧美色图久久 | 综合中文字幕 | 丰满少妇高潮一区二区 | 宅男噜噜噜66一区二区 | 欧美特级黄色大片 | 免费激情片 | 久久久久久久999 | av在线播放国产 | 九九热这里只有精品6 | 久久久欧美 | 98久久| 欧美一区二区三区久久久 | 国产欧美精品 | 视频精品久久 | 色悠悠久久| 精品视频专区 | jizz日韩| 国产欧美日韩在线 | 国产精品一区在线免费观看 | 黑人巨大精品欧美一区二区 | 久久久美女视频 | 亚洲欧洲国产综合 | 岛国av片| 小柔的淫辱日记(h) 玖玖精品 | 亚洲欧美高清 | 日本精品久久久久 | 欧美日韩性 | av青娱乐| 黄色成人在线视频 | 国产精品爽爽久久 | 黄色成人免费视频 | 性生活短视频 | 91精品国产成人观看 |