小編給大家分享一下IntelliJ IDEA如何設(shè)置JVM運(yùn)行參數(shù),希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
創(chuàng)新互聯(lián)專注于網(wǎng)站建設(shè),為客戶提供成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、網(wǎng)頁設(shè)計開發(fā)服務(wù),多年建網(wǎng)站服務(wù)經(jīng)驗(yàn),各類網(wǎng)站都可以開發(fā),成都品牌網(wǎng)站建設(shè),公司官網(wǎng),公司展示網(wǎng)站,網(wǎng)站設(shè)計,建網(wǎng)站費(fèi)用,建網(wǎng)站多少錢,價格優(yōu)惠,收費(fèi)合理。
打開 IDEA 安裝目錄,看到有一個 bin 目錄,其中有兩個 vmoptions 文件,需針對不同的JDK進(jìn)行配置:
32 位:idea.exe.vmoptions
64 位:idea64.exe.vmoptions
-Xms512m -Xmx1024m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=225m -XX:+UseConcMarkSweepGC -XX:SoftRefLRUPolicyMSPerMB=50 -ea -Dsun.io.useCanonCaches=false -Djava.net.preferIPv4Stack=true
上面列出的是idea64.exe.vmoptions
的默認(rèn)內(nèi)容,我們可以根據(jù)需要進(jìn)行修改。
各參數(shù)的含義分別為:
一、設(shè)置JVM內(nèi)存設(shè)置
1. 設(shè)置JVM內(nèi)存的參數(shù)有四個:
-Xmx Java Heap最大值,默認(rèn)值為物理內(nèi)存的1/4,最佳設(shè)值應(yīng)該視物理內(nèi)存大小及計算機(jī)內(nèi)其他內(nèi)存開銷而定;
-Xms Java Heap初始值,Server端JVM最好將-Xms和-Xmx設(shè)為相同值,開發(fā)測試機(jī)JVM可以保留默認(rèn)值;
-Xmn Java Heap Young區(qū)大小,不熟悉最好保留默認(rèn)值;
-Xss 每個線程的Stack大小,不熟悉最好保留默認(rèn)值;
2. 如何設(shè)置JVM內(nèi)存分配:
(1)當(dāng)在命令提示符下啟動并使用JVM時(只對當(dāng)前運(yùn)行的類Test生效):
java -Xmx128m -Xms64m -Xmn32m -Xss16m Test
(2)當(dāng)在集成開發(fā)環(huán)境下(如eclipse)啟動并使用JVM時:
a. 在eclipse根目錄下打開eclipse.ini,默認(rèn)內(nèi)容為(這里設(shè)置的是運(yùn)行當(dāng)前開發(fā)工具的JVM內(nèi)存分配):
-vmargs
-Xms40m
-Xmx256m
-vmargs表示以下為虛擬機(jī)設(shè)置參數(shù),可修改其中的參數(shù)值,也可添加-Xmn,-Xss,另外,eclipse.ini內(nèi)還可以設(shè)置非堆內(nèi)存,如:-XX:PermSize=56m,-XX:MaxPermSize=128m。
此處設(shè)置的參數(shù)值可以通過以下配置在開發(fā)工具的狀態(tài)欄顯示:
在eclipse根目錄下創(chuàng)建文件options,文件內(nèi)容為:org.eclipse.ui/perf/showHeapStatus=true
修改eclipse根目錄下的eclipse.ini文件,在開頭處添加如下內(nèi)容:
-debug
options
-vm
javaw.exe
重新啟動eclipse,就可以看到下方狀態(tài)條多了JVM信息。
b. 打開eclipse-窗口-首選項(xiàng)-Java-已安裝的JRE(對在當(dāng)前開發(fā)環(huán)境中運(yùn)行的java程序皆生效)
編輯當(dāng)前使用的JRE,在缺省VM參數(shù)中輸入:-Xmx128m -Xms64m -Xmn32m -Xss16m
c. 打開eclipse-運(yùn)行-運(yùn)行-Java應(yīng)用程序(只對所設(shè)置的java類生效)
選定需設(shè)置內(nèi)存分配的類-自變量,在VM自變量中輸入:-Xmx128m -Xms64m -Xmn32m -Xss16m
注:如果在同一開發(fā)環(huán)境中同時進(jìn)行了b和c設(shè)置,則b設(shè)置生效,c設(shè)置無效,如:
開發(fā)環(huán)境的設(shè)置為:-Xmx256m,而類Test的設(shè)置為:-Xmx128m -Xms64m,則運(yùn)行Test時生效的設(shè)置為:
-Xmx256m -Xms64m
(3)當(dāng)在服務(wù)器環(huán)境下(如Tomcat)啟動并使用JVM時(對當(dāng)前服務(wù)器環(huán)境下所以Java程序生效):
a. 設(shè)置環(huán)境變量:
變量名:CATALINA_OPTS
變量值:-Xmx128m -Xms64m -Xmn32m -Xss16m
b. 打開Tomcat根目錄下的bin文件夾,編輯catalina.bat,將其中的?TALINA_OPTS%(共有四處)替換為:-Xmx128m -Xms64m -Xmn32m -Xss16m
二、查看設(shè)置JVM內(nèi)存信息
Runtime.getRuntime().maxMemory(); //最大可用內(nèi)存,對應(yīng)-Xmx
Runtime.getRuntime().freeMemory(); //當(dāng)前JVM空閑內(nèi)存
Runtime.getRuntime().totalMemory(); //當(dāng)前JVM占用的內(nèi)存總數(shù),其值相當(dāng)于當(dāng)前JVM已使用的內(nèi)存及freeMemory()的總和
關(guān)于maxMemory(),freeMemory()和totalMemory():
maxMemory()為JVM的最大可用內(nèi)存,可通過-Xmx設(shè)置,默認(rèn)值為物理內(nèi)存的1/4,設(shè)值不能高于計算機(jī)物理內(nèi)存;
totalMemory()為當(dāng)前JVM占用的內(nèi)存總數(shù),其值相當(dāng)于當(dāng)前JVM已使用的內(nèi)存及freeMemory()的總和,會隨著JVM使用內(nèi)存的增加而增加;
freeMemory()為當(dāng)前JVM空閑內(nèi)存,因?yàn)镴VM只有在需要內(nèi)存時才占用物理內(nèi)存使用,所以freeMemory()的值一般情況下都很小,而 JVM實(shí)際可用內(nèi)存并不等于freeMemory(),而應(yīng)該等于maxMemory()-totalMemory()+freeMemory()。及其 設(shè)置JVM內(nèi)存分配。
官方文檔見:
http://docs.sun.com/source/819-0084/pt_tuningjava.html
java啟動參數(shù)共分為三類;
其一是標(biāo)準(zhǔn)參數(shù)(-),所有的JVM實(shí)現(xiàn)都必須實(shí)現(xiàn)這些參數(shù)的功能,而且向后兼容;
其二是非標(biāo)準(zhǔn)參數(shù)(-X),默認(rèn)jvm實(shí)現(xiàn)這些參數(shù)的功能,但是并不保證所有jvm實(shí)現(xiàn)都滿足,且不保證向后兼容;
其三是非Stable參數(shù)(-XX),此類參數(shù)各個jvm實(shí)現(xiàn)會有所不同,將來可能會隨時取消,需要慎重使用;
標(biāo)準(zhǔn)參數(shù)中比較有用的:
verbose
-verbose:class
輸出jvm載入類的相關(guān)信息,當(dāng)jvm報告說找不到類或者類沖突時可此進(jìn)行診斷。
-verbose:gc
輸出每次GC的相關(guān)情況。
-verbose:jni
輸出native方法調(diào)用的相關(guān)情況,一般用于診斷jni調(diào)用錯誤信息。
非標(biāo)準(zhǔn)參數(shù)又稱為擴(kuò)展參數(shù)
一般用到最多的是
-Xms512m 設(shè)置JVM促使內(nèi)存為512m。此值可以設(shè)置與-Xmx相同,以避免每次垃圾回收完成后JVM重新分配內(nèi)存。
-Xmx512m ,設(shè)置JVM最大可用內(nèi)存為512M。
-Xmn200m:設(shè)置年輕代大小為200M。整個堆大小=年輕代大小 + 年老代大小 + 持久代大小。持久代一般固定大小為64m,所以增大年輕代后,將會減小年老代大小。此值對系統(tǒng)性能影響較大,Sun官方推薦配置為整個堆的3/8。
-Xss128k:
設(shè)置每個線程的堆棧大小。JDK5.0以后每個線程堆棧大小為1M,以前每個線程堆棧大小為256K。更具應(yīng)用的線程所需內(nèi)存大小進(jìn)行調(diào)整。在相同物理內(nèi) 存下,減小這個值能生成更多的線程。但是操作系統(tǒng)對一個進(jìn)程內(nèi)的線程數(shù)還是有限制的,不能無限生成,經(jīng)驗(yàn)值在3000~5000左右。
-Xloggc:file
與-verbose:gc功能類似,只是將每次GC事件的相關(guān)情況記錄到一個文件中,文件的位置最好在本地,以避免網(wǎng)絡(luò)的潛在問題,
若與verbose命令同時出現(xiàn)在命令行中,則以-Xloggc為準(zhǔn)。
-Xprof
跟蹤正運(yùn)行的程序,并將跟蹤數(shù)據(jù)在標(biāo)準(zhǔn)輸出輸出;適合于開發(fā)環(huán)境調(diào)試。
用-XX作為前綴的參數(shù)列表在jvm中可能是不健壯的,SUN也不推薦使用,后續(xù)可能會在沒有通知的情況下就直接取消了;但是由于這些參數(shù)中的確有很多是對我們很有用的,比如我們經(jīng)常會見到的-XX:PermSize、-XX:MaxPermSize等等;
首先來介紹行為參數(shù):
參數(shù)及其默認(rèn)值 | 描述 |
-XX:-DisableExplicitGC | 禁止調(diào)用System.gc();但jvm的gc仍然有效 |
-XX:+MaxFDLimit | 最大化文件描述符的數(shù)量限制 |
-XX:+ScavengeBeforeFullGC | 新生代GC優(yōu)先于Full GC執(zhí)行 |
-XX:+UseGCOverheadLimit | 在拋出OOM之前限制jvm耗費(fèi)在GC上的時間比例 |
-XX:-UseConcMarkSweepGC | 對老生代采用并發(fā)標(biāo)記交換算法進(jìn)行GC |
-XX:-UseParallelGC | 啟用并行GC |
-XX:-UseParallelOldGC | 對Full GC啟用并行,當(dāng)-XX:-UseParallelGC啟用時該項(xiàng)自動啟用 |
-XX:-UseSerialGC | 啟用串行GC |
-XX:+UseThreadPriorities | 啟用本地線程優(yōu)先級 |
上面表格中黑體的三個參數(shù)代表著jvm中GC執(zhí)
行的三種方式,即串行、并行、并發(fā);
串行(SerialGC)是jvm的默認(rèn)GC方式,一般適用于小型應(yīng)用和單處理器,算法比較簡單,GC效率也較高,但可能會給應(yīng)用帶來停頓;
并行(ParallelGC)是指GC運(yùn)行時,對應(yīng)用程序運(yùn)行沒有影響,GC和app兩者的線程在并發(fā)執(zhí)行,這樣可以最大限度不影響app的運(yùn)行;
并發(fā)(ConcMarkSweepGC)是指多個線程并發(fā)執(zhí)行GC,一般適用于多處理器系統(tǒng)中,可以提高GC的效率,但算法復(fù)雜,系統(tǒng)消耗較大;
性能調(diào)優(yōu)參數(shù)列表:
參數(shù)及其默認(rèn)值 | 描述 |
-XX:LargePageSizeInBytes=4m | 設(shè)置用于Java堆的大頁面尺寸 |
-XX:MaxHeapFreeRatio=70 | GC后java堆中空閑量占的最大比例 |
-XX:MaxNewSize=size | 新生成對象能占用內(nèi)存的最大值 |
-XX:MaxPermSize=64m | 老生代對象能占用內(nèi)存的最大值 |
-XX:MinHeapFreeRatio=40 | GC后java堆中空閑量占的最小比例 |
-XX:NewRatio=2 | 新生代內(nèi)存容量與老生代內(nèi)存容量的比例 |
-XX:NewSize=2.125m | 新生代對象生成時占用內(nèi)存的默認(rèn)值 |
-XX:ReservedCodeCacheSize=32m | 保留代碼占用的內(nèi)存容量 |
-XX:ThreadStackSize=512 | 設(shè)置線程棧大小,若為0則使用系統(tǒng)默認(rèn)值 |
-XX:+UseLargePages | 使用大頁面內(nèi)存 |
我們在日常性能調(diào)優(yōu)中基本上都會用到以上黑體的這幾個屬性;
調(diào)試參數(shù)列表:
參數(shù)及其默認(rèn)值 | 描述 |
-XX:-CITime | 打印消耗在JIT編譯的時間 |
-XX:ErrorFile=./hs_err_pid<pid>.log | 保存錯誤日志或者數(shù)據(jù)到文件中 |
-XX:-ExtendedDTraceProbes | 開啟solaris特有的dtrace探針 |
-XX:HeapDumpPath=./java_pid<pid>.hprof | 指定導(dǎo)出堆信息時的路徑或文件名 |
-XX:-HeapDumpOnOutOfMemoryError | 當(dāng)首次遭遇OOM時導(dǎo)出此時堆中相關(guān)信息 |
-XX: | 出現(xiàn)致命ERROR之后運(yùn)行自定義命令 |
-XX:OnOutOfMemoryError="<cmd args>;<cmd args>" | 當(dāng)首次遭遇OOM時執(zhí)行自定義命令 |
-XX:-PrintClassHistogram | 遇到Ctrl-Break后打印類實(shí)例的柱狀信息,與jmap -histo功能相同 |
-XX:-PrintConcurrentLocks | 遇到Ctrl-Break后打印并發(fā)鎖的相關(guān)信息,與jstack -l功能相同 |
-XX:-PrintCommandLineFlags | 打印在命令行中出現(xiàn)過的標(biāo)記 |
-XX:-PrintCompilation | 當(dāng)一個方法被編譯時打印相關(guān)信息 |
-XX:-PrintGC | 每次GC時打印相關(guān)信息 |
-XX:-PrintGC Details | 每次GC時打印詳細(xì)信息 |
-XX:-PrintGCTimeStamps | 打印每次GC的時間戳 |
-XX:-TraceClassLoading | 跟蹤類的加載信息 |
-XX:-TraceClassLoadingPreorder | 跟蹤被引用到的所有類的加載信息 |
-XX:-TraceClassResolution | 跟蹤常量池 |
-XX:-TraceClassUnloading | 跟蹤類的卸載信息 |
-XX:-TraceLoaderConstraints | 跟蹤類加載器約束的相關(guān)信息 |
看完了這篇文章,相信你對“IntelliJ IDEA如何設(shè)置JVM運(yùn)行參數(shù)”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
網(wǎng)站標(biāo)題:IntelliJIDEA如何設(shè)置JVM運(yùn)行參數(shù)
本文鏈接:http://m.rwnh.cn/article2/pdidic.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、商城網(wǎng)站、定制開發(fā)、、靜態(tài)網(wǎng)站、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)