真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java虛擬機中常用vm參數(shù)的示例分析

這篇文章主要為大家展示了“Java虛擬機中常用vm參數(shù)的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“Java虛擬機中常用vm參數(shù)的示例分析”這篇文章吧。

成都創(chuàng)新互聯(lián)服務(wù)緊隨時代發(fā)展步伐,進行技術(shù)革新和技術(shù)進步,經(jīng)過10年的發(fā)展和積累,已經(jīng)匯集了一批資深網(wǎng)站策劃師、設(shè)計師、專業(yè)的網(wǎng)站實施團隊以及高素質(zhì)售后服務(wù)人員,并且完全形成了一套成熟的業(yè)務(wù)流程,能夠完全依照客戶要求對網(wǎng)站進行成都做網(wǎng)站、網(wǎng)站設(shè)計、建設(shè)、維護、更新和改版,實現(xiàn)客戶網(wǎng)站對外宣傳展示的首要目的,并為客戶企業(yè)品牌互聯(lián)網(wǎng)化提供全面的解決方案。

1 JVM參數(shù)簡介

首先想說的是其實這些參數(shù)我們并不是陌生的,在平時的開發(fā)和使用中經(jīng)常都會遇到,只是在平時缺少一個比較系統(tǒng)的總結(jié),所以,對這些參數(shù)感覺是很陌生的,所以,通過這篇文章的總結(jié),我相信你一定都會對這些參數(shù)熟稔于心,做做心中有數(shù)。

在Java虛擬機的參數(shù)中,其實可以把這些參數(shù)分為三類,當然,這是針對JDK1.6來說的,如果對于JDK1.8,那么就不是這么分類的了,但是,由于這兩個版本很多常用的參數(shù)的差別是不大的,所以這篇文章就先介紹JDK1.6的VM參數(shù)。

主要可以分為以下三類:

  • 標準參數(shù)(-),所有的JVM實現(xiàn)都必須實現(xiàn)這些參數(shù)的功能,而且向后兼容。

  • 非標準參數(shù)(-X),默認JVM實現(xiàn)這些參數(shù)的功能,但是并不保證所有JVM實現(xiàn)都滿足,且不保證向后兼容。

  • 非Stable參數(shù)(-XX),此類參數(shù)各個JVM實現(xiàn)會有所不同,將來可能會隨時取消,需要慎重使用。

雖然是這么分類的,實際上呢,非標準參數(shù)和非穩(wěn)定的參數(shù)實際的使用中還是用的非常的多的,在后面的文章的介紹中你就會發(fā)現(xiàn)。

2 標準參數(shù)

這一類參數(shù)可以說是我們剛剛開始Java是就用的非常多的參數(shù)了,比如java -versionjava -jar等等,我們在CMD中輸入java -help就可以獲得Java當前版本的所有標準參數(shù)了。

Java虛擬機中常用vm參數(shù)的示例分析

如上圖就是JDK1.8的所有標準參數(shù)了,下面我們將介紹一些我們會用的比較多的參數(shù)。

  • -client

以client模式啟動JVM,這種方式啟動速度快,但運行時性能和內(nèi)存管理效率不高,適合客戶端程序或者開發(fā)調(diào)試。

  • -server

以server模式啟動JVM,與client情況恰好相反。適合生產(chǎn)環(huán)境,適用于

Java虛擬機中常用vm參數(shù)的示例分析

如上就是我電腦的JVM的路徑。

定義系統(tǒng)的全局屬性值,如配置文件地址等,如果value有空格,則需要使用雙引號。

另外用System.getProperty("hello")可以獲得這些定義的屬性值,在代碼中也可以用System.setProperty("hello","world")的形式來定義屬性。

如鍵值對設(shè)置為hello=world。
Java虛擬機中常用vm參數(shù)的示例分析

System.out.println(System.getProperty("hello"));

運行結(jié)果就是:
Java虛擬機中常用vm參數(shù)的示例分析

查詢GC問題最常用的命令之一,參數(shù)如下:
-verbose:class
輸出JVM載入類的相關(guān)信息,當JVM報告說找不到類或者類沖突時可此進行診斷。
-verbose:gc
輸出每次GC的相關(guān)情況。
-verbose:jni
輸出native方法調(diào)用的相關(guān)情況,一般用于診斷jni調(diào)用錯誤信息。

另外,控制臺輸出GC信息還可以使用如下命令:

在JVM的啟動參數(shù)中加入-XX:+PrintGC -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCApplicationStoppedTime,按照參數(shù)的順序分別輸出GC的簡要信息,GC的詳細信息、GC的時間信息及GC造成的應(yīng)用暫停的時間。

3 非標準參數(shù)

