JVM內(nèi)存相關(guān)總結(jié)

JVM大體結(jié)構(gòu)圖

運(yùn)行時(shí)數(shù)據(jù)區(qū)

  • 線程隔離數(shù)據(jù)區(qū)
    • 程序計(jì)算器
      • 當(dāng)前線程執(zhí)行字節(jié)碼的行號(hào)指示器
      • 如分支、循環(huán)抄罕、跳轉(zhuǎn)、異常處理于颖、線程恢復(fù)等
    • 虛擬機(jī)棧
      • 棧幀存儲(chǔ)區(qū)域呆贿,棧幀包含局部變量、操作數(shù)棧森渐、動(dòng)態(tài)鏈接做入、方法出口等
      • 異常情況,StackOverflowError同衣、OutOfMemoryError
    • 本地方法棧
      • JNI服務(wù)使用的棧竟块,作用于本地方法(C/C++)
  • 線程共享數(shù)據(jù)區(qū)
    • Java堆
      • 存儲(chǔ)對(duì)象實(shí)例
      • 異常情況, OutOfMemoryError耐齐、內(nèi)存泄漏
    • 方法區(qū)
      • 存儲(chǔ)加載的類信息彩郊、常量、靜態(tài)變量蚪缀、JIT編譯后的代碼等數(shù)據(jù)
      • 異常情況,OutOfMemoryError
      • 運(yùn)行時(shí)常量池恕出,字面量询枚、符號(hào)引用

對(duì)象創(chuàng)建與回收過(guò)程

JVM垃圾收集算法

復(fù)制

  • 內(nèi)存分成大小相等的兩塊,每次使用其中一塊浙巫,回收的時(shí)候金蜀,把存活的對(duì)象復(fù)制到另一塊刷后,然后把這塊內(nèi)存整個(gè)清理掉
  • 優(yōu)點(diǎn),回收效率提高渊抄、不存在碎片化
  • 缺點(diǎn)尝胆,內(nèi)存利用率低
  • 解決,采用非對(duì)稱法护桦,eden:survivor = 8:1

標(biāo)記清除

  • 標(biāo)記階段含衔,確定所有要回收的對(duì)象,做標(biāo)記
  • 清除階段二庵,將標(biāo)記階段確定的回收對(duì)象進(jìn)行清除
  • 優(yōu)點(diǎn)贪染,簡(jiǎn)單,最基礎(chǔ)算法
  • 缺點(diǎn)催享,效率低杭隙,碎片化


標(biāo)記整理

  • 把存活對(duì)象移動(dòng)到內(nèi)存的一端,然后直接回收邊界以外的內(nèi)存
  • 場(chǎng)景,適合老年代存活對(duì)象較多的情況因妙,減少內(nèi)存復(fù)制量

垃圾收集器

Serial/SerialOld

  • 過(guò)程
    1. 收集GC_ROOTS
    2. 對(duì)象可達(dá)性分析
    3. 標(biāo)記垃圾對(duì)象
    4. 清理垃圾對(duì)象
  • 優(yōu)點(diǎn)痰憎,簡(jiǎn)單高效
  • 缺點(diǎn),STW攀涵,服務(wù)停頓時(shí)間長(zhǎng)
  • 場(chǎng)景铣耘,幾百兆以內(nèi)客戶端程序


Parnew/Parallel Scavenge/Parallel Old

Serial算法多線程版
  • 優(yōu)點(diǎn),多線程汁果,回收速度快
  • 缺點(diǎn)涡拘,依然會(huì)暫停服務(wù)
  • 場(chǎng)景,對(duì)響應(yīng)時(shí)間要求不高的Server端

ParNew與Parallel Scanvenge區(qū)別

  • Parnew關(guān)注回收速度据德,多線程減少單詞GC時(shí)間
  • Parallel Scanvenge關(guān)注吞吐量鳄乏,減少GC時(shí)間占比


CMS(Concurrent Mark Sweep)算法

  • 優(yōu)點(diǎn),并發(fā)棘利,暫停時(shí)間短
  • 缺點(diǎn)橱野,耗CPU、GC時(shí)間長(zhǎng)善玫,GC提前水援,浮動(dòng)垃圾,碎片化
  • 場(chǎng)景茅郎,對(duì)響應(yīng)時(shí)間敏感的Server服務(wù)蜗元,大部分線上服務(wù)應(yīng)該是CMS


