Tomcat本身不能直接在計(jì)算機(jī)上運(yùn)行,需要依賴(lài)于操作系統(tǒng)和一個(gè)JAVA虛擬機(jī)布讹。JAVA程序啟動(dòng)時(shí)JVM會(huì)分配一個(gè)初始內(nèi)存和最大內(nèi)存給APP琳拭。當(dāng)APP需要的內(nèi)存超出內(nèi)存的最大值時(shí)虛擬機(jī)就會(huì)提示內(nèi)存溢出,并且導(dǎo)致應(yīng)用服務(wù)崩潰描验。
一白嘁、常見(jiàn)的Java內(nèi)存溢出有以下三種:
1. java.lang.OutOfMemoryError: Java heap space? ? ? 即JVM Heap溢出
解釋說(shuō)明:JVM在啟動(dòng)的時(shí)候會(huì)自動(dòng)設(shè)置JVM Heap的值,JVM堆的設(shè)置是指java程序運(yùn)行過(guò)程中JVM可以調(diào)配使用的內(nèi)存空間的設(shè)置膘流。其初始空間默認(rèn)是物理內(nèi)存的1/64絮缅,最大空間不可超過(guò)物理內(nèi)存。JVM提供-Xmn -Xms -Xmx等選項(xiàng)來(lái)進(jìn)行設(shè)置呼股。
出錯(cuò)場(chǎng)景:在JVM中耕魄,如果98%的時(shí)間是用于GC,且可用的Heap size不足2%時(shí)彭谁,將會(huì)出現(xiàn)JVM Heap溢出
解決方法:修改JVM Heap的大小吸奴。
2. java.lang.OutOfMemoryError: PermGen space? ? ? ? 即PermGen space溢出。(我出現(xiàn)的是這種情況缠局,在conf目錄下的catalina.sh加了一句代碼解決了)
解釋說(shuō)明:PermGen space是指內(nèi)存的永久保存區(qū)域奄抽。這個(gè)區(qū)域主要存放Class和Meta信息,Class在被Load時(shí)就會(huì)被放入PermGen space甩鳄。
出錯(cuò)場(chǎng)景:如果APP載入很多CLASS逞度,就可能會(huì)出現(xiàn)PermGen space溢出。(因?yàn)閟un的GC不會(huì)在程序運(yùn)行時(shí)對(duì)PermGen space進(jìn)行清理)妙啃。常見(jiàn)在web服務(wù)器對(duì)JSP進(jìn)行pre compile的時(shí)候
解決方法:修改MaxPermSize大小
3. java.lang.StackOverflowError? ? ? ? ? ? ? ? ? ? 即棧溢出
解釋說(shuō)明:JVM采用的是棧式的虛擬機(jī)档泽,函數(shù)的調(diào)用過(guò)程都體現(xiàn)在堆棧和退棧上。
出錯(cuò)場(chǎng)景:通常棧的大小是1-2MB的揖赴,如果調(diào)用構(gòu)造函數(shù)的 “層”太多馆匿,則會(huì)出現(xiàn)棧溢出
解決方法:修改程序
二、Tomcat的JVM內(nèi)存溢出解決方法
在生產(chǎn)環(huán)境中燥滑,tomcat內(nèi)存設(shè)置不好很容易出現(xiàn)JVM內(nèi)存溢渐北,解決方法就是修改Tomcat中的catalina.sh文件。
在catalina.sh文件中铭拧,找到cygwin=false赃蛛,在這一行的前面加入?yún)?shù)恃锉,具體如下
# vi TOMCAT_HOME/conf/catalina.sh
JAVA_OPTS="-server -Xms800m -Xmx800m -XX:PermSize=256m -XX:MaxPermSize=512m -XX:MaxNewSize=512m"