国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
Resin 配置優(yōu)化

1.1. 堆大小設置

JVM 中最大堆大小有三方面限制:

相關操作系統(tǒng)的數(shù)據(jù)模型(32-bt還是64-bit)限制;

系統(tǒng)的可用虛擬內(nèi)存限制;

系統(tǒng)的可用物理內(nèi)存限制。

32位系統(tǒng)下,一般限制在1.5G~2G;64為操作系統(tǒng)對內(nèi)存無限制。

1.2. 典型設置:

java -Xmx3550m -Xms3550m -Xmn2g-Xss128k
-Xmx3550m:設置JVM最大可用內(nèi)存為3550M
-Xms3550m:設置JVM最小內(nèi)存為3550m。此值可以設置與-Xmx相同,以避免每次垃圾回收完成後JVM重新分配內(nèi)存。
-Xmn2g:設置年輕代大小為2G。整個JVM內(nèi)存大小=年輕代大小 年老代大小

所以增大年輕代後,將會減小年老代大小。此值對系統(tǒng)性能影響較大,Sun官方推薦配置為整個堆的3/8
-Xss128k:設置每個線程的堆棧大小。JDK5.0以後每個線程堆棧大小為1M,以前每個線程堆棧大小為256K。根據(jù)應用的線程所需內(nèi)存大小進行調(diào)整。在相同物理內(nèi)存下,減小這個值能生成更多的線程。但是操作系統(tǒng)對一個進程內(nèi)的線程數(shù)還是有限制的,不能無限生成,經(jīng)驗值在3000~5000左右。

java -Xmx3550m -Xms3550m -Xss128k -XX:NewRatio=4 -XX:SurvivorRatio=4 -XX:MaxPermSize=16m -XX:MaxTenuringThreshold=0
-XX:NewRatio=4:設置年輕代(包括Eden和兩個Survivor區(qū))與年老代的比值(除去持久代)。設置為4,則年輕代與年老代所占比值為14,年輕代占整個堆棧的1/5
-XX:SurvivorRatio=4:設置年輕代中Eden區(qū)與Survivor區(qū)的大小比值。設置為4,則兩個Survivor區(qū)與一個Eden區(qū)的比值為2:4,一個Survivor區(qū)占整個年輕代的1/6
-XX:MaxPermSize=16m:設置持久代大小為16m
-XX:MaxTenuringThreshold=0:設置垃圾最大年齡。如果設置為0的話,則年輕代對象不經(jīng)過Survivor區(qū),直接進入年老代。對於年老代比較多的應用,可以提高效率。如果將此值設置為一個較大值,則年輕代對象會在Survivor區(qū)進行多次複制,這樣可以增加對象年輕代的存活時間,增加在年輕代即被回收的概

1.3. 回收器選擇

JVM給了三種選擇:串行收集器、並行收集器、並發(fā)收集器,但是串行收集器只適用於小數(shù)據(jù)量的情況,所以這裏的選擇主要針對並行收集器和並發(fā)收集器。默認情況下,JDK5.0以前都是使用串行收集器,如果想使用其他收集器需要在啟動時加入相應參數(shù)。JDK5.0以後,JVM會根據(jù)當前系統(tǒng)配置進行判斷。 

1.3.1. 吞吐量優(yōu)先的並行收集器

如上文所述,並行收集器主要以到達一定的吞吐量為目標,適用於科學技術和後臺處理等。
典型配置: 

java -Xmx3800m -Xms3800m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20
-XX:+UseParallelGC:選擇垃圾收集器為並行收集器。此配置僅對年輕代有效。即上述配置下,年輕代使用並收集,而年老代仍舊使用串行收集。

-XX:ParallelGCThreads=20:配置並行收集器的線程數(shù),即:同時多少個線程一起進行垃圾回收。此值最好配置與處理器數(shù)目相等。

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會自動調(diào)整年輕代大小,以滿足此值。

java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC  -XX:MaxGCPauseMillis=100-XX:+UseAdaptiveSizePolicy
-XX:+UseAdaptiveSizePolicy:設置此選項後,並行收集器會自動選擇年輕代區(qū)大小和相應的Survivor區(qū)比例,以達到目標系統(tǒng)規(guī)定的最低相應時間或者收集頻率等,此值建議使用並行收集器時,一直打開。

1.3.2. 響應時間優(yōu)先的並發(fā)收集器

如上文所述,並發(fā)收集器主要是保證系統(tǒng)的響應時間,減少垃圾收集時的停頓時間。適用於應用服務器、電信領域等。
典型配置: 

