|
-XX:-CITime | 默認啟用 | 打印JIT編譯器編譯耗時。 |
-XX:ErrorFile=./hs_err_pid<pid>.log | Java1.6引入 | 如果JVM crashed,將錯誤日志輸出到指定文件路徑。 |
-XX:-ExtendedDTraceProbes | Java6引入,限于solaris,默認關閉 | 啟用 dtrace 診斷 |
-XX:HeapDumpPath=./java_pid<pid>.hprof | 默認是java進程啟動位置 | 堆內存快照的存儲文件路徑。 什么是堆內存快照? 當java進程因OOM或crash被OS強制終止后,會生成一個hprof(Heap PROFling)格式的堆內存快照文件。該文件用于線下調試,診斷,查找問題。 文件名一般為 java_<pid>_<date>_<time>_heapDump.hprof 解析快照文件,可以使用 jhat, eclipse MAT,gdb等工具。 |
-XX:-HeapDumpOnOutOfMemoryError | 默認關閉 | 在java.lang.OutOfMemoryError 異常出現時,輸出一個dump.core文件,記錄當時的堆內存快照(見 -XX:HeapDumpPath 的描述)。 |
-XX:OnError="<cmd args>;<cmd args>" | Java1.4引入 | 當java每拋出一個ERROR時,運行指定命令行指令集。指令集是與OS環境相關的,在Linux下多數是.sh腳本,windows下是.bat批處理。 |
-XX:OnOutOfMemoryError="<cmd args>; <cmd args>" | Java1.4.2 update 12和Java6時引入 | 當第一次發生java.lang.OutOfMemoryError 時,運行指定命令行指令集。指令集是與OS環境相關的,在linux下多數是.sh腳本,windows下是.bat批處理。 |
-XX:-PrintClassHistogram | 默認關閉 | 在Windows下, 按ctrl-break或Linux下是執行kill -3(發送SIGQUIT信號)時,打印class柱狀圖。 jmap -histo pid也實現了相同的功能。 |
-XX:-PrintConcurrentLocks | 默認關閉 | 在thread dump的同時,打印java.util.concurrent的鎖狀態。 jstack -l pid 也同樣實現了同樣的功能。 |
-XX:-PrintCommandLineFlags | Java1.5 引入,默認關閉 | Java啟動時,往stdout打印當前啟用的非穩態jvm options。 例如: -XX:+UseConcMarkSweepGC -XX:+HeapDumpOnOutOfMemoryError -XX:+DoEscapeAnalysis |
-XX:-PrintCompilation | 默認關閉 | 往stdout打印方法被JIT編譯時的信息。 |
-XX:-PrintGC | 默認關閉 | 開啟GC日志打印。 顯示結果例如: [Full GC 131115K->7482K(1015808K), 0.1633180 secs] 該選項可通過 com.sun.management.HotSpotDiagnosticMXBean API 和 jconsole 動態啟用。 |
-XX:-PrintGCDetails | Java1.4引入,默認關閉 | 打印GC回收的詳細信息。 顯示結果例如: [Full GC (System) [Tenured: 0K->2394K(466048K), 0.0624140 secs] 30822K->2394K(518464K), [Perm : 10443K->10443K(16384K)], 0.0625410 secs] [Times: user=0.05 sys=0.01, real=0.06 secs] 該選項可通過 com.sun.management.HotSpotDiagnosticMXBean API 和 jconsole 動態啟用。 |
-XX:-PrintGCTimeStamps | 默認關閉 | 打印GC停頓耗時。 顯示結果例如: 2.744: [Full GC (System) 2.744: [Tenured: 0K->2441K(466048K), 0.0598400 secs] 31754K->2441K(518464K), [Perm : 10717K->10717K(16384K)], 0.0599570 secs] [Times: user=0.06 sys=0.00, real=0.06 secs] 該選項可通過 com.sun.management.HotSpotDiagnosticMXBean API 和 jconsole 動態啟用。 |
-XX:-PrintTenuringDistribution | 默認關閉 | 打印對象的存活期限信息。 顯示結果例如: [GC Desired survivor size 4653056 bytes, new threshold 32 (max 32) - age 1: 2330640 bytes, 2330640 total - age 2: 9520 bytes, 2340160 total 204009K->21850K(515200K), 0.1563482 secs] Age1,2表示在第1和2次GC后存活的對象大小。 |
-XX:-TraceClassLoading | 默認關閉 | 打印class裝載信息到stdout。記Loaded狀態。 例如: [Loaded java.lang.Object from /opt/taobao/install/jdk1.6.0_07/jre/lib/rt.jar] |
-XX:-TraceClassLoadingPreorder | 1.4.2引入,默認關閉 | 按class的引用/依賴順序打印類裝載信息到stdout。不同于 TraceClassLoading,本選項只記 Loading狀態。 例如: [Loading java.lang.Object from /home/confsrv/jdk1.6.0_14/jre/lib/rt.jar] |
-XX:-TraceClassResolution | 1.4.2引入,默認關閉 | 打印所有靜態類,常量的代碼引用位置。用于debug。 例如: RESOLVE java.util.HashMap java.util.HashMap$Entry HashMap.java:209 說明HashMap類的209行引用了靜態類 java.util.HashMap$Entry |
-XX:-TraceClassUnloading | 默認關閉 | 打印class的卸載信息到stdout。記Unloaded狀態。 |
-XX:-TraceLoaderConstraints | Java1.6 引入,默認關閉 | 打印class的裝載策略變化信息到stdout。 例如: [Adding new constraint for name: java/lang/String, loader[0]: sun/misc/Launcher$ExtClassLoader, loader[1]: ] [Setting class object in existing constraint for name: [Ljava/lang/Object; and loader sun/misc/Launcher$ExtClassLoader ] [Updating constraint for name org/xml/sax/InputSource, loader , by setting class object ] [Extending constraint for name java/lang/Object by adding loader[15]: sun/reflect/DelegatingClassLoader ] 裝載策略變化是實現classloader隔離/名稱空間一致性的關鍵技術。 |
-XX:+PerfSaveDataToFile | 默認啟用 | 當java進程因java.lang.OutOfMemoryError 異常或crashed 被強制終止后,生成一個堆快照文件。 |
-XX:ParallelGCThreads=n | 默認值:隨JVM運行平臺不同而異 | 配置并行收集器的線程數,即:同時多少個線程一起進行垃圾回收。此值最好配置與處理器數目相等。 |
-XX:+UseCompressedOops | 32位默認關閉,64位默認啟動 | 使用compressed pointers。這個參數默認在64bit的環境下默認啟動,但是如果JVM的內存達到32G后,這個參數就會默認為不啟動,因為32G內存后,壓縮就沒有多大必要了,要管理那么大的內存指針也需要很大的寬度了 |
-XX:+AlwaysPreTouch | 默認關閉 | 在JVM 初始化時預先對Java堆進行摸底。 |
-XX:AllocatePrefetchDistance=n | 默認值取決于當前JVM 設置 | 為對象分配設置預取距離。 |
-XX:InlineSmallCode=n | 默認值取決于當前JVM 設置 | 當編譯的代碼小于指定的值時,內聯編譯的代碼。 |
-XX:MaxInlineSize=35 | 默認值:35 | 內聯方法的最大字節數。 |
-XX:FreqInlineSize=n | 默認值取決于當前JVM 設置 | 內聯頻繁執行的方法的最大字節碼大小。 |
-XX:LoopUnrollLimit=n | 默認值取決于當前JVM 設置 | 代表節點數目小于給定值時打開循環體。 |
-XX:InitialTenuringThreshold=7 | 默認值:7 | 設置初始的對象在新生代中最大存活次數。 |
-XX:MaxTenuringThreshold=n | 默認值:15,最大值:15 | 設置對象在新生代中最大的存活次數,最大值15,并行回收機制默認為15,CMS默認為4。 |
-Xloggc:<filename> | 默認關閉 | 輸出GC 詳細日志信息至指定文件。 |
-XX:-UseGCLogFileRotation | 默認關閉 | 開啟GC 日志文件切分功能,前置選項 -Xloggc |
-XX:NumberOfGClogFiles=1 | 必須>=1,默認值:1 | 設置切分GC 日志文件數量,文件命名格式:.0, .1, ..., .n-1 |
-XX:GCLogFileSize=8K | 必須>=8K,默認值:8K | GC日志文件切分大小。 |