非標注的參數(shù)主要是關(guān)于Java內(nèi)存區(qū)域的設(shè)置參數(shù),所以在看這些參數(shù)之前,應(yīng)該先查看Java內(nèi)存區(qū)域的基礎(chǔ)知識,可以查看這篇文章:深入理解Java虛擬機-Java內(nèi)存區(qū)域透徹分析。

非標準參數(shù)實在標準參數(shù)的基礎(chǔ)上的一些擴充參數(shù),可以輸入java -X,獲得當前JVM支持的非標準參數(shù)。

Java虛擬機中常用vm參數(shù)的示例分析

從圖片中可以看出來,這些非標準的參數(shù)其實不多的,下面我們再 講解一些比較常用的參數(shù)。

新生代內(nèi)存大小的最大值,包括E區(qū)和兩個S區(qū)的總和。設(shè)置方法:-Xmn512m、-Xmn2g。

初始堆的大小,也是堆大小的最小值,默認值是總共的物理內(nèi)存/64(且小于1G)。默認情況下,當堆中可用內(nèi)存小于40%,堆內(nèi)存會開始增加,一直增加到-Xmx的大小。

堆的最大值,默認值是總共的物理內(nèi)存/64(且小于1G),默認情況下,當堆中可用內(nèi)存大于70%,堆內(nèi)存會開始減少,一直減小到-Xms的大小。

因此,為了避免這種浮動,所以在設(shè)置-Xms-Xmx參數(shù)時,一般會設(shè)置成一樣的,能夠提高性能。

另外,官方默認的配置為年老代大小:年輕代大小=2:1左右,使用-XX:NewRatio可以設(shè)置年老代和年輕代之比,例如,-XX:NewRatio=4,表示年老代:年輕代=4:1

參數(shù)實例

設(shè)置-Xms、-Xmn-Xmx參數(shù)分別為-Xms512m -Xmx512m -Xmn128m。同時設(shè)置新生代和老生代之比為1:4,E:S0:S1=8:1:1。

**
 * @ClassName MethodTest
 * @Description vm參數(shù)設(shè)置:-Xms512m -Xmx512m -Xmn128m -XX:NewRatio=4 -XX:SurvivorRatio=8 
 * @Author 歐陽思海
 * @Date 2019/11/25 20:06
 * @Version 1.0
 **/

public class MethodTest {

    public static void main(String[] args) {
        List list = new ArrayList();
        long i = 0;
        while (i < 1000000000) {
            System.out.println(i);
            list.add(String.valueOf(i++).intern());
        }
    }
}

運行之后,用VisualVM查看相關(guān)信息是否正確。

當我們沒有設(shè)置-XX:NewRatio=4 -XX:SurvivorRatio=8時,使用官方默認的情況如下:

Java虛擬機中常用vm參數(shù)的示例分析

上圖可以看出,新生代(Eden Space + Survivor 0 + Survivor 1):老年代(Old Gen)≈ 1:2。

當我們設(shè)置了-XX:NewRatio=4 -XX:SurvivorRatio=8時,情況如下:

Java虛擬機中常用vm參數(shù)的示例分析

變成了新生代(Eden Space + Survivor 0 + Survivor 1):老年代(Old Gen)≈ 1:4,Eden Space:Survivor 0: Survivor 1 = 8:1:1。

Java虛擬機中常用vm參數(shù)的示例分析

從上圖可知,堆的信息是正確的。

設(shè)置每個線程的棧內(nèi)存,默認1M,一般來說是不需要改的。

跟蹤正運行的程序,并將跟蹤數(shù)據(jù)在標準輸出輸出;適合于開發(fā)環(huán)境調(diào)試。

禁用類垃圾收集,關(guān)閉針對class的gc功能;因為其阻止內(nèi)存回收,所以可能會導致OutOfMemoryError錯誤,慎用。

開啟增量gc(默認為關(guān)閉);這有助于減少長時間GC時應(yīng)用程序出現(xiàn)的停頓;但由于可能和應(yīng)用程序并發(fā)執(zhí)行,所以會降低CPU對應(yīng)用的處理能力。

-verbose:gc功能類似,只是將每次GC事件的相關(guān)情況記錄到一個文件中,文件的位置最好在本地,以避免網(wǎng)絡(luò)的潛在問題。
若與verbose命令同時出現(xiàn)在命令行中,則以-Xloggc為準。

在解釋模式(interpreted mode)下,-Xint標記會強制JVM執(zhí)行所有的字節(jié)碼,這會降低運行速度,通常低10倍或更多。

-Xcomp參數(shù)與它(-Xint)正好相反,JVM在第一次使用時會把所有的字節(jié)碼編譯成本地代碼,從而帶來最大程度的優(yōu)化。

