国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - IntelliJ IDEA設置JVM運行參數的操作方法

IntelliJ IDEA設置JVM運行參數的操作方法

2021-04-09 11:04Xeon-Shao Java教程

這篇文章主要介紹了IntelliJ IDEA設置JVM運行參數的操作方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

打開 IDEA 安裝目錄,看到有一個 bin 目錄,其中有兩個 vmoptions 文件,需針對不同的JDK進行配置:

32 位:idea.exe.vmoptions
64 位:idea64.exe.vmoptions

?
1
2
3
4
5
6
7
8
9
-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的默認內容,我們可以根據需要進行修改。

各參數的含義分別為:

一、設置JVM內存設置

1. 設置JVM內存的參數有四個:

-Xmx   Java Heap最大值,默認值為物理內存的1/4,最佳設值應該視物理內存大小及計算機內其他內存開銷而定;

-Xms   Java Heap初始值,Server端JVM最好將-Xms和-Xmx設為相同值,開發測試機JVM可以保留默認值;

-Xmn   Java Heap Young區大小,不熟悉最好保留默認值;

-Xss   每個線程的Stack大小,不熟悉最好保留默認值;

2. 如何設置JVM內存分配:

(1)當在命令提示符下啟動并使用JVM時(只對當前運行的類Test生效):

?
1
java -Xmx128m -Xms64m -Xmn32m -Xss16m Test

(2)當在集成開發環境下(如eclipse)啟動并使用JVM時:

a. 在eclipse根目錄下打開eclipse.ini,默認內容為(這里設置的是運行當前開發工具的JVM內存分配):

  • -vmargs 
  • -Xms40m 
  • -Xmx256m

-vmargs表示以下為虛擬機設置參數,可修改其中的參數值,也可添加-Xmn,-Xss,另外,eclipse.ini內還可以設置非堆內存,如:-XX:PermSize=56m,-XX:MaxPermSize=128m。

此處設置的參數值可以通過以下配置在開發工具的狀態欄顯示:

在eclipse根目錄下創建文件options,文件內容為:org.eclipse.ui/perf/showHeapStatus=true

修改eclipse根目錄下的eclipse.ini文件,在開頭處添加如下內容:

  • -debug 
  • options 
  • -vm 
  • javaw.exe

重新啟動eclipse,就可以看到下方狀態條多了JVM信息。

b. 打開eclipse-窗口-首選項-Java-已安裝的JRE(對在當前開發環境中運行的java程序皆生效)

編輯當前使用的JRE,在缺省VM參數中輸入:-Xmx128m -Xms64m -Xmn32m -Xss16m

c. 打開eclipse-運行-運行-Java應用程序(只對所設置的java類生效)

選定需設置內存分配的類-自變量,在VM自變量中輸入:-Xmx128m -Xms64m -Xmn32m -Xss16m

注:如果在同一開發環境中同時進行了b和c設置,則b設置生效,c設置無效,如:

開發環境的設置為:-Xmx256m,而類Test的設置為:-Xmx128m -Xms64m,則運行Test時生效的設置為:

-Xmx256m -Xms64m

(3)當在服務器環境下(如Tomcat)啟動并使用JVM時(對當前服務器環境下所以Java程序生效):

a. 設置環境變量:

變量名:CATALINA_OPTS

變量值:-Xmx128m -Xms64m -Xmn32m -Xss16m

b. 打開Tomcat根目錄下的bin文件夾,編輯catalina.bat,將其中的?TALINA_OPTS%(共有四處)替換為:-Xmx128m -Xms64m -Xmn32m -Xss16m

二、查看設置JVM內存信息

Runtime.getRuntime().maxMemory(); //最大可用內存,對應-Xmx

Runtime.getRuntime().freeMemory(); //當前JVM空閑內存

Runtime.getRuntime().totalMemory(); //當前JVM占用的內存總數,其值相當于當前JVM已使用的內存及freeMemory()的總和

關于maxMemory(),freeMemory()和totalMemory():

maxMemory()為JVM的最大可用內存,可通過-Xmx設置,默認值為物理內存的1/4,設值不能高于計算機物理內存;

totalMemory()為當前JVM占用的內存總數,其值相當于當前JVM已使用的內存及freeMemory()的總和,會隨著JVM使用內存的增加而增加;

freeMemory()為當前JVM空閑內存,因為JVM只有在需要內存時才占用物理內存使用,所以freeMemory()的值一般情況下都很小,而 JVM實際可用內存并不等于freeMemory(),而應該等于maxMemory()-totalMemory()+freeMemory()。及其 設置JVM內存分配。

官方文檔見:

http://docs.sun.com/source/819-0084/pt_tuningjava.html

java啟動參數共分為三類;

其一是標準參數(-),所有的JVM實現都必須實現這些參數的功能,而且向后兼容;
其二是非標準參數(-X),默認jvm實現這些參數的功能,但是并不保證所有jvm實現都滿足,且不保證向后兼容;
其三是非Stable參數(-XX),此類參數各個jvm實現會有所不同,將來可能會隨時取消,需要慎重使用;

標準參數中比較有用的:

verbose
-verbose:class
 輸出jvm載入類的相關信息,當jvm報告說找不到類或者類沖突時可此進行診斷。
-verbose:gc
 輸出每次GC的相關情況。
-verbose:jni
 輸出native方法調用的相關情況,一般用于診斷jni調用錯誤信息。

非標準參數又稱為擴展參數

一般用到最多的是

