JAVA_OPTS调优

转载:

   

对于JVM设置,可以查考如下配置example:

# Memory configuration

JAVA_OPTS="-server" JAVA_OPTS="$JAVA_OPTS -Xms1280m"

JAVA_OPTS="$JAVA_OPTS -Xmx1280m"

JAVA_OPTS="$JAVA_OPTS -XX:NewSize=640m"

JAVA_OPTS="$JAVA_OPTS -XX:MaxNewSize=640m"

JAVA_OPTS="$JAVA_OPTS -XX:SurvivorRatio=5"

JAVA_OPTS="$JAVA_OPTS -XX:TargetSurvivorRatio=90"

JAVA_OPTS="$JAVA_OPTS -XX:MaxTenuringThreshold=12"

JAVA_OPTS="$JAVA_OPTS -XX:+UseConcMarkSweepGC"

JAVA_OPTS="$JAVA_OPTS -XX:+CMSIncrementalMode"

JAVA_OPTS="$JAVA_OPTS -XX:+CMSIncrementalPacing"

JAVA_OPTS="$JAVA_OPTS -XX:+CMSParallelRemarkEnabled"

JAVA_OPTS="$JAVA_OPTS -XX:+UseParNewGC"

JAVA_OPTS="$JAVA_OPTS -XX:PermSize=64m"

JAVA_OPTS="$JAVA_OPTS -XX:MaxPermSize=64m"

JAVA_OPTS="$JAVA_OPTS -XX:+UseTLAB"


# Enable class unloading (needed with ConcMarkSweepGC

JAVA_OPTS="$JAVA_OPTS -XX:+CMSClassUnloadingEnabled"

JAVA_OPTS="$JAVA_OPTS -XX:+CMSPermGenSweepingEnabled"


# debug and memory tweaks to avoid Hotspot Compiler Failure

JAVA_OPTS="$JAVA_OPTS -XX:+PrintCompilation"

JAVA_OPTS="$JAVA_OPTS -XX:CodeCacheMinimumFreeSpace=2M"

JAVA_OPTS="$JAVA_OPTS -XX:ReservedCodeCacheSize=64M"

JAVA_OPTS="$JAVA_OPTS -XX:CompileCommandFile=/my/portal/bin/hotspot_compiler"


# Enable JMX Remote Monitoring

JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote"

JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.port=9000" JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.ssl=false"

JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.password.file=/my/portal/bin/jmxremote.password"

JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.access.file=/my/portal/bin/jmxremote.access"

 
# turn on some debug for GC only print the distribution when doing tuning

JAVA_OPTS="$JAVA_OPTS -verbose:gc"

JAVA_OPTS="$JAVA_OPTS -XX:+PrintGCTimeStamps"

JAVA_OPTS="$JAVA_OPTS -XX:+PrintGCDetails"

 #JAVA_OPTS="$JAVA_OPTS -XX:+PrintTenuringDistribution"

JAVA_OPTS="$JAVA_OPTS -Xloggc:/my/portal/logs/portal/gc.log"


# Enable remote debugging port

JAVA_OPTS="$JAVA_OPTS -Xdebug -Xrunjdwp:transport=dt_socket,address=8000,server=y,suspend=n"

 

对不同的机器,配的可能不一样:

   JAVA_OPTS=”-server -Xms1536m -Xmx1536m -XX:NewSize=320m -XX:MaxNewSize=320m -XX:PermSize=96m -XX:MaxPermSize=256m -Xmn500m -XX:MaxTenuringThreshold=5″
JAVA_OPTS并不是已成不变的,不同的应用、软硬件环境下,要想充分发挥应用的性能,这些参数里边的设置可是非常有技巧和具有经验积累的。
经过查找资料,先看下JAVA_OPTS参数表示的意义。

-server:一定要作为第一个参数,在多个CPU时性能佳
-Xms:初始Heap大小,使用的最小内存,cpu性能高时此值应设的大一些
-Xmx:java heap最大值,使用的最大内存
上面两个值是分配JVM的最小和最大内存,取决于硬件物理内存的大小,建议均设为物理内存的一半。

-XX:PermSize:设定内存的永久保存区域
-XX:MaxPermSize:设定最大内存的永久保存区域
-XX:MaxNewSize:
-Xss 15120 这使得JBoss每增加一个线程(thread)就会立即消耗15M内存,而最佳值应该是128K,默认值好像是512k.
+XX:AggressiveHeap 会使得 Xms没有意义。这个参数让jvm忽略Xmx参数,疯狂地吃完一个G物理内存,再吃尽一个G的swap。
-Xss:每个线程的Stack大小
-verbose:gc 现实垃圾收集信息
-Xloggc:gc.log 指定垃圾收集日志文件
-Xmn:young generation的heap大小,一般设置为Xmx的3、4分之一
-XX:+UseParNewGC :缩短minor收集的时间
-XX:+UseConcMarkSweepGC :缩短major收集的时间
提示:此选项在Heap Size 比较大而且Major收集时间较长的情况下使用更合适。

 

 http://kongxl.sinaapp.com/?p=494

你可能感兴趣的:(jvm_调优_gc_监控命令)