然而,很多應(yīng)用在使用-Xcomp也會有一些性能損失,當然這比使用-Xint損失的少,原因是-xcomp沒有讓JVM啟用JIT編譯器的全部功能。JIT編譯器可以對是否需要編譯做判斷,如果所有代碼都進行編譯的話,對于一些只執(zhí)行一次的代碼就沒有意義了。

-Xmixed是混合模式,這是JVM默認的模式,也是推薦使用的模式。將解釋模式與編譯模式進行混合使用,由JVM自己決定。

4 非Stable參數(shù)

這類參數(shù)你一看官網(wǎng)以為不能使用呢,官網(wǎng)給你的建議就是這些參數(shù)不穩(wěn)定,慎用,其實這主要的原因還是因為每個公司的實現(xiàn)都是不一樣的,所以就是導致不穩(wěn)定。但是呢,在實際的使用中卻是非常的多的,而且這部分的參數(shù)很重要。

這些參數(shù)大致可以分為三類:

下面還是先羅列一些比較常用的參數(shù),其實,這些文章很多了,這里主要還是做一個總結(jié),以后自己看文章的時候比較方便,如果有同行看到了文章,你可以參考參考,還是很有幫助的。

另外,選取其中的一些參數(shù)做一些例子來解釋,這樣也能夠更加的形象。

注意:以下參數(shù)都是JDK1.7及以下可以使用。

參數(shù)及其默認值描述
-XX:LargePageSizeInBytes=4m設(shè)置用于Java堆的大頁面尺寸
-XX:MaxHeapFreeRatio=70GC后java堆中空閑量占的最大比例
-XX:MinHeapFreeRatio=40GC后java堆中空閑量占的最小比例
-XX:MaxNewSize=size新生成對象能占用內(nèi)存的最大值
-XX:MaxPermSize=64m老生代對象能占用內(nèi)存的最大值
-XX:NewRatio=2新生代內(nèi)存容量與老生代內(nèi)存容量的比例
-XX:NewSize=2.125m新生代對象生成時占用內(nèi)存的默認值
-XX:ReservedCodeCacheSize=32m保留代碼占用的內(nèi)存容量
-XX:ThreadStackSize=512設(shè)置線程棧大小,若為0則使用系統(tǒng)默認值
-XX:+UseLargePages使用大頁面內(nèi)存
參數(shù)及其默認值描述
-XX:+ScavengeBeforeFullGC新生代GC優(yōu)先于Full GC執(zhí)行
-XX:+UseGCOverheadLimit在拋出OOM之前限制jvm耗費在GC上的時間比例
-XX:-UseParNewGC打開此開關(guān),使用ParNew+Serial Old收集器
-XX:-UseConcMarkSweepGC使用ParNew+CMS+Serial Old收集器對老生代采用并發(fā)標記交換算法進行GC
-XX:-UseParallelGC啟用并行GC,使用ParallelScavenge+Serial Old收集器
-XX:-UseParallelOldGC對Full GC啟用并行,當-XX:-UseParallelGC啟用時該項自動啟用,ParallelScavenge+Parallel Old收集器
-XX:-UseSerialGC啟用串行GC
-XX:+UseG1GC使用垃圾優(yōu)先(G1)收集器
-XX:SurvivorRatio=nEden區(qū)域與Survivor區(qū)域大小之比。預設(shè)值為8
-XX:PretenureSizeThreshold=n直接晉升到老年代的對象大小,設(shè)置這個參數(shù)之后,大于這個參數(shù)的對象直接進入到老年代分配
-XX:MaxTenuringThreshold=n晉升到老年代的對象年齡,每個對象在堅持過一次Minor GC之后,年齡加1,當超過這個值之后就進入老年代。預設(shè)值為15
-XX:+UseAdaptiveSizePolicy動態(tài)調(diào)整Java堆中各個區(qū)域的大小以及進入老年代的年齡
-XX:ParallelGCThreads=n設(shè)置并行收集器收集時使用的CPU數(shù)。并行收集線程數(shù)
-XX:MaxGCPauseMillis=n設(shè)置并行收集最大暫停時間
-XX:GCTimeRatio=n設(shè)置垃圾回收時間占程序運行時間的百分比。公式為1/(1+N)
-XX:+UseThreadPriorities啟用本地線程優(yōu)先級
-XX:-DisableExplicitGC禁止調(diào)用System.gc();但jvm的gc仍然有效
-XX:+MaxFDLimit最大化文件描述符的數(shù)量限制

前面6個參數(shù)都是關(guān)于垃圾收集器的行為參數(shù),也是經(jīng)常會用到的參數(shù)。

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

以上是“Java虛擬機中常用vm參數(shù)的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


當前題目:Java虛擬機中常用vm參數(shù)的示例分析
本文來源:
http://weahome.cn/article/pspigs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部