JVM性能調(diào)優(yōu)實(shí)戰(zhàn)——UseParallelGC

前言

在生產(chǎn)環(huán)境中甲捏,你是否遇到過(guò)這樣的問(wèn)題磕蛇?
1)系統(tǒng)運(yùn)行一段時(shí)間后old區(qū)空間正逐漸減少命锄?
2)遇到秒殺促銷(xiāo)活動(dòng)等場(chǎng)景old區(qū)存儲(chǔ)突然暴增钾唬,導(dǎo)致JVM Full GC万哪。fgc time持續(xù)過(guò)長(zhǎng)導(dǎo)致cpu 100%?
3)jvm eden區(qū)分配的內(nèi)存實(shí)際并沒(méi)有按照配置的指定抡秆?survivor區(qū)對(duì)象晉升到old區(qū)并沒(méi)有達(dá)到默認(rèn)的15次奕巍?
4)如何避免Full GC,JVM產(chǎn)生FGC后如何解決儒士?
……
接下來(lái)的內(nèi)容的止,我將從實(shí)際場(chǎng)景出發(fā),分別使用三種垃圾收集器:ParallelGC,Concurrent Mark Sweep(cms),G1着撩,進(jìn)行參數(shù)調(diào)優(yōu)诅福,解決我們?cè)谏a(chǎn)中jvm遇到的各種問(wèn)題。jvm調(diào)優(yōu)會(huì)作為專(zhuān)題持續(xù)更新拖叙。

以下GC調(diào)優(yōu)默認(rèn)使用jdk1.8

jdk1.8默認(rèn)使用ParallelGC氓润。新生代采用的是Parallel Scavenge,老年代Parallel Old薯鳍。
并發(fā)垃圾收集器調(diào)優(yōu)的內(nèi)容一般為:
1)關(guān)閉jvm自動(dòng)分配策略咖气。
2)survivior空間調(diào)優(yōu)。
通過(guò)這兩點(diǎn)調(diào)整,使創(chuàng)建的對(duì)象按照設(shè)定的閾值執(zhí)行崩溪。

  • 關(guān)閉JVM自動(dòng)分配策略

先來(lái)看默認(rèn)情況下jvm內(nèi)存空間的分配情況:

-server -Xms4G -Xmx4G -Xss512K -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/deploy_service_heap.log -verbose:gc -Xloggc:/deploy_service_gc.log

我們使用jdk1.8自帶的jvisualvm工具監(jiān)控查看運(yùn)行情況浅役,如圖:


ParallelGC默認(rèn)配置內(nèi)存分配

tips:對(duì)于并發(fā)類(lèi)型的GC來(lái)說(shuō),jvm默認(rèn)開(kāi)啟了內(nèi)存自動(dòng)適配策略參數(shù)是UseAdaptiveSizePolicy悯舟。使用-XX:-UseAdaptiveSizePolicy來(lái)關(guān)閉jvm的自動(dòng)適配策略担租。

  • survivior空間調(diào)優(yōu)

通常的網(wǎng)文會(huì)說(shuō)-XX:SurvivorRatio這個(gè)參數(shù)默認(rèn)為8,意思是eden:s1:s2 = 8:1:1抵怎。這個(gè)比值到底要不要改奋救,修改后效果就一定好嗎?答案是否定的反惕。舉例說(shuō)明:如果改成6(6:2:2)或者4(4:3:3)增加了survivor空間的同時(shí)縮減了eden區(qū)空間尝艘,這會(huì)導(dǎo)致eden區(qū)由于內(nèi)存分配不夠ygc的頻次增加,每ygc一次姿染,存活的對(duì)象就會(huì)進(jìn)入survivor,但實(shí)際情況是survivor中的對(duì)象會(huì)很少背亥,作者的應(yīng)用程序qps200~500之間,持續(xù)時(shí)間為24小時(shí)悬赏,但survivor中的對(duì)象總量最大不超過(guò)70M狡汉,所以擴(kuò)大survivor區(qū)空間是在浪費(fèi)資源。

survivor區(qū)真正要調(diào)整的是TargetSurvivorRatio,MaxTenuringThreshold這兩個(gè)參數(shù)闽颇。
TargetSurvivorRatio:表示目標(biāo)survivor區(qū)存儲(chǔ)率超過(guò)指定百分比時(shí)盾戴,會(huì)重新計(jì)算一次TenuringThreshold值。在生產(chǎn)中如果你遇到這種情況兵多,說(shuō)明需要調(diào)整TargetSurvivorRatio了尖啡。如圖:


jvm ParalleGC_4.png

圖中survivor區(qū)在每次ygc后都會(huì)重新計(jì)算一次threshold的值(默認(rèn)最大為15),說(shuō)明在survivor區(qū)中的對(duì)象并不都是經(jīng)過(guò)15次以上的ygc才進(jìn)入老年代剩膘。

