淺談JVM內(nèi)存溢出原因和解決思路
棧溢出(虛擬機(jī)棧和本地方法棧)
產(chǎn)生原因
- 在HotSpot中,只能由-Xss參數(shù)來設(shè)定。因?yàn)樵贖otSpot中不區(qū)分虛擬機(jī)棧和本地方法棧的。
- 棧溢出時(shí)會(huì)出現(xiàn)兩種異常:StackOverflowError異常和OutOfMemoryError異常。
- StackOverflowError異常因?yàn)榫€程請(qǐng)求的棧深度大于虛擬機(jī)允許的最大深度。
- OutOfMemoryError異常發(fā)生在虛擬機(jī)棧內(nèi)存允許動(dòng)態(tài)擴(kuò)展的情況下,當(dāng)擴(kuò)展棧容量無法申請(qǐng)到足夠的內(nèi)存時(shí)。
- 因?yàn)镠otSpot是不支持?jǐn)U展的,所在除非在線程創(chuàng)建時(shí)申請(qǐng)內(nèi)存無法滿足時(shí),才會(huì)出現(xiàn)OutOfMemoryError,其余都是產(chǎn)生StackOverflowError異常。
- 結(jié)論:給每個(gè)線程的棧分配內(nèi)存不是越大越好??梢赃@么理解,比如總的內(nèi)存是2G,如果一個(gè)線程就占了1.5G,那就。。。。
解決思路
出現(xiàn) StackOverflowError異常時(shí),會(huì)有明確錯(cuò)誤堆??晒┓治?,相對(duì)而言比較容易定位到問題所在。
如果使用Hotspot虛擬機(jī)默認(rèn)參數(shù),棧深度在大多數(shù)情況下(因?yàn)槊總€(gè)方法壓人棧的幀大小并不是一樣的,所以只能說大多數(shù)情況下)到達(dá)1000~2000 是完全沒有問題,對(duì)于正常的方法調(diào)用(包括不能做尾遞歸優(yōu)化的遞歸調(diào)用),這個(gè)深度應(yīng)該完全夠用了。但是,如果是建立過多線程導(dǎo)致的內(nèi)存濫出,在不能減少線程數(shù)量或者更換 64 位虛擬機(jī)的情況下,就只能通過減少最大堆和減少棧容量來換取更多的線程。
堆溢出
產(chǎn)生原因
當(dāng)不斷的創(chuàng)建對(duì)象并避免垃圾回收時(shí),總?cè)萘坑|及最大堆容量時(shí),就會(huì)產(chǎn)生溢出。
運(yùn)行代碼:設(shè)置vm參數(shù)-Xms10m -Xmx10m
public class HeapTest {
static class OOMObj{
}
/**
* vm arg -Xms10m -Xmx10m -XX:+HeapDumpOnOutOfMemoryError
*/
public static void main(String[] args) {
List<OOMObj> oomObjList = new ArrayList<OOMObj>();
while (true){
oomObjList.add(new OOMObj());
}
}
}
結(jié)果:

