// 應(yīng)組里“每日一技”之邀,寫了這篇總結(jié)貼
在很多地方都會用到 JVM 參數(shù),比如你運行 ant check-style,跑掛了,拋了個 OutOfMemory 錯誤。這時你上網(wǎng)搜索,他們會告訴你,應(yīng)該修改 ANT_OPTS 環(huán)境變量,加上“-Xmx512m”。
再比如 JBoss 或 tomcat 都有啟動腳本(startup.bat等),里面也用到 JVM 參數(shù)。還有 Eclipse 的 eclipse.ini 中也可以加入 JVM 參數(shù)。靈活使用這些 JVM 參數(shù)可以使我們的 Java 程序獲得更好的性能。
=== 常用參數(shù) ===
-server
一定要作為第一個參數(shù),會使JVM啟動速度變慢,但會顯著提升JVM性能
-Xms64m
設(shè)置初始 Heap 大小,使用的最小內(nèi)存
-Xmx1024m
設(shè)置最大 Heap 大小
-Xss256k
設(shè)置每個線程的 Stack 大小
-XX:MaxPermSize=128M
設(shè)置最大永久區(qū)大小,永久保存區(qū)用于存放Class信息和元信息
=== GC(垃圾回收)參數(shù) ===
Sun HotSpot JVM 通常使用的 GC 算法是分代回收。即把對象按生命周期不同分為年輕代和年老代。新的對象會先生成在Young Area,在幾次 GC 以后,如果沒有收集到,就會逐漸升級到Tenured Area。
Sun JVM 默認的回收器稱為 serial collector ,即串行回收,我們也可以使用多線程并發(fā)回收來提高效率。需要注意的是,在單核的機器上,使用默認的回收器可能會更好。
-XX:+UseParNewGC
為年輕代對象使用并發(fā)回收,會縮短年輕代對象的回收時間
-XX:+UseConcMarkSweepGC
為年老代使用并發(fā)回收
-XX:+UseParallelGC
該收集器和 UseConcMarkSweepGC 是互相排斥的,為新生代使用并行清除,年老代使用單線程Mark-Sweep-Compact的垃圾收集器。
=== 其他參數(shù) ===
-XX:CompileThreshold=100
該值表示編譯之前必須調(diào)用方法的次數(shù)。HotSpot JVM 使用 JIT(Just-In-Time Compilation, http://en.wikipedia.org/wiki/Just-in-time_compilation) 技術(shù)將字節(jié)碼編譯成本地碼,默認值為1000,即一個方法被調(diào)用了 1000 次之后 JVM 會編譯它。降低這個值可能會使程序的性能得到提升,但會使啟動速度變慢。
-XX:+DoEscapeAnalysis
啟用逃逸分析,這個選項只能用于 Java 1.6。原理參見:http://kenwublog.com/jvm-optimization-escape-analysis
=== JVM參數(shù)的設(shè)置 ===
可以直接在java命令后面附加,比如:java -Xmx512m -XX:+UseParNewGC Test
還可以在環(huán)境變量中設(shè)置,如 JAVA_OPTS 和 ANT_OPTS 。還可以在eclipse.ini中設(shè)置,需要寫在 -vmargs 一行的后面
=== 參考資料 ===
* Java 6 JVM參數(shù)選項大全(中文版):http://kenwublog.com/docs/java6-jvm-options-chinese-edition.htm
* Garbage Collection - Frequently Asked Questions:http://java.sun.com/docs/hotspot/gc1.4.2/faq.html
* 調(diào)整 JVM 開關(guān)以獲得最佳性能:http://gceclub.sun.com.cn/NetBeans/tutorials/tuning/index.html