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


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

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

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

          標準參數列表如下:
          -client
           設置jvm使用client模式,特點是啟動速度比較快,但運行時性能和內存管理效率不高,通常用于客戶端應用程序或者PC應用開發和調試。

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

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

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

          -classpath classpath
          -cp classpath

           告知jvm搜索目錄名、jar文檔名、zip文檔名,之間用分號;分隔;使用-classpath后jvm將不再使用CLASSPATH中的類搜索路徑,如果-classpath和CLASSPATH都沒有設置,則jvm使用當前路徑(.)作為類搜索路徑。
           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搜索順序為當前路徑.、CLASSPATH、-classpath,jvm最后搜索這些目錄,用System.getProperty("java.class.path")可得到搜索路徑。

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

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

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

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

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

           激活系統類的斷言。
           
          -disablesystemassertions
          -dsa

           關閉系統類的斷言。

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

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

          -verbose
          -verbose:class

           輸出jvm載入類的相關信息,當jvm報告說找不到類或者類沖突時可此進行診斷。
          -verbose:gc
           輸出每次GC的相關情況。
          -verbose:jni
           輸出native方法調用的相關情況,一般用于診斷jni調用錯誤信息。
           
          -version
           輸出java的版本信息,比如jdk版本、vendor、model。
          -version:release
           指定class或者jar運行時需要的jdk版本信息;若指定版本未找到,則以能找到的系統默認jdk版本執行;一般情況下,對于jar文件,可以在manifest文件中指定需要的版本信息,而不是在命令行。
           release中可以指定單個版本,也可以指定一個列表,中間用空格隔開,且支持復雜組合,比如:
           -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相同)之后,繼續輸出java的標準參數列表及其描述。
           
          -?
          -help

           輸出java標準參數列表及其描述。

          -X
           輸出非標準的參數列表及其描述。

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


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

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

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


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

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

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

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

          首先來介紹行為參數

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
















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


          性能調優
          參數列表:

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


















          我們在日常性能調優中基本上都會用到以上黑體的這幾個屬性; 

          調試參數列表:

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


































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


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

          FeedBack:
          # re: JVM啟動參數大全 zz
          2012-02-25 16:57 | nkjava
          感覺有些不對啊  回復  更多評論
            
          # re: JVM啟動參數大全 zz
          2016-02-29 16:13 | asfd
          asdfasdfasd  回復  更多評論
            
          主站蜘蛛池模板: 五莲县| 旌德县| 广饶县| 桐庐县| 临武县| 昆明市| 称多县| 陇川县| 琼结县| 中牟县| 瓦房店市| 平湖市| 彭阳县| 万盛区| 丹东市| 旬邑县| 扬州市| 麻栗坡县| 兴安县| 云霄县| 天津市| 缙云县| 镇原县| 丰城市| 海口市| 定兴县| 林口县| 察雅县| 伊宁县| 河北省| 集贤县| 江阴市| 将乐县| 青阳县| 闸北区| 巴林左旗| 怀柔区| 邮箱| 普定县| 南阳市| 洪洞县|