關於JVM突破Docker內存限制的解決方案及JVM推薦配置

如下參數配置適用於非計算密集型的大部分應用app

分配內存spa

堆配置推薦日誌

2Gserver

-Xmx1344M -Xms1344M -Xmn448M -XX:MaxMetaspaceSize=192M -XX:MetaspaceSize=192M內存

3Gci

-Xmx2048M -Xms2048M -Xmn768M -XX:MaxMetaspaceSize=256M -XX:MetaspaceSize=256Mit

4Gio

-Xmx2688M -Xms2688M -Xmn960M -XX:MaxMetaspaceSize=256M -XX:MetaspaceSize=256Mthread

5G基礎

-Xmx3392M -Xms3392M -Xmn1216M -XX:MaxMetaspaceSize=512M -XX:MetaspaceSize=512M

6G

-Xmx4096M -Xms4096M -Xmn1536M -XX:MaxMetaspaceSize=512M -XX:MetaspaceSize=512M

7G

-Xmx4736M -Xms4736M -Xmn1728M -XX:MaxMetaspaceSize=512M -XX:MetaspaceSize=512M

8G

-Xmx5440M -Xms5440M -XX:MaxMetaspaceSize=512M -XX:MetaspaceSize=512M

 

內存>=8G 基礎配置

內存<8G 基礎配置

-server
-XX:+DisableExplicitGC
-XX:+UseG1GC 
-XX:MaxGCPauseMillis=100 
-XX:+ParallelRefProcEnabled
-XX:+HeapDumpOnOutOfMemoryError
-XX:+PrintGCDetails 
-XX:+PrintGCTimeStamps 
-XX:+PrintHeapAtGC 
-XX:+PrintGCApplicationStoppedTime 
-XX:+PrintGCDateStamps 
-XX:ErrorFile=/var/app/gc/hs_err_pid%p.log 
-XX:HeapDumpPath=/var/app/gc 
-Xloggc:/var/app/gc/gc%t.log

-server
-XX:+DisableExplicitGC 
-XX:+UseParNewGC
-XX:+UseConcMarkSweepGC 
-XX:+UseCMSInitiatingOccupancyOnly 
-XX:CMSInitiatingOccupancyFraction=70 
-XX:+ExplicitGCInvokesConcurrentAndUnloadsClasses 
-XX:+CMSClassUnloadingEnabled 
-XX:+ParallelRefProcEnabled 
-XX:+CMSScavengeBeforeRemark 
-XX:+HeapDumpOnOutOfMemoryError
-XX:+PrintGCDetails 
-XX:+PrintGCTimeStamps 
-XX:+PrintHeapAtGC 
-XX:+PrintGCApplicationStoppedTime 
-XX:+PrintGCDateStamps 
-XX:ErrorFile=/var/app/gc/hs_err_pid%p.log 
-XX:HeapDumpPath=/var/app/gc 
-Xloggc:/var/app/gc/gc%t.log

堆內存根據業務特性調整

 

掛載gc日誌

JVM = Heap + Method Area + Constant Pool + Thread Stack * num of thread 因此Xmx的值要小於鏡像上限內存。

相關文章
相關標籤/搜索