解決思路
首先通過內(nèi)存映像分析工具確認(rèn)是內(nèi)存泄漏還是內(nèi)存溢出。
- 如果是內(nèi)存泄漏,說明導(dǎo)致OOM的對(duì)象不是必要的。進(jìn)一步通過工具查看GC Roots引用鏈。一般可以比較精確的定位。
- 如果是內(nèi)存溢出,對(duì)象是必須存活的,那就檢查虛擬機(jī)的堆參數(shù)-Xms、-Xmx設(shè)置,對(duì)比機(jī)器內(nèi)存,看是否還有上調(diào)的空間。再從代碼上檢查對(duì)象生命周期、持有狀態(tài)時(shí)間、存儲(chǔ)結(jié)構(gòu)是否有設(shè)計(jì)不合理等情況。
方法區(qū)和運(yùn)行時(shí)常量池溢出
產(chǎn)生原因
一個(gè)類要被垃圾收集器回收,條件是比較苛刻的。在經(jīng)常運(yùn)行時(shí)生成大量動(dòng)態(tài)類的應(yīng)用場景里,就應(yīng)該特別關(guān)注了。
解決思路
HotSpot在JDK8中已經(jīng)完全使用元空間代替永久帶。Hotspot提供了一些參數(shù)作為元空間的防御措施,主要包括:
- XX:MaxMetaspacesize:設(shè)置元空間最大值,默認(rèn)是-1,即不限制,或者說只受限于本地內(nèi)存大小。
- -XX:Metaspacesize :指定元空間的初始空間大小,以宇節(jié)為單位,達(dá)到該值就會(huì)觸發(fā)垃圾收集進(jìn)行類型卸載,同時(shí)收集器會(huì)對(duì)該值進(jìn)行調(diào)整:如果釋放了大量的空間,就適當(dāng)降低該值;如果釋放了很少的空間,那么在不超過-XX:MaxMetaspaceSize(如果設(shè)置了的話)的情況下,適當(dāng)提高該值。
- -XX:MinMetaspace Free Ratio:作用是在垃圾收集之后控制最小的元空間剩余容量的百分比,可減少因?yàn)樵臻g不足導(dǎo)致的垃圾收集的頻率。類似的還有-xx:Max-MetaspaceFreeRatio,用于控制最大的元空間剩余容量的百分比。
本機(jī)直接內(nèi)存溢出
產(chǎn)生原因
在直接或間接使用了ByteBuffer中的allocateDirect方法的時(shí)候,而不做clear的時(shí)候就會(huì)出現(xiàn)類似的問題。明顯的特征是在Heap Dump文件中不會(huì)看到明顯的異常情況。
解決思路
設(shè)置參數(shù): -XX:MaxDirectMemorySize
到此這篇關(guān)于淺談JVM內(nèi)存溢出原因和解決思路的文章就介紹到這了,更多相關(guān)JVM內(nèi)存溢出內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot多數(shù)據(jù)源配置方式以及報(bào)錯(cuò)問題的解決
這篇文章主要介紹了SpringBoot多數(shù)據(jù)源配置方式以及報(bào)錯(cuò)問題的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
基于Java字符串 "==" 與 "equals" 的深入理解
本篇文章是對(duì)Java中的字符串"=="與"equals"進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
SSM?Mapper文件查詢出返回?cái)?shù)據(jù)查不到個(gè)別字段的問題
這篇文章主要介紹了SSM?Mapper文件查詢出返回?cái)?shù)據(jù)查不到個(gè)別字段的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
Spring Boot通過Redis實(shí)現(xiàn)防止重復(fù)提交
表單提交是一個(gè)非常常見的功能,如果不加控制,容易因?yàn)橛脩舻恼`操作或網(wǎng)絡(luò)延遲導(dǎo)致同一請(qǐng)求被發(fā)送多次,本文主要介紹了Spring Boot通過Redis實(shí)現(xiàn)防止重復(fù)提交,具有一定的參考價(jià)值,感興趣的可以了解一下2024-06-06
springboot+idea熱部署的實(shí)現(xiàn)方法(自動(dòng)刷新)
這篇文章主要介紹了springboot+idea熱部署的實(shí)現(xiàn)方法(自動(dòng)刷新),本文分步驟通過實(shí)例代碼截圖相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
動(dòng)力節(jié)點(diǎn)_王勇_DRP項(xiàng)目視頻教程完整版292集
該視頻由國內(nèi)知名講師王勇老師主講,適合掌握J(rèn)ava基礎(chǔ)內(nèi)容的同學(xué)學(xué)習(xí),本視頻共計(jì)292集,學(xué)習(xí)Java Web項(xiàng)目,DRP項(xiàng)目視頻是首選,累計(jì)下載量已經(jīng)達(dá)到上千萬,很多同學(xué)通過自學(xué)該視頻找到了軟件開發(fā)工作2017-04-04
完美解決Spring Boot前端的Access-Control-Allow-Origin跨域問題
這篇文章主要介紹了完美解決Spring Boot前端的Access-Control-Allow-Origin跨域問題,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05
Springboot @Validated和@Valid的區(qū)別及使用詳解
這篇文章主要介紹了Springboot @Validated和@Valid的區(qū)別及使用詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
詳解Spring Cloud Gateway修改請(qǐng)求和響應(yīng)body的內(nèi)容
這篇文章主要介紹了Spring Cloud Gateway修改請(qǐng)求和響應(yīng)body的內(nèi)容的相關(guān)資料,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09