tips:在并發(fā)類(lèi)型的GC中衅斩,-XX:-UseAdaptiveSizePolicy保證新生代內(nèi)存分配按照你指定的參數(shù)執(zhí)行。-XX:TargetSurvivorRatio=80 -XX:MaxTenuringThreshold=15 讓目標(biāo)survivor使用空間達(dá)到指定的百分比才會(huì)重新計(jì)算threshold值怠褐。如此一來(lái)畏梆,survivor中大部分的對(duì)象會(huì)活到15歲以上才進(jìn)入老年代。優(yōu)點(diǎn)是:阻止新對(duì)象快速進(jìn)入old區(qū)將其填滿(mǎn)奈懒,導(dǎo)致old區(qū)空間使用率100%而觸發(fā)full gc奠涌。

通過(guò)上述調(diào)整后,我們來(lái)看一下jvm運(yùn)行的效果:


jvm ParalleGC_2.png

我們看到eden區(qū)實(shí)際內(nèi)存分配為1.6G筐赔,survivor區(qū)為204.5M铣猩,并且survivor區(qū)內(nèi)的對(duì)象全部都在第16次ygc后進(jìn)入了old區(qū),這才是我們想要的效果茴丰!

另外補(bǔ)充說(shuō)明一下达皿,ParallelGC優(yōu)調(diào)當(dāng)然遠(yuǎn)不止這些天吓,比如還有一些協(xié)助參數(shù):-XX:+PrintTenuringDistribution 這個(gè)在jvm啟動(dòng)后每次進(jìn)行內(nèi)存分配可以打印出詳細(xì)的內(nèi)存分配情況。

以上是作者通過(guò)實(shí)際生產(chǎn)監(jiān)控發(fā)現(xiàn)的問(wèn)題峦椰,并整理出一些容易被我們忽略的問(wèn)題點(diǎn)龄寞。歡迎各位讀者評(píng)論區(qū)留言進(jìn)行經(jīng)驗(yàn)分享和探討。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末汤功,一起剝皮案震驚了整個(gè)濱河市物邑,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌滔金,老刑警劉巖色解,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異餐茵,居然都是意外死亡科阎,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)忿族,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)锣笨,“玉大人,你說(shuō)我怎么就攤上這事道批〈碛ⅲ” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵隆豹,是天一觀的道長(zhǎng)椭岩。 經(jīng)常有香客問(wèn)我,道長(zhǎng)噪伊,這世上最難降的妖魔是什么簿煌? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任氮唯,我火速辦了婚禮鉴吹,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘惩琉。我一直安慰自己豆励,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布瞒渠。 她就那樣靜靜地躺著良蒸,像睡著了一般。 火紅的嫁衣襯著肌膚如雪伍玖。 梳的紋絲不亂的頭發(fā)上嫩痰,一...
    開(kāi)封第一講書(shū)人閱讀 51,631評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音窍箍,去河邊找鬼串纺。 笑死丽旅,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的纺棺。 我是一名探鬼主播榄笙,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼祷蝌!你這毒婦竟也來(lái)了茅撞?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤巨朦,失蹤者是張志新(化名)和其女友劉穎米丘,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體糊啡,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蠕蚜,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了悔橄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片靶累。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖癣疟,靈堂內(nèi)的尸體忽然破棺而出挣柬,到底是詐尸還是另有隱情,我是刑警寧澤睛挚,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布邪蛔,位于F島的核電站,受9級(jí)特大地震影響扎狱,放射性物質(zhì)發(fā)生泄漏侧到。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一淤击、第九天 我趴在偏房一處隱蔽的房頂上張望匠抗。 院中可真熱鬧,春花似錦污抬、人聲如沸汞贸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)矢腻。三九已至,卻和暖如春射赛,著一層夾襖步出監(jiān)牢的瞬間多柑,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工楣责, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留竣灌,地道東北人诫隅。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像帐偎,于是被迫代替她去往敵國(guó)和親逐纬。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 轉(zhuǎn)載blog.csdn.net/ning109314/article/details/10411495/ JVM工...
    forever_smile閱讀 5,366評(píng)論 1 56
  • JVM架構(gòu) 當(dāng)一個(gè)程序啟動(dòng)之前削樊,它的class會(huì)被類(lèi)裝載器裝入方法區(qū)(Permanent區(qū))豁生,執(zhí)行引擎讀取方法區(qū)的...
    cocohaifang閱讀 1,666評(píng)論 0 7
  • 作者:一字馬胡 轉(zhuǎn)載標(biāo)志 【2017-11-12】 更新日志 日期更新內(nèi)容備注 2017-11-12新建文章初版 ...
    beneke閱讀 2,205評(píng)論 0 7
  • 堆內(nèi)存設(shè)置 原理 JVM堆內(nèi)存分為2塊:Permanent Space 和 Heap Space。 Permane...
    superxcp閱讀 2,004評(píng)論 0 0
  • jvm監(jiān)控與調(diào)優(yōu)之jdk命令行工具 目錄 jvm監(jiān)控與調(diào)優(yōu)之jdk命令行工具jvm的參數(shù)類(lèi)型標(biāo)準(zhǔn)參數(shù)X參數(shù)XX參數(shù)...
    jeffrey_hjf閱讀 439評(píng)論 0 1