java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:ParallelGCThreads=20-XX:+UseConcMarkSweepGC -XX:+UseParNewGC-XX:+UseConcMarkSweepGC:設置年老代為並發(fā)收集。測試中配置這個以後,-XX:NewRatio=4的配置失效了,原因不明。所以,此時年輕代大小最好用-Xmn設置。
-XX:+UseParNewGC:設置年輕代為並行收集??膳cCMS收集同時使用。JDK5.0以上,JVM會根據(jù)系統(tǒng)配置自行設置,所以無需再設置此值。

java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseConcMarkSweepGC-XX:CMSFullGCsBeforeCompaction=5-XX:+UseCMSCompactAtFullCollection
-XX:CMSFullGCsBeforeCompaction:由於並發(fā)收集器不對內(nèi)存空間進行壓縮、整理,所以運行一段時間以後會產(chǎn)生碎片,使得運行效率降低。此值設置運行多少次GC以後對內(nèi)存空間進行壓縮、整理。-XX:+UseCMSCompactAtFullCollection:打開對年老代的壓縮。可能會影響性能,但是可以消除碎片

輔助信息

JVM提供了大量命令行參數(shù),打印信息,供調(diào)試使用。主要有以下一些: 

-XX:+PrintGC輸出形式

[GC 118250K->113543K(130112K), 0.0094143 secs] 

[Full GC 121376K->10414K(130112K), 0.0650971 secs]

-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]

-XX:+PrintGCTimeStamps-XX:+PrintGCPrintGCTimeStamps可與上面兩個混合使用
輸出形式:11.851: [GC 98328K->93620K(130112K), 0.0082960 secs]

-XX:+PrintGCApplicationConcurrentTime:打印每次垃圾回收前,程序未中斷的執(zhí)行時間。可與上面混合使用
輸出形式:Application time: 0.5291524 seconds

-XX:+PrintGCApplicationStoppedTime:打印垃圾回收期間程序暫停的時間??膳c上面混合使用
輸出形式:Total time for which application threads were stopped: 0.0468229 seconds

-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]

-Xloggc:filename:與上面幾個配合使用,把相關日志信息記錄到文件以便分析。

常見配置匯總

堆設置 

§ -Xms:初始堆大小

§ -Xmx:最大堆大小

§ -XX:NewSize=n:設置年輕代大小

§ -XX:NewRatio=n:設置年輕代和年老代的比值。如:3,表示年輕代與年老代比值為13,年輕代占整個年輕代年老代和的1/4

§ -XX:SurvivorRatio=n:年輕代中Eden區(qū)與兩個Survivor區(qū)的比值。注意Survivor區(qū)有兩個。如:3,表示EdenSurvivor=32,一個Survivor區(qū)占整個年輕代的1/5

§ -XX:MaxPermSize=n:設置持久代大小

收集器設置 

§ -XX:+UseSerialGC:設置串行收集器

§ -XX:+UseParallelGC:設置並行收集器

§ -XX:+UseParalledlOldGC:設置並行年老代收集器

§ -XX:+UseConcMarkSweepGC:設置並發(fā)收集器

垃圾回收統(tǒng)計信息 

§ -XX:+PrintGC

§ -XX:+PrintGCDetails

§ -XX:+PrintGCTimeStamps

§ -Xloggc:filename

並行收集器設置 

§ -XX:ParallelGCThreads=n:設置並行收集器收集時使用的CPU數(shù)。並行收集線程數(shù)。

§ -XX:MaxGCPauseMillis=n:設置並行收集最大暫停時間

§ -XX:GCTimeRatio=n:設置垃圾回收時間占程序運行時間的百分比。公式為1/(1+n)

並發(fā)收集器設置 

§ -XX:+CMSIncrementalMode:設置為增量模式。適用於單CPU情況。

-XX:ParallelGCThreads=n:設置並發(fā)收集器年輕代收集方式為並行收集時,使用的CPU數(shù)。並行收集線程數(shù)。

1.4. 調(diào)優(yōu)總結(jié)

1.4.1. 年輕代大小選擇

響應時間優(yōu)先的應用盡可能設大,直到接近系統(tǒng)的最低響應時間限制(根據(jù)實際情況選擇)。在此種情況下,年輕代收集發(fā)生的頻率也是最小的。同時,減少到達年老代的對象。

吞吐量優(yōu)先的應用:盡可能的設置大,可能到達Gbit的程度。因為對響應時間沒有要求,垃圾收集可以並行進行,一般適合8CPU以上的應用。

1.4.2. 年老代大小選擇

響應時間優(yōu)先的應用

