您好,登錄后才能下訂單哦!
本篇內容介紹了“JVM命令行的標志介紹”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
1.DisableExplicitGC
只要跨代碼快速運行grep,就會發現清單1所示的問題--原始Java性能反模式:
清單 1. System.gc();
// We just released a bunch of objects, so tell the stupid // garbage collector to collect them already! System.gc();
顯式垃圾收集是一個非常糟糕的主意--就像將您和一個瘋狂的斗牛犬鎖在一個電話亭里。盡管調用的語法是依賴實現的,但如果您的JVM正在運行一個分代的垃圾回收器(大多數是)System.gc();強迫VM執行一個堆的“全部清掃”,雖然有的沒有必要。全部清掃比一個常規GC操作要昂貴好幾個數量級,這只是個簡單數學問題。
您可以不把我的話放在心上--Sun的工程師為這個特殊的人工錯誤提供一個JVM標志;-XX:+DisableExplicitGC標志自動將System.gc()調用轉換成一個空操作,為您提供運行代碼的機會,您自己看看System.gc()對于整個JVM執行有害還是有利。
2.HeapDumpOnOutOfMemoryError
并不是任何VM都支持所有命令行標志,Sun/Oracle的VM除外。查明一個標志是否被支持的最好方法是試用它,看它是否正常工作。倘若這些標志在技術上是不支持的,那么,使用它們您要承擔全部責任。如果這些標志中的任何一個使您的代碼、您的數據、您的服務器或您的一切消失得無影無蹤,我、Sun/Oracle和IBM都將不負責任。為以防萬一,建議先在虛擬(非常生產)環境中實驗。
在這個時刻您想要的是,在JVM消亡之際捕獲堆的一個快照--正好-XX:+HeapDumpOnOutOfMemoryError命令可以完成這一操作。
運行該命令通知JVM拍攝一個“堆轉儲快照”,并將其保存在一個文件中以便處理,通常使用jhat實用工具。您可以使用相應的-XX:HeapDumpPath標志指定到保存文件的實際路徑。(不管文件保存在哪,務必確保文件系統和/或Java流程必須要有權限配置,可以在其中寫入。)
3.bootclasspath
定期將一個類放入類路徑是很有幫助的,這類路徑與庫存JRE附帶的類路徑或者以某種方式擴展的JRE類路徑略有不同。。如果您想要擴展JRE,那么您定制的實現必須可以使用引導程序ClassLoader,該引導程序可以加載rt.jar中的 java.lang.Object及其所有相關文件。
盡管您可以非法打開rt.jar并將您的定制實現或新數據包移入其中,但從技術上您就違反了您下載JDK時同意的協議了。
相反,使用JVM自己的-Xbootclasspath選項,以及皮膚-Xbootclasspath/p和-Xbootclasspath/a。
-Xbootclasspath使您可以設置完整的引導類路徑(這通常包括一個對rt.jar的引用),以及一些其他JDK附帶的(不是 rt.jar的一部分)JAR文件。-Xbootclasspath/p將值前置到現有bootclasspath中,并將 -Xbootclasspath/a附加到其中。
例如,如果您修改了庫中的java.lang.Integer,并將修改放在一個子路徑mods下,那么-Xbootclasspath/amods參數將新Integer放在默認的參數前面。
4.verbose
對于虛擬的或任何類型的Java應用程序,-verbose是一個很有用的一級診斷使用程序。該標志有三個子標志:gc、class和jni。
開發人員嘗試尋找是否 JVM 垃圾收集器發生故障或者導致性能低下,通常首先要做的就是執行 gc。不幸的是,解釋 gc 輸出很麻煩 - 足夠寫一本書。更糟糕的是,在命令行中打印的輸出在不同的 Java 版本中或者不在不同的 JVM 中會發生改變,這使得正確解釋變得更難。
一般來說,如果垃圾收集器是一個分代收集器(多數“企業級”VMs都是)。某種虛擬標志將會出現,來指出一個全部清掃GC通路;在Sun JVM中,標志在GC輸出行的開始以“[FullGC…]”形式出現。
想要診斷ClassLoader和/或不匹配的類沖突,class可以幫上大忙。它不僅報告類何時加載,還報告類從何處加載,包括到JAR的路徑(如果來自JAR)。
jni很少使用,除了使用JNI或本地庫時。打開時,它將報告各種JNI事件,比如,本地庫何時加載,方法何時彈回;再一次強調,在不同JVM版本中,輸出會發生變化。
5.Command-line-X
-Xint,在解釋模式下運行JVM(對于測試JIT編譯器實際上是否對您的代碼起作用或者驗證是否JIT編譯器中有一個bug,這都很有用)。
-Xloggc:,和-verbose:gc做同樣的事,但是記錄一個文件而不輸出到命令行窗口。
JVM命令行選項時常發生變化,因此,定期查看是一個好主意。
“JVM命令行的標志介紹”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。