歲月如哥
          人生非夢
          posts - 50,comments - 144,trackbacks - 0
          jdk1.4.2 JVM官方地址:http://java.sun.com/j2se/1.4.2/docs/guide/vm/index.html
          標(biāo)準(zhǔn)和非標(biāo)注參數(shù)(for windows):http://java.sun.com/j2se/1.4.2/docs/tooldocs/windows/java.html
          非stable參數(shù):http://java.sun.com/javase/technologies/hotspot/vmoptions.jsp


          中文地址:
          http://blog.csdn.net/sfdev/archive/2008/01/23/2062042.aspx        
                             

          前段時間系統(tǒng)升級時遭遇了OOM,具體解決過程見 遭遇OutOfMemoryError
          為了鞏固對于java啟動各項參數(shù)的認(rèn)識,決定將所有參數(shù)列舉出來,并一一解釋,以便后查;

          java啟動參數(shù)共分為三類;
          其一是標(biāo)準(zhǔn)參數(shù)(-),所有的JVM實現(xiàn)都必須實現(xiàn)這些參數(shù)的功能,而且向后兼容;
          其二是非標(biāo)準(zhǔn)參數(shù)(-X),默認(rèn)jvm實現(xiàn)這些參數(shù)的功能,但是并不保證所有jvm實現(xiàn)都滿足,且不保證向后兼容;
          其三是非Stable參數(shù)(-XX),此類參數(shù)各個jvm實現(xiàn)會有所不同,將來可能會隨時取消,需要慎重使用;
          本文主要描述標(biāo)準(zhǔn)參數(shù)部分,剩下的兩個部分將會陸續(xù)推出;

          標(biāo)準(zhǔn)參數(shù)列表如下:
          -client
           設(shè)置jvm使用client模式,特點是啟動速度比較快,但運行時性能和內(nèi)存管理效率不高,通常用于客戶端應(yīng)用程序或者PC應(yīng)用開發(fā)和調(diào)試。

          -server
           設(shè)置jvm使server模式,特點是啟動速度比較慢,但運行時性能和內(nèi)存管理效率很高,適用于生產(chǎn)環(huán)境。在具有64位能力的jdk環(huán)境下將默認(rèn)啟用該模式,而忽略-client參數(shù)。

          -agentlib:libname[=options]
           用于裝載本地lib包;
           其中l(wèi)ibname為本地代理庫文件名,默認(rèn)搜索路徑為環(huán)境變量PATH中的路徑,options為傳給本地庫啟動時的參數(shù),多個參數(shù)之間用逗號分隔。在Windows平臺上jvm搜索本地庫名為libname.dll的文件,在linux上jvm搜索本地庫名為libname.so的文件,搜索路徑環(huán)境變量在不同系統(tǒng)上有所不同,比如Solaries上就默認(rèn)搜索LD_LIBRARY_PATH。
           比如:-agentlib:hprof
           用來獲取jvm的運行情況,包括CPU、內(nèi)存、線程等的運行數(shù)據(jù),并可輸出到指定文件中;windows中搜索路徑為JRE_HOME/bin/hprof.dll。

          -agentpath:pathname[=options]
           按全路徑裝載本地庫,不再搜索PATH中的路徑;其他功能和agentlib相同;更多的信息待續(xù),在后續(xù)的JVMTI部分會詳述。

          -classpath classpath
          -cp classpath

           告知jvm搜索目錄名、jar文檔名、zip文檔名,之間用分號;分隔;使用-classpath后jvm將不再使用CLASSPATH中的類搜索路徑,如果-classpath和CLASSPATH都沒有設(shè)置,則jvm使用當(dāng)前路徑(.)作為類搜索路徑。
           jvm搜索類的方式和順序為:Bootstrap,Extension,User。
           Bootstrap中的路徑是jvm自帶的jar或zip文件,jvm首先搜索這些包文件,用System.getProperty("sun.boot.class.path")可得到搜索路徑。
           Extension是位于JRE_HOME/lib/ext目錄下的jar文件,jvm在搜索完Bootstrap后就搜索該目錄下的jar文件,用System.getProperty("java.ext.dirs")可得到搜索路徑。
           User搜索順序為當(dāng)前路徑.、CLASSPATH、-classpath,jvm最后搜索這些目錄,用System.getProperty("java.class.path")可得到搜索路徑。

          -Dproperty=value
           設(shè)置系統(tǒng)屬性名/值對,運行在此jvm之上的應(yīng)用程序可用System.getProperty("property")得到value的值。
           如果value中有空格,則需要用雙引號將該值括起來,如-Dname="space string"。
           該參數(shù)通常用于設(shè)置系統(tǒng)級全局變量值,如配置文件路徑,以便該屬性在程序中任何地方都可訪問。

          -enableassertions[:<package name>"..." | :<class name> ]
          -ea[:<package name>"..." | :<class name> ]

           上述參數(shù)就用來設(shè)置jvm是否啟動斷言機(jī)制(從JDK 1.4開始支持),缺省時jvm關(guān)閉斷言機(jī)制。
           用-ea 可打開斷言機(jī)制,不加<packagename>和classname時運行所有包和類中的斷言,如果希望只運行某些包或類中的斷言,可將包名或類名加到-ea之后。例如要啟動包com.wombat.fruitbat中的斷言,可用命令java -ea:com.wombat.fruitbat...<Main Class>。

          -disableassertions[:<package name>"..." | :<class ; ]
          -da[:<package name>"..." | :<class name> ]

           用來設(shè)置jvm關(guān)閉斷言處理,packagename和classname的使用方法和-ea相同,jvm默認(rèn)就是關(guān)閉狀態(tài)。
           該參數(shù)一般用于相同package內(nèi)某些class不需要斷言的場景,比如com.wombat.fruitbat需要斷言,但是com.wombat.fruitbat.Brickbat該類不需要,則可以如下運行:
           java -ea:com.wombat.fruitbat...-da:com.wombat.fruitbat.Brickbat <Main Class>。
           
          -enablesystemassertions
          -esa

           激活系統(tǒng)類的斷言。
           
          -disablesystemassertions
          -dsa

           關(guān)閉系統(tǒng)類的斷言。

          -jar
           指定以jar包的形式執(zhí)行一個應(yīng)用程序。
           要這樣執(zhí)行一個應(yīng)用程序,必須讓jar包的manifest文件中聲明初始加載的Main-class,當(dāng)然那Main-class必須有public static void main(String[] args)方法。

          -javaagent:jarpath[=options]
           指定jvm啟動時裝入java語言設(shè)備代理。
           Jarpath文件中的mainfest文件必須有Agent-Class屬性。代理類也必須實現(xiàn)公共的靜態(tài)public static void premain(String agentArgs, Instrumentation inst)方法(和main方法類似)。當(dāng)jvm初始化時,將按代理類的說明順序調(diào)用premain方法;具體參見java.lang.instrument軟件包的描述。

          -verbose
          -verbose:class

           輸出jvm載入類的相關(guān)信息,當(dāng)jvm報告說找不到類或者類沖突時可此進(jìn)行診斷。
          -verbose:gc
           輸出每次GC的相關(guān)情況。
          -verbose:jni
           輸出native方法調(diào)用的相關(guān)情況,一般用于診斷jni調(diào)用錯誤信息。
           
          -version
           輸出java的版本信息,比如jdk版本、vendor、model。
          -version:release
           指定class或者jar運行時需要的jdk版本信息;若指定版本未找到,則以能找到的系統(tǒng)默認(rèn)jdk版本執(zhí)行;一般情況下,對于jar文件,可以在manifest文件中指定需要的版本信息,而不是在命令行。
           release中可以指定單個版本,也可以指定一個列表,中間用空格隔開,且支持復(fù)雜組合,比如:
           -version:"1.5.0_04 1.5*&1.5.1_02+"
           指定class或者jar需要jdk版本為1.5.0_04或者是1.5系列中比1.5.1_02更高的所有版本。

          -showversion
           輸出java版本信息(與-version相同)之后,繼續(xù)輸出java的標(biāo)準(zhǔn)參數(shù)列表及其描述。
           
          -?
          -help

           輸出java標(biāo)準(zhǔn)參數(shù)列表及其描述。

          -X
           輸出非標(biāo)準(zhǔn)的參數(shù)列表及其描述。

          以上的這些參數(shù)我們經(jīng)常會在很多情況下用到多個的組合,比如我們在用JProfiler進(jìn)行跟蹤監(jiān)控時,需要在被監(jiān)控java啟動參數(shù)中加上如下配置:
          -agentlib:jprofilerti=port=8849  -Xbootclasspath/a:/usr/local/jprofiler5/bin/agent.jar
          其中就用到兩個-agentlib和-X參數(shù),bootclasspath參數(shù)的詳細(xì)信息將會在非標(biāo)準(zhǔn)參數(shù)中詳細(xì)說明。


          http://blog.csdn.net/sfdev/archive/2008/01/24/2063464.aspx

          非標(biāo)準(zhǔn)參數(shù)又稱為擴(kuò)展參數(shù),其列表如下:
          -Xint
           設(shè)置jvm以解釋模式運行,所有的字節(jié)碼將被直接執(zhí)行,而不會編譯成本地碼。
           
          -Xbatch
           關(guān)閉后臺代碼編譯,強(qiáng)制在前臺編譯,編譯完成之后才能進(jìn)行代碼執(zhí)行;
           默認(rèn)情況下,jvm在后臺進(jìn)行編譯,若沒有編譯完成,則前臺運行代碼時以解釋模式運行。
           
          -Xbootclasspath:bootclasspath
           讓jvm從指定路徑(可以是分號分隔的目錄、jar、或者zip)中加載bootclass,用來替換jdk的rt.jar;若非必要,一般不會用到;
          -Xbootclasspath/a:path
           將指定路徑的所有文件追加到默認(rèn)bootstrap路徑中;
          -Xbootclasspath/p:path
           讓jvm優(yōu)先于bootstrap默認(rèn)路徑加載指定路徑的所有文件;
           
          -Xcheck:jni
           對JNI函數(shù)進(jìn)行附加check;此時jvm將校驗傳遞給JNI函數(shù)參數(shù)的合法性,在本地代碼中遇到非法數(shù)據(jù)時,jmv將報一個致命錯誤而終止;使用該參數(shù)后將造成性能下降,請慎用。
           
          -Xfuture
           讓jvm對類文件執(zhí)行嚴(yán)格的格式檢查(默認(rèn)jvm不進(jìn)行嚴(yán)格格式檢查),以符合類文件格式規(guī)范,推薦開發(fā)人員使用該參數(shù)。
           
          -Xnoclassgc
           關(guān)閉針對class的gc功能;因為其阻止內(nèi)存回收,所以可能會導(dǎo)致OutOfMemoryError錯誤,慎用;
           
          -Xincgc
           開啟增量gc(默認(rèn)為關(guān)閉);這有助于減少長時間GC時應(yīng)用程序出現(xiàn)的停頓;但由于可能和應(yīng)用程序并發(fā)執(zhí)行,所以會降低CPU對應(yīng)用的處理能力。
           
          -Xloggc:file
           與-verbose:gc功能類似,只是將每次GC事件的相關(guān)情況記錄到一個文件中,文件的位置最好在本地,以避免網(wǎng)絡(luò)的潛在問題。
           若與verbose命令同時出現(xiàn)在命令行中,則以-Xloggc為準(zhǔn)。
           
          -Xmsn
           指定jvm堆的初始大小,默認(rèn)為物理內(nèi)存的1/64,最小為1M;可以指定單位,比如k、m,若不指定,則默認(rèn)為字節(jié)。
           
          -Xmxn
           指定jvm堆的最大值,默認(rèn)為物理內(nèi)存的1/4或者1G,最小為2M;單位與-Xms一致。
           
          -Xprof
           跟蹤正運行的程序,并將跟蹤數(shù)據(jù)在標(biāo)準(zhǔn)輸出輸出;適合于開發(fā)環(huán)境調(diào)試。
           
          -Xrs
           減少jvm對操作系統(tǒng)信號(signals)的使用,該參數(shù)從1.3.1開始有效;
           從jdk1.3.0開始,jvm允許程序在關(guān)閉之前還可以執(zhí)行一些代碼(比如關(guān)閉數(shù)據(jù)庫的連接池),即使jvm被突然終止;
           jvm關(guān)閉工具通過監(jiān)控控制臺的相關(guān)事件而滿足以上的功能;更確切的說,通知在關(guān)閉工具執(zhí)行之前,先注冊控制臺的控制handler,然后對CTRL_C_EVENT, CTRL_CLOSE_EVENT, CTRL_LOGOFF_EVENT, and CTRL_SHUTDOWN_EVENT這幾類事件直接返回true。
           但如果jvm以服務(wù)的形式在后臺運行(比如servlet引擎),他能接收CTRL_LOGOFF_EVENT事件,但此時并不需要初始化關(guān)閉程序;為了避免類似沖突的再次出現(xiàn),從jdk1.3.1開始提供-Xrs參數(shù);當(dāng)此參數(shù)被設(shè)置之后,jvm將不接收控制臺的控制handler,也就是說他不監(jiān)控和處理CTRL_C_EVENT, CTRL_CLOSE_EVENT, CTRL_LOGOFF_EVENT, or CTRL_SHUTDOWN_EVENT事件。
           
          -Xssn
           設(shè)置單個線程棧的大小,一般默認(rèn)為512k。 

          上面這些參數(shù)中,比如-Xmsn、-Xmxn……都是我們性能優(yōu)化中很重要的參數(shù);
          -Xprof、-Xloggc:file等都是在沒有專業(yè)跟蹤工具情況下排錯的好手;
          在上一小節(jié)中提到的關(guān)于JProfiler的配置中就使用到了-Xbootclasspath/a:path


          http://blog.csdn.net/sfdev/archive/2008/01/24/2063928.aspx

          前面我們提到用-XX作為前綴的參數(shù)列表在jvm中可能是不健壯的,SUN也不推薦使用,后續(xù)可能會在沒有通知的情況下就直接取消了;但是由于這些參數(shù)中的確有很多是對我們很有用的,比如我們經(jīng)常會見到的-XX:PermSize、-XX:MaxPermSize等等;

          下面我們將就Java HotSpot VM中-XX:的可配置參數(shù)列表進(jìn)行描述;
          這些參數(shù)可以被松散的聚合成三類:
          行為參數(shù)(Behavioral Options):用于改變jvm的一些基礎(chǔ)行為;
          性能調(diào)優(yōu)(Performance Tuning):用于jvm的性能調(diào)優(yōu);
          調(diào)試參數(shù)(Debugging Options):一般用于打開跟蹤、打印、輸出等jvm參數(shù),用于顯示jvm更加詳細(xì)的信息;

          由于sun官方文檔中對各參數(shù)的描述也都非常少(大多只有一句話),而且大多涉及OS層面的東西,很難描述清楚,所以以下是挑選了一些我們開發(fā)中可能會用得比較多的配置項,若需要查看所有參數(shù)列表,可以點擊HotSpot VM Specific Options.查看原文;

          首先來介紹行為參數(shù)

          參數(shù)及其默認(rèn)值 描述
          -XX:-DisableExplicitGC 禁止調(diào)用System.gc();但jvm的gc仍然有效
          -XX:+MaxFDLimit 最大化文件描述符的數(shù)量限制
          -XX:+ScavengeBeforeFullGC 新生代GC優(yōu)先于Full GC執(zhí)行
          -XX:+UseGCOverheadLimit 在拋出OOM之前限制jvm耗費在GC上的時間比例
          -XX:-UseConcMarkSweepGC 對老生代采用并發(fā)標(biāo)記交換算法進(jìn)行GC
          -XX:-UseParallelGC 啟用并行GC
          -XX:-UseParallelOldGC 對Full GC啟用并行,當(dāng)-XX:-UseParallelGC啟用時該項自動啟用
          -XX:-UseSerialGC 啟用串行GC
          -XX:+UseThreadPriorities 啟用本地線程優(yōu)先級
















          上面表格中黑體的三個參數(shù)代表著jvm中GC執(zhí)行的三種方式,即串行、并行、并發(fā)
          串行(SerialGC)是jvm的默認(rèn)GC方式,一般適用于小型應(yīng)用和單處理器,算法比較簡單,GC效率也較高,但可能會給應(yīng)用帶來停頓;
          并行(ParallelGC)是指GC運行時,對應(yīng)用程序運行沒有影響,GC和app兩者的線程在并發(fā)執(zhí)行,這樣可以最大限度不影響app的運行;
          并發(fā)(ConcMarkSweepGC)是指多個線程并發(fā)執(zhí)行GC,一般適用于多處理器系統(tǒng)中,可以提高GC的效率,但算法復(fù)雜,系統(tǒng)消耗較大;


          性能調(diào)優(yōu)
          參數(shù)列表:

          參數(shù)及其默認(rèn)值 描述
          -XX:LargePageSizeInBytes=4m 設(shè)置用于Java堆的大頁面尺寸
          -XX:MaxHeapFreeRatio=70 GC后java堆中空閑量占的最大比例
          -XX:MaxNewSize=size 新生成對象能占用內(nèi)存的最大值
          -XX:MaxPermSize=64m 老生代對象能占用內(nèi)存的最大值
          -XX:MinHeapFreeRatio=40 GC后java堆中空閑量占的最小比例
          -XX:NewRatio=2 新生代內(nèi)存容量與老生代內(nèi)存容量的比例
          -XX:NewSize=2.125m 新生代對象生成時占用內(nèi)存的默認(rèn)值
          -XX:ReservedCodeCacheSize=32m 保留代碼占用的內(nèi)存容量
          -XX:ThreadStackSize=512 設(shè)置線程棧大小,若為0則使用系統(tǒng)默認(rèn)值
          -XX:+UseLargePages 使用大頁面內(nèi)存


















          我們在日常性能調(diào)優(yōu)中基本上都會用到以上黑體的這幾個屬性; 

          調(diào)試參數(shù)列表:

          參數(shù)及其默認(rèn)值 描述
          -XX:-CITime 打印消耗在JIT編譯的時間
          -XX:ErrorFile=./hs_err_pid<pid>.log 保存錯誤日志或者數(shù)據(jù)到文件中
          -XX:-ExtendedDTraceProbes 開啟solaris特有的dtrace探針
          -XX:HeapDumpPath=./java_pid<pid>.hprof 指定導(dǎo)出堆信息時的路徑或文件名
          -XX:-HeapDumpOnOutOfMemoryError 當(dāng)首次遭遇OOM時導(dǎo)出此時堆中相關(guān)信息
          -XX:OnError="<cmd args>;<cmd args>" 出現(xiàn)致命ERROR之后運行自定義命令
          -XX:OnOutOfMemoryError="<cmd args>;<cmd args>" 當(dāng)首次遭遇OOM時執(zhí)行自定義命令
          -XX:-PrintClassHistogram 遇到Ctrl-Break后打印類實例的柱狀信息,與jmap -histo功能相同
          -XX:-PrintConcurrentLocks 遇到Ctrl-Break后打印并發(fā)鎖的相關(guān)信息,與jstack -l功能相同
          -XX:-PrintCommandLineFlags 打印在命令行中出現(xiàn)過的標(biāo)記
          -XX:-PrintCompilation 當(dāng)一個方法被編譯時打印相關(guān)信息
          -XX:-PrintGC 每次GC時打印相關(guān)信息
          -XX:-PrintGC Details 每次GC時打印詳細(xì)信息
          -XX:-PrintGCTimeStamps 打印每次GC的時間戳
          -XX:-TraceClassLoading 跟蹤類的加載信息
          -XX:-TraceClassLoadingPreorder 跟蹤被引用到的所有類的加載信息
          -XX:-TraceClassResolution 跟蹤常量池
          -XX:-TraceClassUnloading 跟蹤類的卸載信息
          -XX:-TraceLoaderConstraints 跟蹤類加載器約束的相關(guān)信息


































          當(dāng)系統(tǒng)出現(xiàn)問題的時候,又不能使用外部跟蹤工具(比如JProfiler……)的情況下,以上的這些參數(shù)就會發(fā)揮重大作用了,比如dump堆信息、打印并發(fā)鎖……


          posted on 2008-09-21 15:43 歲月如歌 閱讀(26298) 評論(2)  編輯  收藏 所屬分類: java

          FeedBack:
          # re: JVM啟動參數(shù)大全 zz
          2012-02-25 16:57 | nkjava
          感覺有些不對啊  回復(fù)  更多評論
            
          # re: JVM啟動參數(shù)大全 zz
          2016-02-29 16:13 | asfd
          asdfasdfasd  回復(fù)  更多評論
            
          主站蜘蛛池模板: 晴隆县| 山丹县| 乃东县| 丁青县| 涟水县| 平谷区| 兴和县| 东宁县| 宜丰县| 密山市| 辛集市| 平凉市| 达州市| 武城县| 新绛县| 乐都县| 岳阳市| 磐安县| 芒康县| 苏尼特左旗| 进贤县| 岗巴县| 象山县| 杂多县| 康平县| 远安县| 洪雅县| 外汇| 仙居县| 龙门县| 弥渡县| 阜平县| 搜索| 台安县| 乡宁县| 漾濞| 六枝特区| 莎车县| 安岳县| 师宗县| 新化县|