年老代使用並發(fā)收集器,所以其大小需要小心設置,一般要考慮並發(fā)會話率會話持續(xù)時間等一些參數(shù)。如果堆設置小了,可以會造成內(nèi)存碎片、高回收頻率以及應用暫停而使用傳統(tǒng)的標記清除方式;如果堆大了,則需要較長的收集時間。最優(yōu)化的方案,一般需要參考以下數(shù)據(jù)獲得: 

並發(fā)垃圾收集信息

持久代並發(fā)收集次數(shù)

傳統(tǒng)GC信息

花在年輕代和年老代回收上的時間比例

減少年輕代和年老代花費的時間,一般會提高應用的效率

吞吐量優(yōu)先的應用

一般吞吐量優(yōu)先的應用都有一個很大的年輕代和一個較小的年老代。原因是,這樣可以盡可能回收掉大部分短期對象,減少中期的對象,而年老代盡存放長期存活對象。

較小堆引起的碎片問題

因為年老代的並發(fā)收集器使用標記、清除算法,所以不會對堆進行壓縮。當收集器回收時,他會把相鄰的空間進行合並,這樣可以分配給較大的對象。但是,當堆空間較小時,運行一段時間以後,就會出現(xiàn)碎片,如果並發(fā)收集器找不到足夠的空間,那麼並發(fā)收集器將會停止,然後使用傳統(tǒng)的標記、清除方式進行回收。如果出現(xiàn)碎片,可能需要進行如下配置: 

-XX:+UseCMSCompactAtFullCollection:使用並發(fā)收集器時,開啟對年老代的壓縮。

-XX:CMSFullGCsBeforeCompaction=0:上面配置開啟的情況下,這裏設置多少次Full GC後,對年老代進行壓縮

2. Resin的調(diào)優(yōu)

要綜合考慮resin線程池大小、-XmxJVM最大可用內(nèi)存-Xms:初始堆大小、-XmnYoung Generationheap size參數(shù)互相匹配。(JVM2GC線程。第一個線程負責回收HeapYoung區(qū)。第二個線程在Heap不足時,遍曆Heap,將Young區(qū)升級為Older區(qū)。Older區(qū)的大小等於-Xmx減去-Xmn,不能將-Xms的值設的過大,因為第二個線程被迫運行會降低JVM的性能。)

來避免線上resin服務反複出現(xiàn)以下異常:

OutOfMemoryError Java heap space

OutOfMemoryError PermGen space

 

2.1. Resin.xml設置JDK參數(shù):

Resin 4.0已支持把JDK參數(shù)加入resin配置文件resin.xml裏。

參考resin的幫助文檔

JDK arguments

Resin 4.0 has moved all JDK arguments into the resin.xml file, in the <jvm-arg> tag. Because the Resin 4.0 watchdog starts each Resin server instance, it can pass the arguments defined in the configuration file to the JVM. By moving the Java arguments to the configuration file, server configuration is easier and more maintainable. 

2.2. 建議規(guī)則:

1、 ServerJVM最好將-Xms-Xmx設為相同值。為了優(yōu)化GC,最好讓-Xmn值約等於-Xmx1/4。

2、 通過增大-XXPermSize-XXMaxPermSize這兩個參數(shù)來避免出現(xiàn)JVM內(nèi)存永久保存區(qū)域溢出引發(fā)Resin500錯誤。(因為spring+struts的流行,這些框架用到大量動態(tài)class,ClassLoader是把這部分內(nèi)存放在PermGen space裏的。而JVMGC是不會清理PermGen space的。這樣容易導致線上應用報告PermGen space內(nèi)存溢出。)

 

4、建議resin配置:

建議生產(chǎn)環(huán)境下部署Resin 4resin.xml中增加如下配置節(jié)點:

<server-default>

    <jvm-arg>-Xms1024m</jvm-arg>

    <jvm-arg>-Xmx1024m</jvm-arg>

    <jvm-arg>-Xmn256m</jvm-arg>

<jvm-arg>-XX:PermSize=128m</jvm-arg>

<jvm-arg>-XX:MaxPermSize=256m</jvm-arg>

    <thread-max>1024</thread-max>

    <socket-timeout>30s</socket-timeout>

    <keepalive-max>512</keepalive-max>

    <keepalive-timeout>60s</keepalive-timeout>

</server-default>

本站僅提供存儲服務,所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
JVM優(yōu)化配置(轉(zhuǎn))
合理配置RESIN內(nèi)存
[轉(zhuǎn)帖]Jvm Tuning-feidi -JavaEye技術社區(qū)
JVM調(diào)優(yōu)總結(jié)(七)-典型配置舉例1
jvm 堆內(nèi)存 棧內(nèi)存 大小設置 查看堆大小
java 虛擬機--新生代與老年代GC
更多類似文章 >>
生活服務
分享 收藏 導長圖 關注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服