一灰殴、 檢查啟JAVA應(yīng)用JVM參數(shù)配置
CPU占用高排查:首先確認(rèn)異常的進(jìn)程:
一般CPU100%瘋狂GC,都是死循環(huán)的鍋掰邢,那怎么排查呢牺陶?
1.先進(jìn)服務(wù)器,用top -c 命令找出當(dāng)前進(jìn)程的運(yùn)行列表
2.按一下 P 可以按照CPU使用率進(jìn)行排序
3.顯示Java進(jìn)程 PID 為 2896 的java進(jìn)程消耗最高
4.然后我們需要根據(jù)PID 查出CPU里面消耗最高的進(jìn)程
5.使用命令 top -Hp PID 找出這個(gè)進(jìn)程下面的線程辣之,繼續(xù)按 P 排序
6.然后看可以看到 TID = 7051 占用CPU消耗最高(注意這個(gè)時(shí)候已經(jīng)是線程ID)
①按進(jìn)程的CPU使用率排序
②運(yùn)行top命令后掰伸,鍵入大寫P
有兩種途徑:
a) 打開(kāi)大寫鍵盤的情況下,直接按P鍵
b) 未打開(kāi)大寫鍵盤的情況下怀估,Shift+P鍵
話外音:內(nèi)存占用高狮鸭,如何查看 ?
①按進(jìn)程的內(nèi)存使用率排序
②運(yùn)行top命令后多搀,鍵入大寫M
有兩種途徑:
a) 打開(kāi)大寫鍵盤的情況下歧蕉,直接按M鍵
b) 未打開(kāi)大寫鍵盤的情況下,Shift+M鍵
按Enter鍵可以查看康铭,及時(shí)的情況
TOP交互命令如下
c: 顯示完整的命令
d: 更改刷新頻率
f: 增加或減少要顯示的列(選中的會(huì)變成大寫并加*號(hào))
F: 選擇排序的列
h: 顯示幫助畫面
H: 顯示線程
i: 忽略閑置和僵死進(jìn)程
k: 通過(guò)給予一個(gè)PID和一個(gè)signal來(lái)終止一個(gè)進(jìn)程惯退。(默認(rèn)signal為15。在安全模式中此命令被屏蔽)
l: 顯示平均負(fù)載以及啟動(dòng)時(shí)間(即顯示影藏第一行)
m: 顯示內(nèi)存信息
M: 根據(jù)內(nèi)存資源使用大小進(jìn)行排序
N: 按PID由高到低排列
o: 改變列顯示的順序
O: 選擇排序的列从藤,與F完全相同
P: 根據(jù)CPU資源使用大小進(jìn)行排序
q: 退出top命令
r: 修改進(jìn)程的nice值(優(yōu)先級(jí))催跪。優(yōu)先級(jí)默認(rèn)為10,正值使優(yōu)先級(jí)降低夷野,反之則提高的優(yōu)先級(jí)
s: 設(shè)置刷新頻率(默認(rèn)單位為秒懊蒸,如有小數(shù)則換算成ms)。默認(rèn)值是5s悯搔,輸入0值則系統(tǒng)將不斷刷新
S: 累計(jì)模式(把已完成或退出的子進(jìn)程占用的CPU時(shí)間累計(jì)到父進(jìn)程的MITE+ )
T: 根據(jù)進(jìn)程使用CPU的累積時(shí)間排序
t: 顯示進(jìn)程和CPU狀態(tài)信息(即顯示影藏CPU行)
u: 指定用戶進(jìn)程
W: 將當(dāng)前設(shè)置寫入~/.toprc文件骑丸,下次啟動(dòng)自動(dòng)調(diào)用toprc文件的設(shè)置
<: 向前翻頁(yè)
>: 向后翻頁(yè)
?: 顯示幫助畫面
1(數(shù)字1): 顯示每個(gè)CPU的詳細(xì)情況
將JAVA線程運(yùn)行情況dump到指定路徑,通過(guò)命令行或者M(jìn)AT輔助分析如下:
①使用 pringf "%x\n" 2854(注意: 2854為占用高的線程ID)
轉(zhuǎn)成十六進(jìn)制妒貌,轉(zhuǎn)換結(jié)果:b26
②接下來(lái)就需要導(dǎo)出我們的進(jìn)程快照了通危,看看這個(gè)線程做了啥
③ jstack -l 2609 > ./err.log
再用grep查看一下線程在文件里做了啥/或者使用MAT分析dump文件(更加方便)
④cat err.log| grep 'b26' -C 10
注意:提前獲取Application應(yīng)用的啟動(dòng)參數(shù),方便定位和排查問(wèn)題
ps aux | grep app.jar 輸出JVM的相關(guān)參數(shù)(經(jīng)常使用)
##通過(guò)以下命令查看JVM的啟動(dòng)參數(shù):
ps aux | grep app.jar 輸出JVM的相關(guān)參數(shù)
jps -lv 輸出啟動(dòng)類名與啟動(dòng)時(shí) jvm 參數(shù)苏揣,可以方便的看到各個(gè) tomcat 的自定義參數(shù)配置
jps -lv | grep app.jar 在上述基礎(chǔ)上過(guò)濾出自己想要查看的項(xiàng)目的信息
jinfo pid 顯示 jvm 系統(tǒng)屬性與 vm 參數(shù)信息
jinfo -flags pid 顯示 jvm vm 參數(shù)信息,如最大最小堆推姻,默認(rèn)堆平匈,垃圾收集器參數(shù)等
jinfo -sysprops pid 顯示 jvm 系統(tǒng)屬性
jinfo -flag 顯示特定 vm 參數(shù)值,例如 jinfo -flag MaxHeapSize pid 輸出 pid 的最大堆內(nèi)存
二、jstat (jvm statistics monitoring tool) 收集運(yùn)行數(shù)據(jù)(堆棧排查相關(guān))
1增炭、語(yǔ)法格式
jstat -gc pid 1s 20 (經(jīng)常使用)
jstat [option pid [interval[s|ms] [count]]]
說(shuō)明: interval 表示循環(huán)時(shí)間間隔忍燥,默認(rèn)單位為 ms,可以在直接使用 s/ms 指定單位
如 60ms/1s隙姿, count 表示輸出幾次 例如下:
jstat -gc pid 1s 20 : 每 1s 查詢一次 gc 情況梅垄,查詢 20 次
2、option 詳解(主要分三類:類裝載输玷、垃圾收集队丝、運(yùn)行期編譯狀況)
3.查看 GC 情況
jstat -gc pid (經(jīng)常使用)
4、查看 GC 情況欲鹏,以百分比顯示
jstat -gcutil pid (經(jīng)常使用)
5机久、查看新生代 GC 情況
jstat -gcnew pid
6、查看老年代 GC 情況
jstat -gcold pid
7浦楣、查看各空間容量
jstat -gccapacity pid
8瘩将、查看編譯情況
jstat -compiler pid
三衩椒、jmap (memory map for java) 虛擬機(jī)堆快照工具
1、常用用法
jmap -heap pid (經(jīng)常使用)
使用實(shí)例 jmap -heap 28076| head -n60
jmap -dump:format=b,file=/temp/filename.hprof pid (經(jīng)常使用)
轉(zhuǎn)儲(chǔ)堆快照侠畔,生成 hprof 文件到指定路徑**
jmap -histo pid | more (經(jīng)常使用)
列出當(dāng)前 heap 中對(duì)象狀況,附字節(jié)碼與 java 對(duì)象映射表
(1)jmap -heap pid 查看JVM空間總體使用情況
(2)jmap -histo pid |more 查看類的實(shí)例數(shù)和內(nèi)存量
(3)jmap -histo:live pid |more 查看所有活著的實(shí)例數(shù)量损晤。
(4)jmap -dump:format=b,file=dump_tomcat.dat pid 將內(nèi)存使用情況dump到文件中
四软棺、jstack (stack trace for java) 虛擬機(jī)線程快照工具(主要獲取運(yùn)行線程相關(guān))
jstack -h查看stack的命令提示
jstack [-l] <pid>
(to connect to running process)
jstack -F [-m] [-l] <pid>
(to connect to a hung process)
jstack [-m] [-l] <executable> <core>
(to connect to a core file)
jstack [-m] [-l] [server_id@]<remote server IP or hostname>
(to connect to a remote debug server)
jstack pid > ./a.log (經(jīng)常使用)
將生成的運(yùn)行線程的相關(guān)信息輸出到a.log日志中,下載查看
查看線程棧執(zhí)行情況/會(huì)顯示所有線程的各種信息沉馆,可以用來(lái)排查死鎖码党,或線程長(zhǎng)時(shí)間停滯的問(wèn)題
①可以通過(guò)MAT工具進(jìn)行分析
5、Tomcat內(nèi)存設(shè)置
windows下在catalina.bat的第一行增加:
Java代碼 :set JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=256m
Linux下在catalina.sh的第一行增加:
Java代碼 :JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=256m
實(shí)例+詳解
設(shè)置Tomcat啟動(dòng)的初始內(nèi)存其初始空間(即-Xms)是物理內(nèi)存的1/64斥黑,最大空間(-Xmx)是物理內(nèi)存的1/4揖盘。
可以利用JVM提供的-Xmn -Xms -Xmx等選項(xiàng)可進(jìn)行設(shè)置
實(shí)例,以下給出1G內(nèi)存環(huán)境下Java jvm
的參數(shù)設(shè)置參考:
JAVA_OPTS=”-server -Xms800m -Xmx800m -XX:PermSize=64M -XX:MaxNewSize=256m -XX:MaxPermSize=128m -Djava.awt.headless=true “
JAVA_OPTS=”-server -Xms768m -Xmx768m -XX:PermSize=128m -XX:MaxPermSize=256m -XX: NewSize=192m -XX:MaxNewSize=384m”
CATALINA_OPTS=”-server -Xms768m -Xmx768m -XX:PermSize=128m -XX:MaxPermSize=256m -XX:NewSize=192m -XX:MaxNewSize=384m”
在/usr/local/apache-tomcat-5.5.23/bin 目錄下的catalina.sh添加:
JAVA_OPTS=’-Xms512m -Xmx1024m’要加“m”說(shuō)明是MB锌奴,否則就是KB了兽狭,在啟動(dòng)tomcat時(shí)會(huì) 報(bào)內(nèi)存不足。
-Xms:初始值-Xmx:最大值-Xmn:最小值
Windows:
在catalina.bat最前面加入set JAVA_OPTS=-Xms128m -Xmx350m
如果用startup.bat啟動(dòng)tomcat,OK設(shè)置生效.夠成功的分配200M內(nèi)存.
但是如果不是執(zhí)行startup.bat啟動(dòng)tomcat而是利用windows的系統(tǒng)服務(wù)啟動(dòng)tomcat服務(wù),上面的設(shè)置就不生效了,就是說(shuō)set JAVA_OPTS=-Xms128m -Xmx350m 沒(méi)起作用.上面分配200M內(nèi)存就OOM了..
windows服務(wù)執(zhí)行的是bin\tomcat.exe.他讀取注冊(cè)表中的值,而不是catalina.bat的設(shè)置.
解決辦法:
修改注冊(cè)表HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Tomcat Service Manager\Tomcat5\Parameters\JavaOptions
原值為-Dcatalina.home=”C:\ApacheGroup\Tomcat 5.0″-Djava.endorsed.dirs=”C:\ApacheGroup\Tomcat 5.0\common\endorsed”-Xrs加入 -Xms300m -Xmx350m
重起tomcat服務(wù),設(shè)置生效
**Tomcat 的JVM 內(nèi)存溢出問(wèn)題的解決關(guān)鍵字: tomcat 的jvm 內(nèi)存溢出問(wèn)題的解決 **
最近在熟悉一個(gè)開(kāi)發(fā)了有幾年的項(xiàng)目鹿蜀,需要把數(shù)據(jù)庫(kù)從MySQL移植到Oracle箕慧,首先把jdbc的連接指向mysql,打包放到tomcat里面茴恰,可以跑起來(lái)颠焦,沒(méi)有問(wèn)題,可是當(dāng)把jdbc連接指向oracle的時(shí)候往枣,tomcat就連續(xù)拋java.lang.OutOfMemoryError的錯(cuò)誤伐庭,上網(wǎng)google了一下粉渠,了解了一下tomcat的運(yùn)行機(jī)制,也解決了問(wèn)題圾另,share出來(lái)霸株,以備查。
1集乔、首先是:java.lang.OutOfMemoryError: java heap
space 解釋:
Heap size 設(shè)置 JVM堆的設(shè)置是指java程序運(yùn)行過(guò)程中JVM可以調(diào)配使用的內(nèi)存空間的設(shè)置.JVM在啟動(dòng)的時(shí)候會(huì)自動(dòng)設(shè)置Heap size的值去件,其初始空間(即-Xms)是物理內(nèi)存的1/64,最大空間(-Xmx)是物理內(nèi)存的1/4扰路∮攘铮可以利用JVM提供的-Xmn -Xms -Xmx等選項(xiàng)可進(jìn)行設(shè)置。Heap size 的大小是Young Generation 和Tenured Generaion
之和幼衰。
提示:在JVM中如果98%的時(shí)間是用于GC且可用的Heap size 不足2%的時(shí)候?qū)伋龃水惓P畔ⅰ?/p>
提示:Heap Size 最大不要超過(guò)可用物理內(nèi)存的80%靴跛,一般的要將-Xms和-Xmx選項(xiàng)設(shè)置為相同,而-Xmn為1/4的-Xmx值渡嚣。
解決方法:
手動(dòng)設(shè)置Heap size 修改TOMCAT_HOME/bin/catalina.bat梢睛,在“echo “Using CATALINA_BASE: $CATALINA_BASE””上面加入以下行:
Java代碼 set JAVA_OPTS=%JAVA_OPTS% -server -Xms800m -Xmx800m -XX:MaxNewSize=256m
或修改catalina.sh 在“echo “Using CATALINA_BASE: JAVA_OPTS -server -Xms800m -Xmx800m -XX:MaxNewSize=256m”
2、其次是:java.lang.OutOfMemoryError: PermGen space 原因:
PermGen space的全稱是Permanent Generation space,是指內(nèi)存的永久保存區(qū)域识椰,這塊內(nèi)存主要是被JVM存放Class和Meta信息的,Class在被Loader時(shí)就會(huì)被放到PermGen space中绝葡,它和存放類實(shí)例(Instance)的Heap區(qū)域不同,GC(Garbage Collection)不會(huì)在主程序運(yùn)行期對(duì)PermGen space進(jìn)行清理,所以如果你的應(yīng)用中有很CLASS的話,就很可能出現(xiàn)PermGen
space錯(cuò)誤腹鹉,這種錯(cuò)誤常見(jiàn)在web服務(wù)器對(duì)JSP進(jìn)行pre compile的時(shí)候藏畅。如果你的WEB APP下都用了大量的第三方j(luò)ar, 其大小超過(guò)了jvm默認(rèn)的大小(4M)那么就會(huì)產(chǎn)生此錯(cuò)誤信息了。
解決方法:
1. 手動(dòng)設(shè)置MaxPermSize大小 修改TOMCAT_HOME/bin/catalina.bat(Linux下為catalina.sh)功咒,在Java代碼 “echo “Using CATALINA_BASE: $CATALINA_BASE””上面加入以下行: set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128M -XX:MaxPermSize=512m
catalina.sh下為: Java代碼 JAVA_OPTS=”$JAVA_OPTS -server -XX:PermSize=128M -XX:MaxPermSize=512m”
下面給出各種可以用戶設(shè)置堆大小的命令行參數(shù)愉阎。注釋列提供了一些設(shè)置參數(shù)的初級(jí)或高級(jí)建議。此外力奋,后面還會(huì)給出更多的詳細(xì)建議榜旦。
| 參數(shù) | 描述 | 注釋 |
| -Xms<size> | 設(shè)置堆的最小值 | 在生產(chǎn)階段,最小和最大堆值設(shè)置為相同的值 |
| -Xmx<size> | 設(shè)置堆的最大值 | |
| -XX:NewSize=<size> | 設(shè)置年輕代的最小值 | 在生產(chǎn)階段景殷,最小和最大年輕代的值設(shè)為相同的值 |
| -XX:MaxNewSize=<size> | 設(shè)置年輕代的最大值 | |
| -XX:NewRatio=<number> | 設(shè)置年輕代和年老代的大小比例溅呢。例如,數(shù)值為2時(shí)
年老代將會(huì)是年輕代大小的2倍猿挚。 | 使用NewSize/MaxNewSize參數(shù)或NewRatio參數(shù)咐旧,但不要兩個(gè)參數(shù)都使用 |
| -XX:SurvivorRatio=<number> | 設(shè)置eden space和剩余空間的大小比例。例如绩蜻,剩余空間比例為8時(shí)铣墨,eden space是任一剩余空間大小的8倍。 | 基于年輕代大小改變比例办绝。比例值為8適用于
小的年輕代(如10M)伊约,32適用于比較大的年輕代(如100M)词顾。 |
| -XX:MaxTenuringThreshold=<number> | 表示一個(gè)對(duì)象在被自動(dòng)放置于年老代之前必須存活的次要回收的次數(shù) | 一般應(yīng)該使用的值為32 |
| -XX:MaxPermSizse=<size> | 設(shè)置永久代的大小 | 在用完空間后在設(shè)置永久代 |
| -XX:+UserTLAB | 在eden space里給應(yīng)用程序的每一個(gè)線程提供它自己的分配區(qū)域(線程本地分配塊TLAB)。注意它是一個(gè)布爾型選項(xiàng)碱妆,
用plus(+)可以啟動(dòng)它,用minus(-)(-XX:-UseTLAB)可以禁用它 | 主要對(duì)多處理器系統(tǒng)有利 |
| -XX:TLABSize=<size> | 每一個(gè)TLAB的大小 | 確保年輕代空間足夠?yàn)閼?yīng)用程序里的每一個(gè)線程保存所有的TLAB昔驱。應(yīng)該分別使用64KB疹尾、128KB和256KB進(jìn)行嘗試 |
注意:1.<size>是一個(gè)表示字節(jié)數(shù)量的浮點(diǎn)數(shù),在其后面加上K骤肛、M纳本、G后綴分別代表KB、MB腋颠、GB繁成。
2.<number>是一個(gè)浮點(diǎn)數(shù)。
-
堆大小設(shè)置 JVM 中最大堆大小有三方面限制:相關(guān)操作系統(tǒng)的數(shù)據(jù)模型(32-bt還是64-bit)限制淑玫;系統(tǒng)的可用虛擬內(nèi)存限制巾腕;系統(tǒng)的可用物理內(nèi)存限制。32位系統(tǒng)下絮蒿,一般限制在1.5G~2G尊搬;64為操作系統(tǒng)對(duì)內(nèi)存無(wú)限制。我在Windows Server 2003 系統(tǒng)土涝,3.5G物理內(nèi)存佛寿,JDK5.0下測(cè)試,最大可設(shè)置為1478m但壮。
典型設(shè)置:- java -Xmx3550m -Xms3550m -Xmn2g -Xss128k
–****Xmx3550m:設(shè)置JVM最大可用內(nèi)存為3550M冀泻。
-Xms3550m:設(shè)置JVM促使內(nèi)存為3550m。此值可以設(shè)置與-Xmx相同蜡饵,以避免每次垃圾回收完成后JVM重新分配內(nèi)存弹渔。
-Xmn2g:設(shè)置年輕代大小為2G。整個(gè)JVM內(nèi)存大小=年輕代大小 + 年老代大小 + 持久代大小验残。持久代一般固定大小為64m捞附,所以增大年輕代后,將會(huì)減小年老代大小您没。此值對(duì)系統(tǒng)性能影響較大鸟召,Sun官方推薦配置為整個(gè)堆的3/8。
-Xss128k:設(shè)置每個(gè)線程的堆棧大小氨鹏。JDK5.0以后每個(gè)線程堆棧大小為1M欧募,以前每個(gè)線程堆棧大小為256K。更具應(yīng)用的線程所需內(nèi)存大小進(jìn)行調(diào)整仆抵。在相同物理內(nèi)存下跟继,減小這個(gè)值能生成更多的線程种冬。但是操作系統(tǒng)對(duì)一個(gè)進(jìn)程內(nèi)的線程數(shù)還是有限制的,不能無(wú)限生成舔糖,經(jīng)驗(yàn)值在3000~5000左右娱两。 - java -Xmx3550m -Xms3550m -Xss128k -XX:NewRatio=4 -XX:SurvivorRatio=4 -XX:MaxPermSize=16m -XX:MaxTenuringThreshold=0
-XX:NewRatio=4:設(shè)置年輕代(包括Eden和兩個(gè)Survivor區(qū))與年老代的比值(除去持久代)。設(shè)置為4金吗,則年輕代與年老代所占比值為1:4十兢,年輕代占整個(gè)堆棧的1/5
-XX:SurvivorRatio=4:設(shè)置年輕代中Eden區(qū)與Survivor區(qū)的大小比值。設(shè)置為4摇庙,則兩個(gè)Survivor區(qū)與一個(gè)Eden區(qū)的比值為2:4,一個(gè)Survivor區(qū)占整個(gè)年輕代的1/6
-XX:MaxPermSize=16m:設(shè)置持久代大小為16m卫袒。
-XX:MaxTenuringThreshold=0:設(shè)置垃圾最大年齡宵呛。如果設(shè)置為0的話,則年輕代對(duì)象不經(jīng)過(guò)Survivor區(qū)夕凝,直接進(jìn)入年老代宝穗。對(duì)于年老代比較多的應(yīng)用,可以提高效率码秉。如果將此值設(shè)置為一個(gè)較大值讽营,則年輕代對(duì)象會(huì)在Survivor區(qū)進(jìn)行多次復(fù)制,這樣可以增加對(duì)象再年輕代的存活時(shí)間泡徙,增加在年輕代即被回收的概論橱鹏。
- java -Xmx3550m -Xms3550m -Xmn2g -Xss128k
-
回收器選擇 JVM給了三種選擇:串行收集器、并行收集器堪藐、并發(fā)收集器莉兰,但是串行收集器只適用于小數(shù)據(jù)量的情況,所以這里的選擇主要針對(duì)并行收集器和并發(fā)收集器礁竞。默認(rèn)情況下糖荒,JDK5.0以前都是使用串行收集器,如果想使用其他收集器需要在啟動(dòng)時(shí)加入相應(yīng)參數(shù)模捂。JDK5.0以后捶朵,JVM會(huì)根據(jù)當(dāng)前系統(tǒng)配置進(jìn)行判斷。
-
吞吐量?jī)?yōu)先的并行收集器
如上文所述狂男,并行收集器主要以到達(dá)一定的吞吐量為目標(biāo)综看,適用于科學(xué)技術(shù)和后臺(tái)處理等。
典型配置:- java -Xmx3800m -Xms3800m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20
-XX:+UseParallelGC:選擇垃圾收集器為并行收集器岖食。此配置僅對(duì)年輕代有效红碑。即上述配置下,年輕代使用并發(fā)收集,而年老代仍舊使用串行收集析珊。 -XX:ParallelGCThreads=20:配置并行收集器的線程數(shù)羡鸥,即:同時(shí)多少個(gè)線程一起進(jìn)行垃圾回收。此值最好配置與處理器數(shù)目相等忠寻。 - java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20 -XX:+UseParallelOldGC -XX:+UseParallelOldGC:配置年老代垃圾收集方式為并行收集惧浴。JDK6.0支持對(duì)年老代并行收集。
- java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:MaxGCPauseMillis=100 -XX:MaxGCPauseMillis=100****:設(shè)置每次年輕代垃圾回收的最長(zhǎng)時(shí)間奕剃,如果無(wú)法滿足此時(shí)間赶舆,JVM會(huì)自動(dòng)調(diào)整年輕代大小,以滿足此值祭饭。
- java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:MaxGCPauseMillis=100 -XX:+UseAdaptiveSizePolicy
-XX:+UseAdaptiveSizePolicy:設(shè)置此選項(xiàng)后,并行收集器會(huì)自動(dòng)選擇年輕代區(qū)大小和相應(yīng)的Survivor區(qū)比例叙量,以達(dá)到目標(biāo)系統(tǒng)規(guī)定的最低相應(yīng)時(shí)間或者收集頻率等倡蝙,此值建議使用并行收集器時(shí),一直打開(kāi)绞佩。
- java -Xmx3800m -Xms3800m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20
-
響應(yīng)時(shí)間優(yōu)先的并發(fā)收集器
如上文所述寺鸥,并發(fā)收集器主要是保證系統(tǒng)的響應(yīng)時(shí)間,減少垃圾收集時(shí)的停頓時(shí)間品山。適用于應(yīng)用服務(wù)器胆建、電信領(lǐng)域等。
典型配置:- java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:ParallelGCThreads=20 -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:+UseConcMarkSweepGC:設(shè)置年老代為并發(fā)收集肘交。測(cè)試中配置這個(gè)以后笆载,-XX:NewRatio=4的配置失效了,原因不明涯呻。所以凉驻,此時(shí)年輕代大小最好用-Xmn設(shè)置。
-XX:+UseParNewGC:設(shè)置年輕代為并行收集复罐±缘牵可與CMS收集同時(shí)使用。JDK5.0以上效诅,JVM會(huì)根據(jù)系統(tǒng)配置自行設(shè)置胀滚,所以無(wú)需再設(shè)置此值。 - java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseConcMarkSweepGC -XX:CMSFullGCsBeforeCompaction=5 -XX:+UseCMSCompactAtFullCollection
-XX:CMSFullGCsBeforeCompaction:由于并發(fā)收集器不對(duì)內(nèi)存空間進(jìn)行壓縮乱投、整理咽笼,所以運(yùn)行一段時(shí)間以后會(huì)產(chǎn)生“碎片”,使得運(yùn)行效率降低戚炫。此值設(shè)置運(yùn)行多少次GC以后對(duì)內(nèi)存空間進(jìn)行壓縮褐荷、整理。 -XX:+UseCMSCompactAtFullCollection:打開(kāi)對(duì)年老代的壓縮嘹悼∨迅Γ可能會(huì)影響性能层宫,但是可以消除碎片
- java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:ParallelGCThreads=20 -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:+UseConcMarkSweepGC:設(shè)置年老代為并發(fā)收集肘交。測(cè)試中配置這個(gè)以后笆载,-XX:NewRatio=4的配置失效了,原因不明涯呻。所以凉驻,此時(shí)年輕代大小最好用-Xmn設(shè)置。
-
吞吐量?jī)?yōu)先的并行收集器
-
輔助信息 JVM提供了大量命令行參數(shù),打印信息其监,供調(diào)試使用萌腿。主要有以下一些:
-
-XX:+PrintGC 輸出形式:[GC 118250K->113543K(130112K), 0.0094143 secs]
** [Full GC 121376K->10414K(130112K), 0.0650971 secs]**
-
-XX:+PrintGCDetails 輸出形式:[GC [DefNew: 8614K->781K(9088K), 0.0123035 secs] 118250K->113543K(130112K), 0.0124633 secs]
** [GC [DefNew: 8614K->8614K(9088K), 0.0000665 secs][Tenured: 112761K->10414K(121024K), 0.0433488 secs] 121376K->10414K(130112K), 0.0436268 secs]**
-XX:+PrintGCTimeStamps -XX:+PrintGC:PrintGCTimeStamps可與上面兩個(gè)混合使用
輸出形式:11.851: [GC 98328K->93620K(130112K), 0.0082960 secs]-XX:+PrintGCApplicationConcurrentTime:打印每次垃圾回收前,程序未中斷的執(zhí)行時(shí)間抖苦』倭猓可與上面混合使用
輸出形式:Application time: 0.5291524 seconds-XX:+PrintGCApplicationStoppedTime:打印垃圾回收期間程序暫停的時(shí)間⌒坷可與上面混合使用
輸出形式:Total time for which application threads were stopped: 0.0468229 seconds-XX:PrintHeapAtGC:打印GC前后的詳細(xì)堆棧信息
輸出形式:
34.702: [GC {Heap before gc invocations=7:
def new generation total 55296K, used 52568K [0x1ebd0000, 0x227d0000, 0x227d0000)
eden space 49152K, 99% used [0x1ebd0000, 0x21bce430, 0x21bd0000)
from space 6144K, 55% used [0x221d0000, 0x22527e10, 0x227d0000)
to space 6144K, 0% used [0x21bd0000, 0x21bd0000, 0x221d0000)
tenured generation total 69632K, used 2696K [0x227d0000, 0x26bd0000, 0x26bd0000)
the space 69632K, 3% used [0x227d0000, 0x22a720f8, 0x22a72200, 0x26bd0000)
compacting perm gen total 8192K, used 2898K [0x26bd0000, 0x273d0000, 0x2abd0000)
the space 8192K, 35% used [0x26bd0000, 0x26ea4ba8, 0x26ea4c00, 0x273d0000)
ro space 8192K, 66% used [0x2abd0000, 0x2b12bcc0, 0x2b12be00, 0x2b3d0000)
rw space 12288K, 46% used [0x2b3d0000, 0x2b972060, 0x2b972200, 0x2bfd0000)
34.735: [DefNew: 52568K->3433K(55296K), 0.0072126 secs] 55264K->6615K(124928K)Heap after gc invocations=8: def new generation total 55296K, used 3433K [0x1ebd0000, 0x227d0000, 0x227d0000)
eden space 49152K, 0% used [0x1ebd0000, 0x1ebd0000, 0x21bd0000)
from space 6144K, 55% used [0x21bd0000, 0x21f2a5e8, 0x221d0000)
to space 6144K, 0% used [0x221d0000, 0x221d0000, 0x227d0000)
tenured generation total 69632K, used 3182K [0x227d0000, 0x26bd0000, 0x26bd0000)
**the space 69632K, 4% used **[0x227d0000, 0x22aeb958, 0x22aeba00, 0x26bd0000)
compacting perm gen total 8192K, used 2898K [0x26bd0000, 0x273d0000, 0x2abd0000)
the space 8192K, 35% used [0x26bd0000, 0x26ea4ba8, 0x26ea4c00, 0x273d0000)
ro space 8192K, 66% used [0x2abd0000, 0x2b12bcc0, 0x2b12be00, 0x2b3d0000)
rw space 12288K, 46% used [0x2b3d0000, 0x2b972060, 0x2b972200, 0x2bfd0000)
}
, 0.0757599 secs]-Xloggc:filename:與上面幾個(gè)配合使用贮庞,把相關(guān)日志信息記錄到文件以便分析。
-
-
常見(jiàn)配置匯總
- 堆設(shè)置
- -Xms:初始堆大小
- -Xmx:最大堆大小
- -XX:NewSize=n:設(shè)置年輕代大小
- -XX:NewRatio=n:設(shè)置年輕代和年老代的比值究西。如:為3窗慎,表示年輕代與年老代比值為1:3,年輕代占整個(gè)年輕代年老代和的1/4
- -XX:SurvivorRatio=n:年輕代中Eden區(qū)與兩個(gè)Survivor區(qū)的比值卤材。注意Survivor區(qū)有兩個(gè)遮斥。如:3,表示Eden:Survivor=3:2扇丛,一個(gè)Survivor區(qū)占整個(gè)年輕代的1/5
- -XX:MaxPermSize=n:設(shè)置持久代大小
- 收集器設(shè)置
- -XX:+UseSerialGC:設(shè)置串行收集器
- -XX:+UseParallelGC:設(shè)置并行收集器
- -XX:+UseParalledlOldGC:設(shè)置并行年老代收集器
- -XX:+UseConcMarkSweepGC:設(shè)置并發(fā)收集器
- 垃圾回收統(tǒng)計(jì)信息
- -XX:+PrintGC
- -XX:+PrintGCDetails
- -XX:+PrintGCTimeStamps
- -Xloggc:filename
- 并行收集器設(shè)置
- -XX:ParallelGCThreads=n:設(shè)置并行收集器收集時(shí)使用的CPU數(shù)术吗。并行收集線程數(shù)。
- -XX:MaxGCPauseMillis=n:設(shè)置并行收集最大暫停時(shí)間
- -XX:GCTimeRatio=n:設(shè)置垃圾回收時(shí)間占程序運(yùn)行時(shí)間的百分比帆精。公式為1/(1+n)
- 并發(fā)收集器設(shè)置
- -XX:+CMSIncrementalMode:設(shè)置為增量模式较屿。適用于單CPU情況。
- -XX:ParallelGCThreads=n:設(shè)置并發(fā)收集器年輕代收集方式為并行收集時(shí)卓练,使用的CPU數(shù)吝镣。并行收集線程數(shù)。
- 堆設(shè)置
四昆庇、調(diào)優(yōu)總結(jié)
-
年輕代大小選擇
- 響應(yīng)時(shí)間優(yōu)先的應(yīng)用:盡可能設(shè)大末贾,直到接近系統(tǒng)的最低響應(yīng)時(shí)間限制(根據(jù)實(shí)際情況選擇)。在此種情況下整吆,年輕代收集發(fā)生的頻率也是最小的拱撵。同時(shí),減少到達(dá)年老代的對(duì)象表蝙。
- 吞吐量?jī)?yōu)先的應(yīng)用:盡可能的設(shè)置大拴测,可能到達(dá)Gbit的程度。因?yàn)閷?duì)響應(yīng)時(shí)間沒(méi)有要求府蛇,垃圾收集可以并行進(jìn)行集索,一般適合8CPU以上的應(yīng)用。
-
年老代大小選擇
-
響應(yīng)時(shí)間優(yōu)先的應(yīng)用:年老代使用并發(fā)收集器,所以其大小需要小心設(shè)置务荆,一般要考慮并發(fā)會(huì)話率和會(huì)話持續(xù)時(shí)間等一些參數(shù)妆距。如果堆設(shè)置小了,可以會(huì)造成內(nèi)存碎片函匕、高回收頻率以及應(yīng)用暫停而使用傳統(tǒng)的標(biāo)記清除方式娱据;如果堆大了,則需要較長(zhǎng)的收集時(shí)間盅惜。最優(yōu)化的方案中剩,一般需要參考以下數(shù)據(jù)獲得:
- 并發(fā)垃圾收集信息
- 持久代并發(fā)收集次數(shù)
- 傳統(tǒng)GC信息
- 花在年輕代和年老代回收上的時(shí)間比例
減少年輕代和年老代花費(fèi)的時(shí)間,一般會(huì)提高應(yīng)用的效率
吞吐量?jī)?yōu)先的應(yīng)用:一般吞吐量?jī)?yōu)先的應(yīng)用都有一個(gè)很大的年輕代和一個(gè)較小的年老代抒寂。原因是结啼,這樣可以盡可能回收掉大部分短期對(duì)象,減少中期的對(duì)象屈芜,而年老代盡存放長(zhǎng)期存活對(duì)象郊愧。
-
-
較小堆引起的碎片問(wèn)題 因?yàn)槟昀洗牟l(fā)收集器使用標(biāo)記、清除算法沸伏,所以不會(huì)對(duì)堆進(jìn)行壓縮。當(dāng)收集器回收時(shí)动分,他會(huì)把相鄰的空間進(jìn)行合并毅糟,這樣可以分配給較大的對(duì)象。但是澜公,當(dāng)堆空間較小時(shí)姆另,運(yùn)行一段時(shí)間以后,就會(huì)出現(xiàn)“碎片”坟乾,如果并發(fā)收集器找不到足夠的空間迹辐,那么并發(fā)收集器將會(huì)停止,然后使用傳統(tǒng)的標(biāo)記甚侣、清除方式進(jìn)行回收明吩。如果出現(xiàn)“碎片”,可能需要進(jìn)行如下配置:
- -XX:+UseCMSCompactAtFullCollection:使用并發(fā)收集器時(shí)殷费,開(kāi)啟對(duì)年老代的壓縮印荔。
- -XX:CMSFullGCsBeforeCompaction=0:上面配置開(kāi)啟的情況下,這里設(shè)置多少次Full GC后详羡,對(duì)年老代進(jìn)行壓縮
1.在eclipse設(shè)置JVM參數(shù)
打開(kāi)eclipse-窗口-首選項(xiàng)-Java-已安裝的JRE(對(duì)在當(dāng)前開(kāi)發(fā)環(huán)境中運(yùn)行的java程序皆生效仍律,也就是在eclipse中運(yùn)行的java程序)編輯當(dāng)前使用的JRE,在缺省VM參數(shù)中輸入:
-Xmx1024m -Xms1024m -Xmn256m -Xss16m
或者在運(yùn)行一個(gè)java程序的時(shí)候執(zhí)行:
java -Xmx1024m
-Xms1024m -Xmn256m -Xss16m Test
Test是一個(gè)class文件实柠。
2. 在Tomcat服務(wù)器上設(shè)置JVM參數(shù)
set CATALINA_OPTS=-Xmx512m -Xms512m -Xmn64m -Xss2m 或者
set JAVA_OPTS=-Xmx512m -Xms512m -Xmn64m -Xss2m
設(shè)置CATALINA_OPTS 和 JAVA_OPTS都是一個(gè)道理水泉,在啟動(dòng)tomcat的時(shí)候設(shè)置參數(shù)。
兩者區(qū)別是JAVA_OPTS在tomcat停止的時(shí)候也會(huì)執(zhí)行這個(gè)命令。
注意:Tomcat分為安裝版(.exe)和非安裝版或者解壓版(.zip)草则,個(gè)人還是比較喜歡解壓版丧没。兩者雖然在功能上沒(méi)有什么區(qū)別淑际,但是在設(shè)置上還是有要注意的地方。這里只談JVM設(shè)置要注意的地方。
安裝版:windows的服務(wù)會(huì)有一個(gè)tomcat服務(wù)缭受,當(dāng)啟動(dòng)服務(wù)的時(shí)候Tomcat會(huì)從注冊(cè)表讀取JVM的參數(shù)。也就是說(shuō)當(dāng)在tomcat的lib文件夾下catalina.bat或者startup.bat中設(shè)置JVM參數(shù)是無(wú)效的惰瓜。解決辦法:設(shè)置tomcat的注冊(cè)表梅桩;或者使用startup.bat啟動(dòng)tomcat。
解壓版:當(dāng)點(diǎn)擊startup.bat時(shí)伯铣,它會(huì)讀取catalina.bat中的配置呻此,不管在startup.bat文件還是在catalina.bat文件中設(shè)置JVM參數(shù),都會(huì)讀取JVM參數(shù)腔寡。
3. 查看堆的大小
在程序中查看焚鲜,返回值單位是字節(jié),當(dāng)然還有其他JVM參數(shù)可以查看放前。
Runtime.getRuntime().maxMemory();
或者在命令行 執(zhí)行jvisualvm 命令
或者%java_home%\bin 目錄下點(diǎn)擊jvisualvm.exe
或者在命令行執(zhí)行jconsole 命令
或者%java_home%\bin 目錄下點(diǎn)擊jconsole.exe
4. java內(nèi)存可以分為堆內(nèi)存和非堆內(nèi)存
—- 堆內(nèi)存設(shè)置:程序可以到達(dá)的忿磅,可以操作的
-Xms 初始堆內(nèi)存 默認(rèn)物理內(nèi)存1/64,也是最小分配堆內(nèi)存。當(dāng)空余堆內(nèi)存小于40%時(shí)凭语,會(huì)增加到-Xms的最大限制
-Xmx 最大堆內(nèi)存分配 默認(rèn)物理內(nèi)存1/4葱她,當(dāng)空余堆內(nèi)存大于70%時(shí),會(huì)減小到-Xms的最小限制似扔。
一般設(shè)置 -Xms和Xms大小相等
—- 非堆內(nèi)存設(shè)置
-XX:PermSize 非堆內(nèi)存的初始值吨些,默認(rèn)物理內(nèi)存的1/64 ,也是最小非堆內(nèi)存炒辉。
-XX:MaxPermSize 非堆內(nèi)存最大值豪墅,默認(rèn)物理內(nèi)存的1/4,
5. 典型JVM參數(shù)設(shè)置:
java -Xmx128m -Xms128m -Xmn64m -Xss1m
-Xmx128m:設(shè)置JVM最大可用內(nèi)存為128M。
-Xms128m:設(shè)置JVM最小內(nèi)存為128m黔寇。此值可以設(shè)置與-Xmx相同偶器,以避免每次垃圾回收完成后JVM重新分配內(nèi)存。
-Xmn2g:設(shè)置年輕代大小為2G缝裤。整個(gè)堆大小=年輕代大小 + 年老代大小 + 持久代大小状囱。持久代一般固定大小為64m,所以增大年輕代后倘是,將會(huì)減小年老代大小亭枷。此值對(duì)系統(tǒng)性能影響較大,Sun官方推薦配置為整個(gè)堆的3/8搀崭。
-Xss128k:設(shè)置每個(gè)線程的堆棧大小叨粘。 JDK5.0以后每個(gè)線程堆棧大小為1M猾编,以前每個(gè)線程堆棧大小為256K。根據(jù)應(yīng)用的線程所需內(nèi)存大小進(jìn)行調(diào)整升敲。在相同物理內(nèi)存下答倡,減小這個(gè)值能生成更 多的線程。但是操作系統(tǒng)對(duì)一個(gè)進(jìn)程內(nèi)的線程數(shù)還是有限制的驴党,不能無(wú)限生成瘪撇,經(jīng)驗(yàn)值在3000~5000左右。
— Ratio 英音:[‘reiseu] 比率
— Eden 伊甸
— Survivor 幸存者
java -Xmx3550m -Xms3550m -Xss128k -XX:NewRatio=4 -XX:SurvivorRatio=4 -XX:MaxPermSize=16m -XX:MaxTenuringThreshold=0
-XX:NewRatio=4:設(shè)置年輕代(包括Eden和兩個(gè)Survivor區(qū))與年老代的比值(除去持久代)港庄。設(shè)置為4倔既,則年輕代與年老代所占比值為1:4,年輕代占整個(gè)堆棧的1/5
-XX:SurvivorRatio=4:設(shè)置年輕代中Eden區(qū)與Survivor區(qū)的大小比值鹏氧。設(shè)置為4渤涌,則兩個(gè)Survivor區(qū)與一個(gè)Eden區(qū)的比值為2:4,一個(gè)Survivor區(qū)占整個(gè)年輕代的1/6
-XX:MaxPermSize=16m:設(shè)置持久代大小為16m把还。
-XX:MaxTenuringThreshold=0:設(shè)置垃圾最大年齡实蓬。如果設(shè)置為0的話,則年輕代對(duì)象不經(jīng)過(guò)Survivor區(qū)吊履,直接進(jìn)入年老代安皱。
對(duì)于年老代比較多的應(yīng)用,可以提高效率艇炎。如果將此值設(shè)置為一個(gè)較大值酌伊,則年輕代對(duì)象會(huì)在Survivor區(qū)進(jìn)行多次復(fù)制,這樣可以增加對(duì)象再年輕代的存活時(shí)間冕臭,增加在年輕代即被回收的概論腺晾。