【轉載】Tomcat GC參數詳解 - 滄海一述苦笑天

原文地址 http://www.cnblogs.com/mockitobuilder/p/3754509.html

tomcat啟動參數,將JVM GC信息寫入tomcat_gc.log
CATALINA_OPTS='-Xms512m -Xmx4096m -XX:PermSize=64M -XX:MaxNewSize=128m -XX:MaxPermSize=64m -XX:ParallelGCThreads=8 -XX:+UseConcMarkSweepGC -Xloggc:/var/log/search/tomcat_gc.log'
各個參數含義,以及GC機制,參考下文:
一、相關概念
基本回收算法

  1. **引用計數(** **Reference Counting** **)** ** ** ** ** 比較古老的回收算法。原理是此對象有一個引用,即增加一個計數,刪除一個引用則減少一個計數。垃圾回收時,只用收集計數為0的對象。此算法最致命的是無法處理循環引用的問題。
    
  2. **標記** **-** **清除(** **Mark-Sweep** **)** ** ** ** ** 此算法執行分兩階段。第一階段從引用根節點開始標記所有被引用的對象,第二階段遍歷整個堆,把未標記的對象清除。此算法需要暫停整個應用,同時,會產生內存碎片。
    
  3. **復制(** **Copying** **)** ** ** ** ** 此 算法把內存空間劃為兩個相等的區域,每次只使用其中一個區域。垃圾回收時,遍歷當前使用區域,把正在使用中的對象復制到另外一個區域中。次算法每次只處理 正在使用中的對象,因此復制成本比較小,同時復制過去以后還能進行相應的內存整理,不過出現“碎片”問題。當然,此算法的缺點也是很明顯的,就是需要兩倍 內存空間。
    
  4. **標記** **-** **整理(** **Mark-Compact** **)** ** ** ** ** 此算法結合了“標記-清除”和“復 制”兩個算法的優點。也是分兩階段,第一階段從根節點開始標記所有被引用對象,第二階段遍歷整個堆,把清除未標記對象并且把存活對象“壓縮”到堆的其中一 塊,按順序排放。此算法避免了“標記-清除”的碎片問題,同時也避免了“復制”算法的空間問題。
    
  5. **增量收集(** **Incremental Collecting** **)**  實施垃圾回收算法,即:在應用進行的同時進行垃圾回收。不知道什么原因JDK5.0中的收集器沒有使用這種算法的。
    
  6. **分代(** **Generational Collecting** **)** ** ** ** ** 基于對對象生命周期分析后得出的垃圾回收算法。把對象分為年青代、年老代、持久代,對不同生命周期的對象使用不同的算法(上述方式中的一個)進行回收。現在的垃圾回收器(從J2SE1.2開始)都是使用此算法的。
    

分代垃圾回收詳述

  1. **Young** **(年輕代)** ** ** ** ** 年 輕代分三個區。一個Eden區,兩個Survivor區。大部分對象在Eden區中生成。當Eden區滿時,還存活的對象將被復制到Survivor區 (兩個中的一個),當這個Survivor區滿時,此區的存活對象將被復制到另外一個Survivor區,當這個Survivor去也滿了的時候,從第一 個Survivor區復制過來的并且此時還存活的對象,將被復制“年老區(Tenured)”。需要注意,Survivor的兩個區是對稱的,沒先后關 系,所以同一個區中可能同時存在從Eden復制過來 對象,和從前一個Survivor復制過來的對象,而復制到年老區的只有從第一個Survivor去過來的對象。而且,Survivor區總有一個是空 的。
    
  2. **Tenured** **(年老代)** ** ** ** ** 年老代存放從年輕代存活的對象。一般來說年老代存放的都是生命期較長的對象。
    
  3. **Perm** **(持久代)** ** ** ** ** 用 于存放靜態文件,如今Java類、方法等。持久代對垃圾回收沒有顯著影響,但是有些應用可能動態生成或者調用一些class,例如Hibernate等, 在這種時候需要設置一個比較大的持久代空間來存放這些運行過程中新增的類。持久代大小通過-XX:MaxPermSize=進行設置。
    

