中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

IntelliJIDEA如何設(shè)置JVM運(yùn)行參數(shù)

小編給大家分享一下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=70GC后java堆中空閑量占的最大比例
-XX:MaxNewSize=size新生成對象能占用內(nèi)存的最大值
-XX:MaxPermSize=64m老生代對象能占用內(nèi)存的最大值
-XX:MinHeapFreeRatio=40GC后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)

成都網(wǎng)站建設(shè)公司
隆回县| 永吉县| 抚松县| 和田县| 乐业县| 陆丰市| 吉隆县| 法库县| 丽江市| 灵丘县| 尼木县| 乌海市| 邵武市| 老河口市| 桑日县| 喀喇沁旗| 灵丘县| 恩平市| 翁源县| 沿河| 拜城县| 威宁| 南皮县| 丁青县| 武鸣县| 南澳县| 砀山县| 枣阳市| 黄石市| 木里| 澄城县| 庆城县| 天全县| 酉阳| 台湾省| 澄江县| 文昌市| 平谷区| 绵竹市| 陇西县| 凤山县|