-Xms512m  設置JVM促使內存為512m。此值可以設置與-Xmx相同,以避免每次垃圾回收完成后JVM重新分配內存。

-Xmx512m ,設置JVM最大可用內存為512M。

-Xmn200m:設置年輕代大小為200M。整個堆大小=年輕代大小 + 年老代大小 + 持久代大小。持久代一般固定大小為64m,所以增大年輕代后,將會減小年老代大小。此值對系統性能影響較大,Sun官方推薦配置為整個堆的3/8。

-Xss128k:

設置每個線程的堆棧大小。JDK5.0以后每個線程堆棧大小為1M,以前每個線程堆棧大小為256K。更具應用的線程所需內存大小進行調整。在相同物理內 存下,減小這個值能生成更多的線程。但是操作系統對一個進程內的線程數還是有限制的,不能無限生成,經驗值在3000~5000左右。

-Xloggc:file

 與-verbose:gc功能類似,只是將每次GC事件的相關情況記錄到一個文件中,文件的位置最好在本地,以避免網絡的潛在問題,

若與verbose命令同時出現在命令行中,則以-Xloggc為準。
-Xprof

 跟蹤正運行的程序,并將跟蹤數據在標準輸出輸出;適合于開發環境調試。

用-XX作為前綴的參數列表在jvm中可能是不健壯的,SUN也不推薦使用,后續可能會在沒有通知的情況下就直接取消了;但是由于這些參數中的確有很多是對我們很有用的,比如我們經常會見到的-XX:PermSize、-XX:MaxPermSize等等;

首先來介紹行為參數:

 

參數及其默認值 描述
-XX:-DisableExplicitGC 禁止調用System.gc();但jvm的gc仍然有效
-XX:+MaxFDLimit 最大化文件描述符的數量限制
-XX:+ScavengeBeforeFullGC 新生代GC優先于Full GC執行
-XX:+UseGCOverheadLimit 在拋出OOM之前限制jvm耗費在GC上的時間比例
-XX:-UseConcMarkSweepGC 對老生代采用并發標記交換算法進行GC
-XX:-UseParallelGC 啟用并行GC
-XX:-UseParallelOldGC 對Full GC啟用并行,當-XX:-UseParallelGC啟用時該項自動啟用
-XX:-UseSerialGC 啟用串行GC
-XX:+UseThreadPriorities 啟用本地線程優先級

 

上面表格中黑體的三個參數代表著jvm中GC執

行的三種方式,即串行、并行、并發;

串行(SerialGC)是jvm的默認GC方式,一般適用于小型應用和單處理器,算法比較簡單,GC效率也較高,但可能會給應用帶來停頓;

并行(ParallelGC)是指GC運行時,對應用程序運行沒有影響,GC和app兩者的線程在并發執行,這樣可以最大限度不影響app的運行;

并發(ConcMarkSweepGC)是指多個線程并發執行GC,一般適用于多處理器系統中,可以提高GC的效率,但算法復雜,系統消耗較大;

性能調優參數列表:

 

參數及其默認值 描述
-XX:LargePageSizeInBytes=4m 設置用于Java堆的大頁面尺寸
-XX:MaxHeapFreeRatio=70 GC后java堆中空閑量占的最大比例
-XX:MaxNewSize=size 新生成對象能占用內存的最大值
-XX:MaxPermSize=64m 老生代對象能占用內存的最大值
-XX:MinHeapFreeRatio=40 GC后java堆中空閑量占的最小比例
-XX:NewRatio=2 新生代內存容量與老生代內存容量的比例
-XX:NewSize=2.125m 新生代對象生成時占用內存的默認值
-XX:ReservedCodeCacheSize=32m 保留代碼占用的內存容量
-XX:ThreadStackSize=512 設置線程棧大小,若為0則使用系統默認值
-XX:+UseLargePages 使用大頁面內存

 

我們在日常性能調優中基本上都會用到以上黑體的這幾個屬性;

調試參數列表:

 

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

 

總結

以上所述是小編給大家介紹的IntelliJ IDEA設置JVM運行參數的操作方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!

原文鏈接:http://blog.csdn.net/sdujava2011/article/details/50086933

延伸 · 閱讀

精彩推薦
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 欧美精品一区二区在线观看 | 日本一区二区不卡在线观看 | 亚洲精品视频在线看 | 欧美一级片在线观看 | 久久久久久久久久久影视 | 亚洲精品高潮呻吟久久av | 色偷偷888欧美精品久久久 | 日韩精品小视频 | 色com| 久久久久久免费毛片精品 | 欧美伦理电影一区二区 | 欧美精品一区二区三区在线四季 | 久久精品国产99精品国产亚洲性色 | 色吧一区 | 国产精品毛片一区二区 | 欧美亚洲国产一区二区三区 | 色日韩 | 激情五月婷婷综合 | av亚洲在线 | 久久成人免费视频 | 亚洲免费在线视频 | 激情五月激情综合网 | 国产精品影院在线观看 | 国产精品99一区二区三区 | 亚洲精品一区二三区 | 欧美日韩国产一区二区三区 | 蜜桃成人在线观看 | 国产免费激情视频 | 欧美a网站| a免费在线 | 黄视频 | 国产一区二区三区不卡在线观看 | 欧美日韩精品一区二区在线观看 | 91成人小视频 | 精品玖玖玖| 精久久| 人人爽人人爽人人片av | 亚洲一区二区三区蜜桃 | 视频一区在线 | 黄视频在线 | 在线视频国产一区 |