GC 類型 ** ** ** ** GC有兩種類型: Scavenge GC Full GC

  1. Scavenge GC 一般情況下,當新對象生成,并且在Eden申請空間失敗時,就好觸發Scavenge GC,堆Eden區域進行GC,清除非存活對象,并且把尚且存活的對象移動到Survivor區。然后整理Survivor的兩個區。
  2. Full GC 對整個堆進行整理,包括Young、Tenured和Perm。Full GC比Scavenge GC要慢,因此應該盡可能減少Full GC。有如下原因可能導致Full GC:
    o Tenured被寫滿
    o Perm域被寫滿
    o System.gc()被顯示調用
    o 上一次GC之后Heap的各域分配策略動態變化
    二、垃圾回收器
    目前的收集器主要有三種: 串行收集器、并行收集器、并發收集器
  3. **串行收集器**  使用單線程處理所有垃圾回收工作,因為無需多線程交互,所以效率比較高。但是,也無法使用多處理器的優勢,所以此收集器適合單處理器機器。當然,此收集器也可以用在小數據量( **100M** 左右)情況下的多處理器機器上。可以使用 **-XX:+UseSerialGC** 打開。
    
  4. **并行收集器** 
    
  5. 對年輕代進行并行垃圾回收,因此可以減少垃圾回收時間。一般在多線程多處理器機器上使用。使用 -XX:+UseParallelGC .打開。并行收集器在J2SE5.0第六6更新上引入,在Java SE6.0中進行了增強--可以堆年老代進行并行收集。 如果年老代不使用并發收集的話,是使用單線程進行垃圾回收 ,因此會制約擴展能力。使用 -XX:+UseParallelOldGC 打開。
  6. 使用 -XX:ParallelGCThreads= 設置并行垃圾回收的線程數。 此值可以設置與機器處理器數量相等
  7. 此收集器可以進行如下配置:
    § 最大垃圾回收暫停 : 指定垃圾回收時的最長暫停時間,通過 -XX:MaxGCPauseMillis= 指定。為毫秒.如果指定了此值的話, 堆大小和垃圾回收相關參數會進行調整以達到指定值 。設定此值可能會減少應用的吞吐量。
    § 吞吐量 : 吞吐量為 垃圾回收時間與非垃圾回收時間的比值 ,通過 -XX:GCTimeRatio= 來設定,公式為 1/ 1+N 。例如,-XX:GCTimeRatio=19時,表示5%的時間用于垃圾回收。默認情況為99,即1%的時間用于垃圾回收。
  8. **并發收集器** ** ** ** ** 可以保證大部分工作都并發進行(應用不停止),垃圾回收只暫停很少的時間,此收集器適合對響應時間要求比較高的中、大規模應用。使用 **-XX:+UseConcMarkSweepGC** 打開。
    
  9. 并 發收集器主要減少年老代的暫停時間,他在應用不停止的情況下使用獨立的垃圾回收線程,跟蹤可達對象。在每個年老代垃圾回收周期中,在收集初期并發收集器會 對整個應用進行簡短的暫停,在收集中還會再暫停一次。第二次暫停會比第一次稍長,在此過程中多個線程同時進行垃圾回收工作。
  10. 并發收集器使用 處理器換來短暫的停頓時間 。在一個N個處理器的系統上,并發收集部分使用 K/N 個可用處理器進行回收,一般情況下 1<=K<=N/4
  11. 在只有 一個處理器的主機上使用并發收集器 ,設置為 incremental mode 模式也可獲得較短的停頓時間。
  12. **浮動垃圾** :由于在應用運行的同時進行垃圾回收,所以有些垃圾可能在垃圾回收進行完成時產生,這樣就造成了“Floating Garbage”,這些垃圾需要在下次垃圾回收周期時才能回收掉。所以,并發收集器一般需要 **20%** 的預留空間用于這些浮動垃圾。
    
  13. **Concurrent Mode Failure** :并發收集器在應用運行時進行收集,所以需要保證堆在垃圾回收的這段時間有足夠的空間供程序使用,否則,垃圾回收還未完成,堆空間先滿了。這種情況下將會發生“并發模式失敗”,此時整個應用將會暫停,進行垃圾回收。
    
  14. **啟動并發收集器** :因為并發收集在應用運行時進行收集,所以必須保證收集完成之前有足夠的內存空間供程序使用,否則會出現“Concurrent Mode Failure”。通過設置 **-XX:CMSInitiatingOccupancyFraction=** 指定還有多少剩余堆時開始執行并發收集
    
  15. **小結** 
    

