JVM啟動參數大全及默認值


Java啟動參數共分為三類;

其一是標准參數(-),所有的JVM實現都必須實現這些參數的功能,而且向后兼容;

其二是非標准參數(-X),默認jvm實現這些參數的功能,但是並不保證所有jvm實現都滿足,且不保證向后兼容;

其三是非Stable參數(-XX),此類參數各個jvm實現會有所不同,將來可能會隨時取消,需要慎重使用;

一、JVM標准參數(-)

JVM的標准參數都是以”-“開頭,通過輸入”java -help”或者”java -?”,可以查看JVM標准參數列表。如 
這里寫代碼片

以下是JVM標准參數的詳細介紹(紅色標記的參數請着重注意): 
以下是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[:”…” | : ]

-ea[:”…” | : ]

上述參數就用來設置jvm是否啟動斷言機制(從JDK 1.4開始支持),缺省時jvm關閉斷言機制。

用-ea 可打開斷言機制,不加和classname時運行所有包和類中的斷言,如果希望只運行某些包或類中的斷言,可將包名或類名加到-ea之后。例如要啟動包com.wombat.fruitbat中的斷言,可用命令java -ea:com.wombat.fruitbat…。

-disableassertions[:”…” | :

二、JVM非標准參數(-X)

通過”java -X”可以輸出非標准參數列表,如下所示: 
這里寫圖片描述

非標准參數又稱為擴展參數,其列表如下:

-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為准。

-Xms

指定jvm堆的初始大小,默認為物理內存的1/64,最小為1M;可以指定單位,比如k、m,若不指定,則默認為字節。

-Xmx

指定jvm堆的最大值,默認為物理內存的1/4或者1G,最小為2M;單位與-Xms一致。

-Xss

設置單個線程棧的大小,一般默認為512k。

-Xprof

輸出 cpu 配置文件數據

-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事件。

上面這些參數中,比如-Xmsn、-Xmxn……都是我們性能優化中很重要的參數;

-Xprof、-Xloggc:file等都是在沒有專業跟蹤工具情況下排錯的好手;

三、JVM非Stable參數(-XX)

Java 6(update 21oder 21之后)版本, HotSpot JVM 提供給了兩個新的參數,在JVM啟動后,在命令行中可以輸出所有XX參數和值。

-XX:+PrintFlagsFinal and -XX:+PrintFlagsInitial
  • 1

讀者可以使用以下語句輸出所有的參數和默認值

java -XX:+PrintFlagsInitial -XX:+PrintFlagsInitial>>1.txt
  • 1

由於非State參數非常的多,因此這里就不列出所有參數進行講解。只介紹我們比較常用的。

Java HotSpot VM中-XX:的可配置參數列表進行描述;

這些參數可以被松散的聚合成三類:

行為參數(Behavioral Options):用於改變jvm的一些基礎行為;

性能調優(Performance Tuning):用於jvm的性能調優;

調試參數(Debugging Options):一般用於打開跟蹤、打印、輸出等jvm參數,用於顯示jvm更加詳細的信息;

行為參數(功能開關)

-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 啟用本地線程優先級 性能調優 -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 跟蹤類加載器約束的相關信息


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM