轉載:http://blog.163.com/wb_zhaoyuwei/blog/static/183075439201111524716439/
http://www.open-open.com/lib/view/open1330049653655.html
序言:
在Java、J2EE大型應用中,JVM非標準參數的配置直接關係到整個系統的性能。
JVM非標準參數指的是JVM底層的一些配置參數,這些參數在通常開發中默認便可,不須要任何配置。可是在
生產環境中,爲了提升性能,每每須要調整這些參數,以求系統達到最佳新能。
另外這些參數的配置也是影響系統穩定性的一個重要因素,相信大多數Java開發人員都見過「OutOfMemory
」類型的錯誤。呵呵,這其中極可能就是JVM參數配置不當或者就沒有配置沒意識到配置引發的。
Java 在運行已編譯完成的類時,是經過 java 虛擬機來裝載和執行的,java 虛擬機經過操做
系統命令 JAVA_HOME\bin\java –option 來啓動,-option 爲虛擬機參數,JAVA_HOME 爲JDK
安裝路徑,經過這些參數可對虛擬機的運行狀態進行調整,掌握參數的含義可對虛擬機的運
行模式有更深刻理解。
1、 查看參數列表:
虛擬機參數分爲基本和擴展兩類,在命令行中輸入 JAVA_HOME\bin\java 就可獲得基本參數
列表,
在命令行輸入 JAVA_HOME\bin\java –X 就可獲得擴展參數列表。 html
2、 基本參數說明: java
-----------------------------------------------------------------------
D:\j2sdk15\bin>java
Usage: java [-options] class [args...]
(to execute a class)
or java [-options] -jar jarfile [args...]
(to execute a jar file)
where options include:
-client to select the "client" VM
-server to select the "server" VM
-hotspot is a synonym for the "client" VM [deprecated]
The default VM is client.
-cp <class search path of directories and zip/jar files>
-classpath <class search path of directories and zip/jar files>
A ; separated list of directories, JAR archives,
and ZIP archives to search for class files.
-D<name>=<value>
set a system property
-verbose[:class|gc|jni]
enable verbose output
-version print product version and exit
-version:<value>
require the specified version to run
-showversion print product version and continue
-jre-restrict-search | -jre-no-restrict-search
include/exclude user private JREs in the version search
-? -help print this help message
-X print help on non-standard options
-ea[:<packagename>...|:<classname>]
-enableassertions[:<packagename>...|:<classname>]
enable assertions
-da[:<packagename>...|:<classname>]
-disableassertions[:<packagename>...|:<classname>]
disable assertions
-esa | -enablesystemassertions
enable system assertions
-dsa | -disablesystemassertions
disable system assertions
-agentlib:<libname>[=<options>]
load native agent library <libname>, e.g. -agentlib:hprof
see also, -agentlib:jdwp=help and -agentlib:hprof=help
-agentpath:<pathname>[=<options>]
load native agent library by full pathname
-javaagent:<jarpath>[=<options>]
load Java programming language agent, see java.lang.instrument
-----------------------------------------------------------------------
1. -client,-server
這兩個參數用於設置虛擬機使用何種運行模式,client 模式啓動比較快,但運行時性能和
內存管理效率不如 server 模式,一般用於客戶端應用程序。相反,server 模式啓動比 client
慢,但可得到更高的運行性能。
在 windows上,缺省的虛擬機類型爲 client 模式,若是要使用 server模式,就須要在啓動
虛擬機時加-server 參數,以得到更高性能,對服務器端應用,推薦採用 server 模式,尤
其是多個 CPU 的系統。在 Linux,Solaris 上缺省採用 server模式。
2. -hotspot
含義與 client 相同,jdk1.4 之前使用的參數,jdk1.4 開始再也不使用,代之以 client。
3. -classpath,-cp
虛擬機在運行一個類時,須要將其裝入內存,虛擬機搜索類的方式和順序以下:
Bootstrap classes,Extension classes,User classes。
Bootstrap 中的路徑是虛擬機自帶的 jar 或 zip 文件,虛擬機首先搜索這些包文件,用
System.getProperty("sun.boot.class.path")可獲得虛擬機搜索的包名。
Extension 是位於 jre\lib\ext 目錄下的 jar 文件,虛擬機在搜索完 Bootstrap 後就搜索該
目錄下的 jar 文件。用 System. getProperty("java.ext.dirs」)可獲得虛擬機使用
Extension 搜索路徑。
User classes 搜索順序爲當前目錄、環境變量 CLASSPATH、-classpath。
4. -classpath
告知虛擬機搜索目錄名、jar 文檔名、zip 文檔名,之間用分號;分隔。
例如當你本身開發了公共類幷包裝成一個 common.jar 包,在使用 common.jar 中的類時,就
須要用-classpath common.jar 告訴虛擬機從 common.jar 中查找該類,不然虛擬機就會拋
出 java.lang.NoClassDefFoundError異常,代表未找到類定義。
在運行時可用 System.getProperty(「java.class.path」)獲得虛擬機查找類的路徑。
使用-classpath 後虛擬機將再也不使用 CLASSPATH 中的類搜索路徑,若是-classpath 和
CLASSPATH 都沒有設置,則虛擬機使用當前路徑(.)做爲類搜索路徑。
推薦使用-classpath 來定義虛擬機要搜索的類路徑,而不要使用環境變量 CLASSPATH 的搜
索路徑,以減小多個項目同時使用 CLASSPATH 時存在的潛在衝突。例如應用 1 要使用
a1.0.jar 中的類 G,應用 2 要使用 a2.0.jar 中的類 G,a2.0.jar 是 a1.0.jar 的升級包,當
a1.0.jar,a2.0.jar 都在 CLASSPATH 中,虛擬機搜索到第一個包中的類 G 時就中止搜索,
若是應用1應用2的虛擬機都從CLASSPATH中搜索,就會有一個應用得不到正確版本的類G。
5. -D<propertyName>=value
在虛擬機的系統屬性中設置屬性名/值對,運行在此虛擬機之上的應用程序可用
當虛擬機報告類找不到或類衝突時可用此參數來診斷來查看虛擬機從裝入類的狀況。
7. -verbose:gc
在虛擬機發生內存回收時在輸出設備顯示信息,格式以下:
[Full GC 268K->168K(1984K), 0.0187390 secs]
該參數用來監視虛擬機內存回收的狀況。
8. -verbose:jni
在虛擬機調用 native 方法時輸出設備顯示信息,格式以下:
[Dynamic-linking native method HelloNative.sum ... JNI]
該參數用來監視虛擬機調用本地方法的狀況,在發生 jni錯誤時可爲診斷提供便利。
9. -version
顯示可運行的虛擬機版本信息而後退出。一臺機器上裝有不一樣版本的 JDK 時
10. -showversion
顯示版本信息以及幫助信息。
11. -ea[:<packagename>...|:<classname>]
12. -enableassertions[:<packagename>...|:<classname>]
從 JDK1.4 開始,java 可支持斷言機制,用於診斷運行時問題。一般在測試階段使斷言有效,
在正式運行時不須要運行斷言。斷言後的表達式的值是一個邏輯值,爲 true 時斷言不運行,
爲 false 時斷言運行,拋出 java.lang.AssertionError 錯誤。
上述參數就用來設置虛擬機是否啓動斷言機制,缺省時虛擬機關閉斷言機制,用-ea 可打開
斷言機制,不加<packagename>和 classname 時運行全部包和類中的斷言,若是但願只運行
某些包或類中的斷言,可將包名或類名加到-ea 以後。例如要啓動包 com.foo.util 中的斷
言,可用命令 –ea:com.foo.util 。
13. -da[:<packagename>...|:<classname>]
14. -disableassertions[:<packagename>...|:<classname>]
用來設置虛擬機關閉斷言處理,packagename和classname 的使用方法和-ea 相同。
15. -esa | -enablesystemassertions
設置虛擬機顯示系統類的斷言。
16. -dsa | -disablesystemassertions
設置虛擬機關閉系統類的斷言。
17. -agentlib:<libname>[=<options>]
該參數是 JDK5 新引入的,用於虛擬機裝載本地代理庫。
Libname 爲本地代理庫文件名,虛擬機的搜索路徑爲環境變量 PATH 中的路徑,options 爲傳
給本地庫啓動時的參數,多個參數之間用逗號分隔。在 Windows 平臺上虛擬機搜索本地庫名
爲 libname.dll 的文件,在 Unix 上虛擬機搜索本地庫名爲 libname.so 的文件,搜索路徑環
境變量在不一樣系統上有所不一樣,Linux、SunOS、IRIX上爲LD_LIBRARY_PATH,AIX上爲LIBPATH,
HP-UX 上爲SHLIB_PATH。
例如可以使用-agentlib:hprof 來獲取虛擬機的運行狀況,包括 CPU、內存、線程等的運行數
據,並可輸出到指定文件中,可用-agentlib:hprof=help 來獲得使用幫助列表。在 jre\bin
目錄下可發現 hprof.dll 文件。
18. -agentpath:<pathname>[=<options>]
設置虛擬機按全路徑裝載本地庫,再也不搜索 PATH 中的路徑。其餘功能和 agentlib 相同。
19. -javaagent:<jarpath>[=<options>]
虛擬機啓動時裝入java語言設備代理。Jarpath文件中的mainfest文件必須有Agent-Class
屬性。代理類要實現 public static void premain(String agentArgs, Instrumentation
inst)方法。當虛擬機初始化時,將按代理類的說明順序調用 premain方法。
參見:java.lang.instrument
-----------------------------------------------------------------------
在控制檯輸出信息中,有個-X(注意是大寫)的命令,這個正是查看JVM配置參數的命令。
其次,用java -X 命令查看JVM的配置說明:
運行後以下結果,這些就是配置JVM參數的祕密武器.
-----------------------------------------------------------------------
D:\j2sdk15\bin>java -X
-Xmixed mixed mode execution (default)
-Xint interpreted mode execution only
-Xbootclasspath:<directories and zip/jar files separated by ;>
set search path for bootstrap classes and resources
-Xbootclasspath/a:<directories and zip/jar files separated by ;>
append to end of bootstrap class path
-Xbootclasspath/p:<directories and zip/jar files separated by ;>
prepend in front of bootstrap class path
-Xnoclassgc disable class garbage collection
-Xincgc enable incremental garbage collection
-Xloggc:<file> log GC status to a file with time stamps
-Xbatch disable background compilation
-Xms<size> set initial Java heap size
-Xmx<size> set maximum Java heap size
-Xss<size> set java thread stack size
-Xprof output cpu profiling data
-Xfuture enable strictest checks, anticipating future default
-Xrs reduce use of OS signals by Java/VM (see documentation)
-Xcheck:jni perform additional checks for JNI functions
-Xshare:off do not attempt to use shared class data
-Xshare:auto use shared class data if possible (default)
-Xshare:on require using shared class data, otherwise fail.
The -X options are non-standard and subject to change without notice.
-----------------------------------------------------------------------
JVM配置擴展參數說明:
-----------------------------------------------------------------------
一、-Xmixed mixed mode execution (default)
混合模式執行
設置-client 模式虛擬機對使用頻率高的方式進行 Just-In-Time 編譯和執行,對其餘方法
使用解釋方式執行。該方式是虛擬機缺省模式。
二、-Xint interpreted mode execution only
解釋模式執行
設置-client模式下運行的虛擬機以解釋方式執行類的字節碼,不將字節碼編譯爲本機碼。
三、-Xbootclasspath:<directories and zip/jar files separated by ;>
set search path for bootstrap classes and resources
設置zip/jar資源或者類(.class文件)存放目錄路徑
三、-Xbootclasspath/a:<directories and zip/jar files separated by ;>
append to end of bootstrap class path
追加zip/jar資源或者類(.class文件)存放目錄路徑
四、-Xbootclasspath/p:<directories and zip/jar files separated by ;>
prepend in front of bootstrap class path
預先加載zip/jar資源或者類(.class文件)存放目錄路徑
改變虛擬機裝載缺省系統運行包 rt.jar 而從-Xbootclasspath 中設定的搜索路徑中裝載系
統運行類。除非你本身能寫一個運行時,不然不會用到該參數。
/a:將在缺省搜索路徑後加上 path 中的搜索路徑。
/p:在缺省搜索路徑前先搜索 path 中的搜索路徑。
五、-Xnoclassgc disable class garbage collection
關閉類垃圾回收功能
關閉虛擬機對 class 的垃圾回收功能。
六、-Xincgc enable incremental garbage collection
開啓類的垃圾回收功能
啓動增量垃圾收集器,缺省是關閉的。增量垃圾收集器能減小偶然發生的長時間的垃圾回收
形成的暫停時間。但增量垃圾收集器和應用程序併發執行,所以會佔用部分 CPU 在應用程序
上的功能。
七、-Xloggc:<file> log GC status to a file with time stamps
記錄垃圾回日誌到一個文件。
將虛擬機每次垃圾回收的信息寫到日誌文件中,文件名由 file 指定,文件格式是平文件,
內容和-verbose:gc 輸出內容相同。
八、-Xbatch disable background compilation
關閉後臺編譯
虛擬機的缺省運行方式是在後臺編譯類代碼,而後在前臺執行代碼,使用-Xbatch參數將關
閉虛擬機後臺編譯,在前臺編譯完成後再執行
九、-Xms<size> set initial Java heap size
設置JVM初始化堆內存大小
設置虛擬機可用內存堆的初始大小,缺省單位爲字節,該大小爲 1024 的整數倍而且要大於
1MB,可用 k(K)或m(M)爲單位來設置較大的內存數。初始堆大小爲 2MB。
例如:-Xms6400K,-Xms256M
十、-Xmx<size> set maximum Java heap size
設置JVM最大的堆內存大小
設置虛擬機內存堆的最大可用大小,缺省單位爲字節。該值必須爲 1024 整數倍,而且要大
於 2MB。可用 k(K)或 m(M)爲單位來設置較大的內存數。缺省堆最大值爲 64MB。
例如:-Xmx81920K,-Xmx80M
當應用程序申請了大內存運行時虛擬機拋出 java.lang.OutOfMemoryError: Java heap
space 錯誤,就須要使用-Xmx 設媒洗蟮目捎媚詿娑選?BR>
十一、-Xss<size> set java thread stack size
設置JVM棧內存大小
設置線程棧的大小,缺省單位爲字節。與-Xmx 相似,也可用 K 或 M 來設置較大的值。一般
操做系統分配給線程棧的缺省大小爲 1MB。
另外也可在 java 中建立線程對象時設置棧的大小,構造函數原型爲 Thread(ThreadGroup
group, Runnable target, String name, long stackSize)。
十二、-Xprof output cpu profiling data
輸入CPU概要表數據
輸出 CPU 運行時的診斷信息。
1三、-Xfuture enable strictest checks, anticipating future default
執行嚴格的代碼檢查,預測可能出現的狀況
對類文件進行嚴格格式檢查,以保證類代碼符合類代碼規範。爲保持向後兼容,虛擬機缺省
不進行嚴格的格式檢查。
1四、-Xrs reduce use of OS signals by Java/VM (see documentation)
經過JVM還原操做系統信號
減小虛擬機中操做系統的信號(singals)的使用。該參數一般用在虛擬機之後臺服務方式
運行時使用(如 Servlet)。
1五、-Xcheck:jni perform additional checks for JNI functions
調用 JNI 函數時進行附加的檢查,特別地虛擬機將校驗傳遞給 JNI 函數參數的合法性,在本
地代碼中遇到非法數據時,虛擬機將報一個致命錯誤而終止。使用該參數後將形成性能降低。
1六、-Xshare:off do not attempt to use shared class data
儘量不去使用共享類的數據
1七、-Xshare:auto use shared class data if possible (default)
儘量的使用共享類的數據
1八、-Xshare:on require using shared class data, otherwise fail.
儘量的使用共享類的數據,不然運行失敗
The -X options are non-standard and subject to change without notice.
-----------------------------------------------------------------------
怎麼用這這些參數呢?其實全部的命令行都是這麼一用,下面我就給出一個最簡單的HelloWorl的例子來演
示這個參數的用法,很是的簡單。
HelloWorld.java
-----------------------------------------------
public class HelloWorld
{
public static void main(String[] args)
{
System.out.println("Hello World!");
}
}
編譯並運行:
D:\j2sdk15\bin>javac HelloWorld.java
D:\j2sdk15\bin>java -Xms256M -Xmx512M HelloWorld
Hello World!
呵呵,這下知足了吧!
實踐:在大型系統或者應用中配置JVM參數
好比你配置IDE工具的參數,常見的有IDEA、Eclipse,這個是在一個配置文件中指定便可。
若是你要在J2EE環境中配置這些參數,那麼你須要在J2EE應用服務器或者Servlet容器相關啓動參數設置處
指定,其啓動文件中來配置,Tomcat是在catalina.bat中配置,weblogic和websphere是在其餘地方,具體
我就說了,相信玩過的這些大型服務器的人都知道,沒玩過的看看這篇文章,玩玩就知道了,呵呵。
另外經常有人問到jdk的一些相關命令用法,其實,當你看到這裏的時候,你應該知道如何獲取這些命令的
用法了。若是你還不會,那麼,建議你去學學DOS,我是沒轍了。若是你會這些,仍是沒有看明白,那麼你
趕忙學學英語吧,這樣你就能看懂了。
另外:我在最後給出經常使用的幾個Java命令行說明,以供參考:
(1)、javac
用法:javac <選項> <源文件>
其中,可能的選項包括:
-g 生成全部調試信息
-g:none 不生成任何調試信息
-g:{lines,vars,source} 只生成某些調試信息
-nowarn 不生成任何警告
-verbose 輸出有關編譯器正在執行的操做的消息
-deprecation 輸出使用已過期的 API 的源位置
-classpath <路徑> 指定查找用戶類文件的位置
-cp <路徑> 指定查找用戶類文件的位置
-sourcepath <路徑> 指定查找輸入源文件的位置
-bootclasspath <路徑> 覆蓋引導類文件的位置
-extdirs <目錄> 覆蓋安裝的擴展目錄的位置
-endorseddirs <目錄> 覆蓋簽名的標準路徑的位置
-d <目錄> 指定存放生成的類文件的位置
-encoding <編碼> 指定源文件使用的字符編碼
-source <版本> 提供與指定版本的源兼容性
-target <版本> 生成特定 VM 版本的類文件
-version 版本信息
-help 輸出標準選項的提要
-X 輸出非標準選項的提要
-J<標誌> 直接將 <標誌> 傳遞給運行時系統
(2)、jar
用法:jar {ctxu}[vfm0Mi] [jar-文件] [manifest-文件] [-C 目錄] 文件名 ...
選項:
-c 建立新的存檔
-t 列出存檔內容的列表
-x 展開存檔中的命名的(或全部的〕文件
-u 更新已存在的存檔
-v 生成詳細輸出到標準輸出上
-f 指定存檔文件名
-m 包含來自標明文件的標明信息
-0 只存儲方式;未用ZIP壓縮格式
-M 不產生全部項的清單(manifest〕文件
-i 爲指定的jar文件產生索引信息
-C 改變到指定的目錄,而且包含下列文件:
若是一個文件名是一個目錄,它將被遞歸處理。
清單(manifest〕文件名和存檔文件名都須要被指定,按'm' 和 'f'標誌指定的相同順序。
示例1:將兩個class文件存檔到一個名爲 'classes.jar' 的存檔文件中:
jar cvf classes.jar Foo.class Bar.class
示例2:用一個存在的清單(manifest)文件 'mymanifest' 將 foo/ 目錄下的全部
文件存檔到一個名爲 'classes.jar' 的存檔文件中:
jar cvfm classes.jar mymanifest -C foo/ .
(3)、javadoc
javadoc: 錯誤 - 未指定軟件包或類。
用法:javadoc [選項] [軟件包名稱] [源文件] [
@file]
-overview <文件> 讀取 HTML 文件的概述文檔
-public 僅顯示公共類和成員
-protected 顯示受保護/公共類和成員(默認)
-package 顯示軟件包/受保護/公共類和成員
-private 顯示全部類和成員
-help 顯示命令行選項並退出
-doclet <類> 經過替代 doclet 生成輸出
-docletpath <路徑> 指定查找 doclet 類文件的位置
-sourcepath <路徑列表> 指定查找源文件的位置
-classpath <路徑列表> 指定查找用戶類文件的位置
-exclude <軟件包列表> 指定要排除的軟件包的列表
-subpackages <子軟件包列表> 指定要遞歸裝入的子軟件包
-breakiterator 使用 BreakIterator 計算第 1 句
-bootclasspath <路徑列表> 覆蓋引導類加載器所裝入的
類文件的位置
-source <版本> 提供與指定版本的源兼容性
-extdirs <目錄列表> 覆蓋安裝的擴展目錄的位置
-verbose 輸出有關 Javadoc 正在執行的操做的消息
-locale <名稱> 要使用的語言環境,例如 en_US 或 en_US_WIN
-encoding <名稱> 源文件編碼名稱
-quiet 不顯示狀態消息
-J<標誌> 直接將 <標誌> 傳遞給運行時系統
經過標準 doclet 提供:
-d <目錄> 輸出文件的目標目錄
-use 建立類和軟件包用法頁面
-version 包含
@version 段
-author 包含
@author 段
-docfilessubdirs 遞歸複製文檔文件子目錄
-splitindex 將索引分爲每一個字母對應一個文件
-windowtitle <文本> 文檔的瀏覽器窗口標題
-doctitle <html 代碼> 包含概述頁面的標題
-header <html 代碼> 包含每一個頁面的頁眉文本
-footer <html 代碼> 包含每一個頁面的頁腳文本
-bottom <html 代碼> 包含每一個頁面的底部文本
-link <url> 建立指向位於 <url> 的 javadoc 輸出的連接
-linkoffline <url> <url2> 利用位於 <url2> 的軟件包列表連接至位於 <url>
的文檔
-excludedocfilessubdir <名稱 1>:..排除帶有給定名稱的全部文檔文件子目錄。
-group <名稱> <p1>:<p2>.. 在概述頁面中,將指定的軟件包分組
-nocomment 抑止描述和標記,只生成聲明。
-nodeprecated 不包含
@deprecated 信息
-noqualifier <名稱 1>:<名稱 2>:...從輸出中排除限定符的列表。
-nosince 不包含
@since 信息 -notimestamp 不包含隱藏時間戳 -nodeprecatedlist 不生成已過期的列表 -notree 不生成類分層結構 -noindex 不生成索引 -nohelp 不生成幫助連接 -nonavbar 不生成導航欄 -serialwarn 生成有關 @serial 標記的警告 -tag <名稱>:<位置>:<標題> 指定單個變量自定義標記 -taglet 要註冊的 Taglet 的全限定名稱 -tagletpath Taglet 的路徑 -charset <字符集> 用於跨平臺查看生成的文檔的字符集。 -helpfile <文件> 包含幫助連接所連接到的文件 -linksource 以 HTML 格式生成源 -sourcetab <製表符長度> 指定源中每一個製表符佔據的空格數 -keywords 使軟件包、類和成員信息附帶 HTML 元標記 -stylesheetfile <路徑> 用於更改生成文檔的樣式的文件 -docencoding <名稱> 輸出編碼名稱 (4)、rmid rmid: 非法選項:-? 用法:rmid <option> 其中,<option> 包括: -port <option> 指定供 rmid 使用的端口 -log <directory> 指定 rmid 將日誌寫入的目錄 -stop 中止當前的 rmid 調用(對指定端口) -C<runtime 標記> 向每一個子進程傳遞參數(激活組) -J<runtime 標記> 向 java 解釋程序傳遞參數