o 串行處理器: --適用情況:數據量比較小(100M左右);單處理器下并且對響應時間無要求的應用。 --缺點:只能用于小型應用
o 并行處理器: --適用情況:“對吞吐量有高要求”,多CPU、對應用響應時間無要求的中、大型應用。舉例:后臺處理、科學計算。 --缺點:應用響應時間可能較長
o 并發處理器: ** ** ** ** --適用情況:“對響應時間有高要求”,多CPU、對應用響應時間有較高要求的中、大型應用。舉例:Web服務器/應用服務器、電信交換、集成開發環境。
三、常見配置舉例

  1. **堆大小設置** ** ** ** ** JVM 中最大堆大小有三方面限制:相關操作系統的數據模型(32-bt還是64-bit)限制;系統的可用虛擬內存限制;系統的可用物理內存限制。32位系統 下,一般限制在1.5G~2G;64為操作系統對內存無限制。我在Windows Server 2003 系統,3.5G物理內存,JDK5.0下測試,最大可設置為1478m。 **典型設置:** 
    

o java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -Xmx3550m :設置JVM最大可用內存為3550M。 -Xms3550m :設置JVM促使內存為3550m。此值可以設置與-Xmx相同,以避免每次垃圾回收完成后JVM重新分配內存。 -Xmn2g :設置年輕代大小為2G。 整個堆大小=年輕代大小 + 年老代大小 + 持久代大小 。持久代一般固定大小為64m,所以增大年輕代后,將會減小年老代大小。此值對系統性能影響較大,Sun官方推薦配置為整個堆的3/8。 -Xss128k : 設置每個線程的堆棧大小。JDK5.0以后每個線程堆棧大小為1M,以前每個線程堆棧大小為256K。更具應用的線程所需內存大小進行調整。在相同物理內 存下,減小這個值能生成更多的線程。但是操作系統對一個進程內的線程數還是有限制的,不能無限生成,經驗值在3000~5000左右。
o java -Xmx3550m -Xms3550m -Xss128k -XX:NewRatio=4 -XX:SurvivorRatio=4 -XX:MaxPermSize=16m -XX:MaxTenuringThreshold=0 -XX:NewRatio=4 :設置年輕代(包括Eden和兩個Survivor區)與年老代的比值(除去持久代)。設置為4,則年輕代與年老代所占比值為1:4,年輕代占整個堆棧的1/5 -XX:SurvivorRatio=4 :設置年輕代中Eden區與Survivor區的大小比值。設置為4,則兩個Survivor區與一個Eden區的比值為2:4,一個Survivor區占整個年輕代的1/6 -XX:MaxPermSize=16m :設置持久代大小為16m。 -XX:MaxTenuringThreshold=0 :設置垃圾最大年齡。 如果設置為0的話,則年輕代對象不經過Survivor區,直接進入年老代 。對于年老代比較多的應用,可以提高效率。 如果將此值設置為一個較大值,則年輕代對象會在Survivor區進行多次復制,這樣可以增加對象再年輕代的存活時間 ,增加在年輕代即被回收的概論。

  1. **回收器選擇** ** ** ** ** JVM給了三種選擇: **串行收集器、并行收集器、并發收集器** ,但是串行收集器只適用于小數據量的情況,所以這里的選擇主要針對并行收集器和并發收集器。默認情況下,JDK5.0以前都是使用串行收集器,如果想使用其他收集器需要在啟動時加入相應參數。JDK5.0以后,JVM會根據當前 [系統配置](http://java.sun.com/j2se/1.5.0/docs/guide/vm/server-class.html) 進行判斷。
    
  2. **吞吐量優先** 的并行收集器 如上文所述,并行收集器主要以到達一定的吞吐量為目標,適用于科學技術和后臺處理等。 **典型配置** :
    

§ java -Xmx3800m -Xms3800m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20 -XX:+UseParallelGC :選擇垃圾收集器為并行收集器。 此配置僅對年輕代有效。即上述配置下,年輕代使用并發收集,而年老代仍舊使用串行收集。 -XX:ParallelGCThreads=20 :配置并行收集器的線程數,即:同時多少個線程一起進行垃圾回收。此值最好配置與處理器數目相等。
§ java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20 ** -XX:+UseParallelOldGC -XX:+UseParallelOldGC ** :配置年老代垃圾收集方式為并行收集。JDK6.0支持對年老代并行收集。
§ java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC ** -XX:MaxGCPauseMillis=100 -XX:MaxGCPauseMillis=100: ** 設置每次年輕代垃圾回收的最長時間,如果無法滿足此時間,JVM會自動調整年輕代大小,以滿足此值。
§ java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:MaxGCPauseMillis=100 **-XX:+UseAdaptiveSizePolicy ** ** ** -XX:+UseAdaptiveSizePolicy :設置此選項后,并行收集器會自動選擇年輕代區大小和相應的Survivor區比例,以達到目標系統規定的最低相應時間或者收集頻率等,此值建議使用并行收集器時,一直打開。

  1. **響應時間優先** 的并發收集器 如上文所述,并發收集器主要是保證系統的響應時間,減少垃圾收集時的停頓時間。適用于應用服務器、電信領域等。 **典型配置** :
    

§ java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:ParallelGCThreads=20 ** -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:+UseConcMarkSweepGC ** :設置年老代為并發收集。測試中配置這個以后,-XX:NewRatio=4的配置失效了,原因不明。所以,此時年輕代大小最好用-Xmn設置。 -XX:+UseParNewGC :設置年輕代為并行收集。可與CMS收集同時使用。JDK5.0以上,JVM會根據系統配置自行設置,所以無需再設置此值。
§ java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseConcMarkSweepGC **-XX:CMSFullGCsBeforeCompaction=5 ** -XX:+UseCMSCompactAtFullCollection -XX:CMSFullGCsBeforeCompaction :由于并發收集器不對內存空間進行壓縮、整理,所以運行一段時間以后會產生“碎片”,使得運行效率降低。此值設置運行多少次GC以后對內存空間進行壓縮、整理。 -XX:+UseCMSCompactAtFullCollection :打開對年老代的壓縮。可能會影響性能,但是可以消除碎片
輔助信息 ** ** ** ** JVM提供了大量命令行參數,打印信息,供調試使用。主要有以下一些:
o -XX:+PrintGC ** ** ** 輸出形式 [GC 118250K->113543K(130112K), 0.0094143 secs]
** [Full GC 121376K->10414K(130112K), 0.0650971 secs]

o **-XX:+PrintGCDetails ** ** ** 輸出形式 [GC [DefNew: 8614K->781K(9088K), 0.0123035 secs] 118250K->113543K(130112K), 0.0124633 secs]
[GC [DefNew: 8614K->8614K(9088K), 0.0000665 secs][Tenured: 112761K->10414K(121024K), 0.0433488 secs] 121376K->10414K(130112K), 0.0436268 secs]
o -XX:+PrintGCTimeStamps -XX:+PrintGC:PrintGCTimeStamps可與上面兩個混合使用 輸出形式: 11.851: [GC 98328K->93620K(130112K), 0.0082960 secs]
o -XX:+PrintGCApplicationConcurrentTime: 打印每次垃圾回收前,程序未中斷的執行時間。可與上面混合使用 輸出形式: Application time: 0.5291524 seconds
o -XX:+PrintGCApplicationStoppedTime :打印垃圾回收期間程序暫停的時間。可與上面混合使用 輸出形式: Total time for which application threads were stopped: 0.0468229 seconds
o -XX:PrintHeapAtGC :打印GC前后的詳細堆棧信息 輸出形式: 34.702: [GC {Heap before gc invocations=7: def new generation total 55296K, used 52568K [0x1ebd0000, 0x227d0000, 0x227d0000) eden space 49152K, 99% used [0x1ebd0000, 0x21bce430, 0x21bd0000) from space 6144K, 55% used [0x221d0000, 0x22527e10, 0x227d0000) to space 6144K, 0% used [0x21bd0000, 0x21bd0000, 0x221d0000) tenured generation total 69632K, used 2696K [0x227d0000, 0x26bd0000, 0x26bd0000) the space 69632K, 3% used [0x227d0000, 0x22a720f8, 0x22a72200, 0x26bd0000) compacting perm gen total 8192K, used 2898K [0x26bd0000, 0x273d0000, 0x2abd0000) the space 8192K, 35% used [0x26bd0000, 0x26ea4ba8, 0x26ea4c00, 0x273d0000) ro space 8192K, 66% used [0x2abd0000, 0x2b12bcc0, 0x2b12be00, 0x2b3d0000) rw space 12288K, 46% used [0x2b3d0000, 0x2b972060, 0x2b972200, 0x2bfd0000) 34.735: [DefNew: 52568K->3433K(55296K), 0.0072126 secs] 55264K->6615K(124928K) **Heap after gc invocations=8: ** ** ** def new generation total 55296K, used 3433K [0x1ebd0000, 0x227d0000, 0x227d0000) eden space 49152K, 0% used [0x1ebd0000, 0x1ebd0000, 0x21bd0000) from space 6144K, 55% used [0x21bd0000, 0x21f2a5e8, 0x221d0000) to space 6144K, 0% used [0x221d0000, 0x221d0000, 0x227d0000) tenured generation total 69632K, used 3182K [0x227d0000, 0x26bd0000, 0x26bd0000) **the space 69632K, 4% used ** [0x227d0000, 0x22aeb958, 0x22aeba00, 0x26bd0000) compacting perm gen total 8192K, used 2898K [0x26bd0000, 0x273d0000, 0x2abd0000) the space 8192K, 35% used [0x26bd0000, 0x26ea4ba8, 0x26ea4c00, 0x273d0000) ro space 8192K, 66% used [0x2abd0000, 0x2b12bcc0, 0x2b12be00, 0x2b3d0000) rw space 12288K, 46% used [0x2b3d0000, 0x2b972060, 0x2b972200, 0x2bfd0000) } , 0.0757599 secs]
o -Xloggc:filename :與上面幾個配合使用,把相關日志信息記錄到文件以便分析。
常見配置匯總

  1. 堆設置
    § -Xms :初始堆大小
    § -Xmx :最大堆大小
    § -XX:NewSize=n :設置年輕代大小
    § -XX:NewRatio=n: 設置年輕代和年老代的比值。如:為3,表示年輕代與年老代比值為1:3,年輕代占整個年輕代年老代和的1/4
    § -XX:SurvivorRatio=n :年輕代中Eden區與兩個Survivor區的比值。注意Survivor區有兩個。如:3,表示Eden:Survivor=3:2,一個Survivor區占整個年輕代的1/5
    § -XX:MaxPermSize=n :設置持久代大小
  2. 收集器設置
    § -XX:+UseSerialGC :設置串行收集器
    § -XX:+UseParallelGC :設置并行收集器
    § -XX:+UseParalledlOldGC :設置并行年老代收集器
    § -XX:+UseConcMarkSweepGC :設置并發收集器
  3. 垃圾回收統計信息
    § -XX:+PrintGC
    § -XX:+PrintGCDetails
    § -XX:+PrintGCTimeStamps
    § -Xloggc:filename
  4. 并行收集器設置
    § -XX:ParallelGCThreads=n :設置并行收集器收集時使用的CPU數。并行收集線程數。
    § -XX:MaxGCPauseMillis=n :設置并行收集最大暫停時間
    § -XX:GCTimeRatio=n :設置垃圾回收時間占程序運行時間的百分比。公式為1/(1+n)
  5. 并發收集器設置
    § -XX:+CMSIncrementalMode :設置為增量模式。適用于單CPU情況。
    § -XX:ParallelGCThreads=n :設置并發收集器年輕代收集方式為并行收集時,使用的CPU數。并行收集線程數。
    四、調優總結
  6. **年輕代大小選擇** 
    

o 響應時間優先的應用盡可能設大,直到接近系統的最低響應時間限制 (根據實際情況選擇)。在此種情況下,年輕代收集發生的頻率也是最小的。同時,減少到達年老代的對象。
o 吞吐量優先的應用 :盡可能的設置大,可能到達Gbit的程度。因為對響應時間沒有要求,垃圾收集可以并行進行,一般適合8CPU以上的應用。

  1. **年老代大小選擇** 
    

o 響應時間優先的應用 :年老代使用并發收集器,所以其大小需要小心設置,一般要考慮 并發會話率會話持續時間 等一些參數。如果堆設置小了,可以會造成內存碎片、高回收頻率以及應用暫停而使用傳統的標記清除方式;如果堆大了,則需要較長的收集時間。最優化的方案,一般需要參考以下數據獲得:
§ 并發垃圾收集信息
§ 持久代并發收集次數
§ 傳統GC信息
§ 花在年輕代和年老代回收上的時間比例
減少年輕代和年老代花費的時間,一般會提高應用的效率
o 吞吐量優先的應用 :一般吞吐量優先的應用都有一個很大的年輕代和一個較小的年老代。原因是,這樣可以盡可能回收掉大部分短期對象,減少中期的對象,而年老代盡存放長期存活對象。

  1. **較小堆引起的碎片問題** ** ** ** ** 因 為年老代的并發收集器使用標記、清除算法,所以不會對堆進行壓縮。當收集器回收時,他會把相鄰的空間進行合并,這樣可以分配給較大的對象。但是,當堆空間 較小時,運行一段時間以后,就會出現“碎片”,如果并發收集器找不到足夠的空間,那么并發收集器將會停止,然后使用傳統的標記、清除方式進行回收。如果出 現“碎片”,可能需要進行如下配置:
    

o -XX:+UseCMSCompactAtFullCollection :使用并發收集器時,開啟對年老代的壓縮。
o -XX:CMSFullGCsBeforeCompaction=0 :上面配置開啟的情況下,這里設置多少次Full GC后,對年老代進行壓縮
五、參考文獻
Java 理論與實踐: 垃圾收集簡史
Java SE 6 HotSpot[tm] Virtual Machine Garbage Collection Tuning
Improving Java Application Performance and Scalability by Reducing Garbage Collection Times and Sizing Memory Using JDK 1.4.1
Hotspot memory management whitepaper
Java Tuning White Paper
Diagnosing a Garbage Collection problem
Java HotSpot VM Options
A Collection of JVM Options
Frequently Asked Questions about Garbage Collection in the HotspotTM JavaTM Virtual Machine

Java虛擬機參數 -XX等相關參數應用
通常,我們為了避免內存溢出等問題,需要設置環境變量JAVA_OPTS -Xms256M -Xmx512M 等,【對于服務器,一般都設置成一樣的】但是有的時候可能這樣的設置還會不行(比如,當Server應用程序加載較多類時,即jvm加載類時,永久域中的對象急劇增加,從而使jvm不斷調整永久域大小,為了避免調整),你可以使用更多的參數配置,如: java -Xms512m -Xmx512m -XX:PermSize=64m -XX:MaxPermSize=128m其中,使用 -XX:MaxPerSize標志來增加永久域的大小,-XX:PerSize標志設置初始值-XX 基于 Sun 的 Java 2 Standard Edition(J2SE)5 有生成垃圾回收功能,這允許分隔內存池以包含不同時效的對象。垃圾回收循環根據時效收集與其他對象彼此獨立的對象。使用其他參數,您可以單獨設置內存池的 大小。為了實現更好的性能,您應該對包含短期存活對象的池的大小進行設置,以使該池中的對象的存活時間不會超過一個垃圾回收循環。新生成的池的大小由 NewSize
和 MaxNewSize
參數確定。
第一次垃圾回收循環中存活下來的對象轉移到另一個池中。生還者池的大小由參數 SurvivorRatio
確定。 如果垃圾回收變成了瓶頸,您可以嘗試定制生成池設置。要監控垃圾回收統計信息,使用 Tivoli Performance Viewer 中的對象統計信息或 verbose:gc 配置設置。 輸入下列值:-XX:NewSize (lower bound)
-XX:MaxNewSize (upper bound)
-XX:SurvivorRatio=NewRatioSize
-XX:NewSize 320m 此值設大可調大新對象區,減少Full GC次數-XX:userParNewGC 可用來設置并行收集【多CPU】-XX:ParallelGCThreads 可用來增加并行度【多CPU】-XXUseParallelGC 設置后可以使用并行清除收集器【多CPU】下面的命令把整個堆設置成128m,新域比率設置成3,即新域與舊域比例為1:3,新域為堆的1/4或32M:java –Xms128m –Xmx128m –XX:NewRatio =3缺省值為:NewSize=2m MaxNewSize=32m SurvivorRatio=2
。但是,如果 JVM 的堆大小大于 1GB,則應該使用值:-XX:newSize=640m -XX:MaxNewSize=640m -XX:SurvivorRatio=16
,或者將堆的總大小的 50% 到 60% 分配給新生成的池。
舉例:永久域默認大小為4m。運行程序時,jvm會調整永久域的大小以滿足需要。每次調整時,jvm會對堆進行一次完全的垃圾收集。 使用-XX:MaxPerSize標志來增加永久域的大小。在WebLogic Server應用程序加載較多類時,經常需要增加永久域的最大值。當jvm加載類時,永久域中的對象急劇增加,從而使jvm不斷調整永久域大小。為了避免 調整,可使用-XX:PerSize標志設置初始值。 下面把永久域初始值設置成32m,最大值設置成64m。 java -Xms512m -Xmx512m -Xmn128m -XX:PermSize=32m -XX:MaxPermSize=64m默認狀態下,HotSpot在新域中使用復制收集器。該域一般分為三個部分。第一部分為Eden,用于生成新的對象。另兩部分稱為救助空間,當Eden充 滿時,收集器停止應用程序,把所有可到達對象復制到當前的from救助空間,一旦當前的from救助空間充滿,收集器則把可到達對象復制到當前的to救助 空間。From和to救助空間互換角色。維持活動的對象將在救助空間不斷復制,直到它們獲得使用期并轉入舊域。使用-XX:SurvivorRatio可 控制新域子空間的大小。目前,我的的開發環境 2G內存,tomcat+eclipse 大型應用程序java -Xmx1024m -XX:PermSize=512m 基本就ok大部分應用了

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 轉自別人的博客http://www.cnblogs.com/mockitobuilder/p/3754509.ht...
    JaeGwen閱讀 750評論 0 1
  • 原文閱讀 前言 這段時間懈怠了,罪過! 最近看到有同事也開始用上了微信公眾號寫博客了,挺好的~給他們點贊,這博客我...
    碼農戲碼閱讀 6,025評論 2 31
  • Java 虛擬機有自己完善的硬件架構, 如處理器、堆棧、寄存器等,還具有相應的指令系統。JVM 屏蔽了與具體操作系...
    尹小凱閱讀 1,707評論 0 10
  • 1.一些概念 1.1.數據類型 Java虛擬機中,數據類型可以分為兩類:基本類型和引用類型。基本類型的變量保存原始...
    落落落落大大方方閱讀 4,576評論 4 86
  • 1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虛擬機(JVM)垃圾回收器提供...
    簡欲明心閱讀 89,887評論 17 311