您好,登錄后才能下訂單哦!
如何理解JVM for Linux JIT診斷技術,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
JVM有很多值得學習的地方,簡要介紹Just-In-Time(JIT)編譯器和Mixed ModeInterpreter(MMI)優化技術,在IBM的JVM1.3.1和1.4.2中使用了這兩種技術,它們對于從SunHotspotJVM上遷移過來的Java程序可能產生影響。
JVM for Linux JIT 診斷技術簡介
“一次編寫,到處運行”(WORA)的原則只有在將純Java™的字節碼從一個平臺的某個特定版本的Java虛擬機(JVM)移植到另外一個不同平臺上完全相同版本的JVM上時才適用。
然而,有時這種遷移過程并不是無縫的。可以對這個遷移過程產生影響的一個因素是不同供應商的優化技術的內部實現之間存在差異。
在將一個Java程序從使用SunJDK的平臺遷移到使用IBMJDK的平臺上時,重要的是要了解在這兩個供應商的JVM中使用的優化技術之間的差異,這些差異可能會對程序產生影響,以及如何通過調節IBM JVM中可用的優化機制來獲得更好的性能。
本文著重介紹對于在JVM for Linux JIT中碰到的問題的診斷,在從SunHotSpotJVM遷移到IBM基于JVM for Linux JIT的JVM時可能會碰到這些問題。
雖然本文中介紹的大部分內容對于IBMJVM1.3.1和1.4.2都是普遍適用的,但是尤其適用于IBMJVM1.3.1和JVM1.4.2forLinux,包括POWER和PowerPC架構上的Linux。
在Sun的JVM1.3.1中,JIT和HotSpot編譯器都已經包含其中了,可以使用-server或-hotspot選項(默認為客戶機HotSpotVM)來調用,使用-classic選項調用JIT,-hotspot選項是隱含的默認值。在SunJDK1.4.1及之后的版本中,只能使用HotSpot了。IBMJVM1.3.1和1.4.2使用了JIT和MMI的組合,這是默認的運行模式,可以實現與HotSpot相同的功能。
JVM for Linux JIT和MMI
用來提高Java程序性能的工具是Just-In-Time(JIT)編譯器。JVM for Linux JIT是一個代碼生成器,它將Java字節碼轉換成宿主平臺的本地代碼。Java程序使用JIT調用時的運行速度通常都比使用解釋程序執行字節碼時的速度更快。
當JVM啟動時,會有很多方法被加載到JVM中并執行。
如果JIT被禁用了,那么JVM啟動會很快,但是在大部分情況中,運行程序的速度都會與解釋字節碼的速度一樣慢。如果JIT被啟用了,但是并沒有使用JIT的一些自適應式優化機制,就會試圖在啟動時對所有方法進行編譯。對于諸如applet之類的小程序來說,當啟動JVM的時間長于運行程序的時間時,就可能會成為問題。
IBM JVMMixedModeInterpreter(MMI)與JIT緊密地結合在一起,它可以減輕這個問題。它可以用于與HotSpotVM相同的目的,將編譯方法延伸到JVM的生命期之外。除了其他特性之外,MMI還可以計算一個特定的方法被執行了多少次。為了達到平衡的性能,MMI對于IBMJVM支持的每種平臺都有一個默認的上限計數器,這是經過仔細選擇的,并經過了廣泛的測試和研究。
每執行一次方法,該方法在MMI中的上限計數器就減1。當一個方法的上限計數器達到零(0)時,就可以使用JIT將這個方法編譯成本地代碼了。因此,與HotSpotVM一樣,高頻率使用的方法——“熱點”——都會在啟動JVM之后由JIT進行編譯,而低頻度使用的方法則會在之后進行編譯,或者可能在整個JVM進程的生命周期中都不會被編譯。
IBM JVM1.3.1和1.4.2還為改進某些Java程序的啟動時間而提供了一個非標準的選項-Xquickstart。-Xquickstart選項會導致使用優化選項的子集來運行JIT;也就是說,快速編譯的方法。這個選項適用于短期運行的程序,特別是那些執行時間不集中在少量的“熱點”方法中的程序。如果-Xquickstart選項用在長時間運行的程序上,而這些程序又包含一些熱點方法,那么這個選項就可能會導致性能的降低。
與其他非標準的-X選項一樣,-Xquickstart選項的實現和存在都可能不加通知就會修改。
可以減小MMI上限計數器,從而加速JIT編譯一個方法的過程;或者增大它以達到相反的效果。這是通過使用一個環境變量IBM_MIXED_MODE_THRESHOLD實現的,與其他環境變量一樣,需要在運行JVM進程的shell實例中進行設置。自然,這個變量是在啟動JVM進程之前設置的,對于在JVM中執行的所有方法都是有效的。
將IBM_MIXED_MODE_THRESHOLD設置為0可以禁用MMI,這樣,所有的方法在***加載到JVM中時就可以立即使用JIT進行編譯。
IBM JVM運行時模式如下:
◆MMI和JIT都啟用
這是默認的IBMJVM設置。
◆MMI禁用,JIT啟用
所有的方法都是在***運行之前編譯的,即JVM的啟動時間可能會很慢,但是后來的性能會很好。
◆MMI和JIT都禁用
JVM是一個純解釋系統。所有的代碼都不會進行編譯。禁用JVM for Linux JIT同時還會自動禁用MMI,并將IBM_MIXED_MODE_THRESHOLD設置為0,這樣可以有效地禁用MMI,但是不會禁用JIT。
MMI是一個非常有效的解釋器,利用宿主平臺上的程序集代碼來達到***的優化。雖然JIT并不是JVM的一個集成部分,但卻以一個共享庫(libjitc)的形式提供了,它與MMI緊密地結合在一起,JVM for Linux JIT和MMI是IBMJVM中緊密結合的兩種技術。
在JavaHotSpotVM或經典的JIT模式中使用的是SunJVM1.3.1,Sun的JIT實現并不與IBM的JIT完全相同;SunHotSpotJVM1.4.1中根本沒有JIT。當將Java程序從SunJVM1.3.1或SunJVM1.4.1遷移到IBMJVM上時,在一些非常罕見的情況中可能會出現問題,問題的范圍從性能的下降,到代碼會產生不正確的結果,以及JVM的掛起、崩潰和出現一些異常。
關于如何理解JVM for Linux JIT診斷技術問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。