JVM 調(diào)優(yōu)過程

-Xms 初始化堆大?。J(rèn)物理內(nèi)存1/64,根據(jù)實際需求)

-Xmx 最大堆大小

整個堆大小=年輕代+年老代+持久代

一? jvm新生代(young generation)

剛創(chuàng)建的java對象會分配新生代里面

1)年輕代= 1個e區(qū)+2個s區(qū)

2)-Xmn 年輕代大?。?.4之后版本 or lator)

3)-XX:NewRatio? (該參數(shù)一般不使用)

年輕代(e區(qū)和二個S區(qū))

4) -XX:SurvivorRatio

e區(qū)與s區(qū)的大小比值,設(shè)置為8 ,則二個s區(qū)與一個e區(qū)比例:2:8

5)

二? java 老年代

1) 老年代= 整個堆-年輕代-持久代

2)年輕代中經(jīng)過 垃圾回收沒有回收對象被復(fù)制到年老代,

3)老年代存儲對象比年輕代年齡大的多,而且不乏大對象。(文件,緩存,數(shù)組)

對于大對象,可通過啟動參數(shù)設(shè)置(-XX:PretenureSizeThreshold=1024)單位字節(jié)也就是1M,

默認(rèn)為0來代表超過多大就不在新生代分配。(建議不需要分配)

三? java 持久代(perm generation)

1) 持久代 = 整個堆 - 年輕代 - 老年代大小

2) -XX:PermSize -XX:MaxPermSize

設(shè)置持久代的大小,一般情況推薦把-XX:PermSize設(shè)置-XX:MaxPermSize相同,

因為持久代大小的調(diào)整也會導(dǎo)致堆內(nèi)存觸發(fā)一次Fgc

3)? 持久代里面存放Class,Methmod元信息,其大小與項目的規(guī)模,類,方法的數(shù)量有關(guān),

一般設(shè)置為128M就足夠,保留30%的空間。

4) 持久代的回收方式

常量池中的常量,無用的類信息,常量的回收很簡單,沒有引用就可以回收了

對于無用的類進(jìn)行回收,必須保證3點:

類的所有實例都已經(jīng)被回收

加載類的classLoader已經(jīng)被回收

jvm? 垃圾收集算法

1. 引用計數(shù)算法(已經(jīng)不用了,很早版本)

2. 根搜索算法

jvm 垃圾回收算法

1. 復(fù)制算法(copying)

abc三個對象,進(jìn)入e區(qū)的時候,把需要的復(fù)制到s0,s1區(qū),沒有被引用直接被回收了。(gcroot)根掃描

新生代中二個s0區(qū),就應(yīng)用到此場景

2.? 標(biāo)記清除算法(Mark-sweep)

適合老年代回收,不需要對象移動。

3.? 標(biāo)記整理壓縮算法(Mark-Compac)

對象進(jìn)行移動,會將存活的對象往左端,標(biāo)記整理標(biāo)記算法是在標(biāo)記清除算法的基礎(chǔ)上,又進(jìn)行對象移動,因此

成本更高,但是卻解決了內(nèi)存碎片的問題。

名詞解釋

1 . 串行回收

gc單線程內(nèi)存回收,會暫停所有用戶線程

2 .? 并行回收

收集是指多個GC線程并發(fā)工作,但此時用戶線程是暫停;所以,serial是串行的,

parallel收集是并行的,而CMS收集器是并發(fā)的。

3 . 并發(fā)回收

是指用戶線程與GC線程同時執(zhí)行(不一定是并行,可以交替,但總體同時執(zhí)行),不需要

要停頓用戶線程(其實在CMS中用戶線程還是需要停頓的,只是非常短,GC線程在另一個

CPU上執(zhí)行);

-XX:+UseConcMarkSweepGC 表示使用CMS

-XX:+CMSParallelRemarkEnabled 表示并行remark

-XX:+UseCMSCompactAtFullCollection 表示在FGC之后進(jìn)行壓縮,因為CMS默認(rèn)不壓縮空間的。

-XX:+UseCMSInitiatingOccupancyOnly 表示只在到達(dá)閥值的時候,才進(jìn)行CMS GC

-XX:CMSInitiatingOccupancyFraction=70 設(shè)置閥值為70%,默認(rèn)為68%。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1.一些概念 1.1.數(shù)據(jù)類型 Java虛擬機(jī)中,數(shù)據(jù)類型可以分為兩類:基本類型和引用類型?;绢愋偷淖兞勘4嬖?..
    落落落落大大方方閱讀 4,830評論 4 86
  • JVM架構(gòu) 當(dāng)一個程序啟動之前,它的class會被類裝載器裝入方法區(qū)(Permanent區(qū)),執(zhí)行引擎讀取方法區(qū)的...
    cocohaifang閱讀 1,852評論 0 7
  • 原文閱讀 前言 這段時間懈怠了,罪過! 最近看到有同事也開始用上了微信公眾號寫博客了,挺好的~給他們點贊,這博客我...
    碼農(nóng)戲碼閱讀 6,167評論 2 31
  • 參數(shù)設(shè)置 在Java虛擬機(jī)的參數(shù)中,有3種表示方法用“ps -ef |grep "java"命令,可以得到當(dāng)前Ja...
    九問閱讀 9,288評論 2 52
  • Java 虛擬機(jī)有自己完善的硬件架構(gòu), 如處理器、堆棧、寄存器等,還具有相應(yīng)的指令系統(tǒng)。JVM 屏蔽了與具體操作系...
    尹小凱閱讀 1,759評論 0 10

友情鏈接更多精彩內(nèi)容