G1垃圾回收器

  • 新一代垃圾回收算法
  • 場(chǎng)景,大內(nèi)存系冗、高響應(yīng)的服務(wù)端應(yīng)用


JVM工具集

JPS

  • 查看當(dāng)前用戶java進(jìn)程奕扣,類似于ps
  • -q 只輸出LVMID(與PID一致),省略主類的名稱
  • -m 輸出啟動(dòng)時(shí)傳遞給主類main函數(shù)的參數(shù)
  • -l 輸出主類的全名掌敬,如果是jar包惯豆,輸出jar路徑
  • -v 輸出啟動(dòng)時(shí)的jvm參數(shù)

jstack

  • 用于監(jiān)視虛擬機(jī)各種運(yùn)行狀態(tài)信息池磁,例如類裝載、內(nèi)存楷兽、垃圾收集地熄、 jit編譯等運(yùn)行參數(shù)
  • -class 監(jiān)視類裝載、卸載數(shù)量芯杀、總空間以及裝載所耗費(fèi)時(shí)間等
  • -gc 監(jiān)視java堆狀況端考,包括eden區(qū),survivor區(qū)瘪匿,老年代跛梗,永久代的容量、已用 空間和 GC時(shí)間等信息
  • -gcnew 監(jiān)視新生代GC狀況
  • -gcold 監(jiān)視老年代GC狀況
  • -compiler 輸出JIT編譯器編譯過(guò)的方法棋弥、耗時(shí)等信息

jmap

  • java內(nèi)存映像工具核偿,用于生成堆轉(zhuǎn)儲(chǔ)快照,即dump文件顽染,結(jié)合JHAT漾岳、MAT或者VisualVM等軟件 來(lái)分析java內(nèi)存的詳細(xì)使用情況,便于排查java內(nèi)存問(wèn)題
  • -dump 生成堆轉(zhuǎn)儲(chǔ)快照
  • -finalizerinfo 顯示在等待執(zhí)行finalize方法的對(duì)象
  • -heap 顯示java堆詳細(xì)信息粉寞,如使用的回收器尼荆、參數(shù)配置、分代狀況等
  • -histo 顯示堆中對(duì)象統(tǒng)計(jì)信息唧垦,包括類捅儒、實(shí)例數(shù)量、合計(jì)容量等
  • -permstat 以classloader為統(tǒng)計(jì)口徑顯示永久代內(nèi)存狀態(tài)
  • -F 強(qiáng)制生成堆轉(zhuǎn)出快照

參考

https://plumbr.io/handbook/what-is-garbage-collection

?著作權(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)容

  • 1.什么是垃圾回收泊愧? 垃圾回收(Garbage Collection)是Java虛擬機(jī)(JVM)垃圾回收器提供...
    簡(jiǎn)欲明心閱讀 89,501評(píng)論 17 311
  • JVM架構(gòu) 當(dāng)一個(gè)程序啟動(dòng)之前伊磺,它的class會(huì)被類裝載器裝入方法區(qū)(Permanent區(qū)),執(zhí)行引擎讀取方法區(qū)的...
    cocohaifang閱讀 1,666評(píng)論 0 7
  • 原文閱讀 前言 這段時(shí)間懈怠了删咱,罪過(guò)屑埋! 最近看到有同事也開(kāi)始用上了微信公眾號(hào)寫(xiě)博客了,挺好的~給他們點(diǎn)贊痰滋,這博客我...
    碼農(nóng)戲碼閱讀 5,972評(píng)論 2 31
  • 今天就要高考結(jié)束了摘能,這兩天在微博上看到好多高考生刷屏,一邊感嘆三年一晃而過(guò)敲街,一晃眼就要分開(kāi)团搞。一邊感嘆終于要結(jié)束了不...
    Amy丶未歸閱讀 277評(píng)論 2 3
  • 這幾天在外面跑,蘇州廣州南京多艇,很匆忙逻恐。所以這個(gè)打卡作業(yè)是兩天斷斷續(xù)續(xù)完成的。 暫時(shí)先畫(huà)了一張,離總量20張差得很遠(yuǎn)复隆。
    世界記憶大師程程閱讀 281評(píng)論 0 2