溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java中關于OOM的場景及解決方法是什么

發布時間:2021-12-07 16:42:10 來源:億速云 閱讀:165 作者:柒染 欄目:編程語言

這期內容當中小編將會給大家帶來有關Java中關于OOM的場景及解決方法是什么,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

1、OOM for Heap=>例如:java.lang.OutOfMemoryError: Java heap space

分  析

此OOM是由于JVM中heap的***值不滿足需要,將設置heap的***值調高即可,參數樣例為:-Xmx2G

解決方法

調高heap的***值,即-Xmx的值調大。2、OOM for Perm=>例如:java.lang.OutOfMemoryError: Java perm space

分  析

此OOM是由于JVM中perm的***值不滿足需要,將設置perm的***值調高即可,參數樣例為:-XX:MaxPermSize=512M

解決方法

調高heap的***值,即-XX:MaxPermSize的值調大。

另外,注意一點,Perm一般是在JVM啟動時加載類進來,如果是JVM運行較長一段時間而不是剛啟動后溢出的話,很有可能是由于運行時有類被動態加載進來,此時建議用CMS策略中的類卸載配置。

如:-XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled3、OOM for GC=>例如:java.lang.OutOfMemoryError: GC overhead limit exceeded

分  析

此OOM是由于JVM在GC時,對象過多,導致內存溢出,建議調整GC的策略,在一定比例下開始GC而不要使用默認的策略,或者將新代和老代設置合適的大小,需要進行微調存活率。

解決方法

改變GC策略,在老代80%時就是開始GC,并且將-XX:SurvivorRatio(-XX:SurvivorRatio=8)和-XX:NewRatio(-XX:NewRatio=4)設置的更合理。4、OOM for native thread created=>

如:java.lang.OutOfMemoryError: unable to create new native thread

分  析

參考如下:

(MaxProcessMemory - JVMMemory - ReservedOsMemory) / (ThreadStackSize) = Number of threads

MaxProcessMemory   指的是一個進程的***內存

JVMMemory         JVM內存

ReservedOsMemory   保留的操作系統內存

ThreadStackSize      線程棧的大小

如果JVM內存調的過大或者可利用率小于20%,可以建議將heap及perm的***值下調,并將線程棧調小,即-Xss調小,如:-Xss128k

解決方法

在JVM內存不能調小的前提下,將-Xss設置較小,如:-Xss:128k

5、OOM for allocate huge array=>例如:Exception in thread "main": java.lang.OutOfMemoryError: Requested array size exceeds VM limit

分  析

此類信息表明應用程序(或者被應用程序調用的APIs)試圖分配一個大于堆大小的數組。例如,如果應用程序new一個數組對象,大小為512M,但是***堆大小為256M,因此OutOfMemoryError會拋出,因為數組的大小超過虛擬機的限制。

解決方法

(1)、首先檢查heap的-Xmx是不是設置的過小

(2)、如果heap的-Xmx已經足夠大,那么請檢查應用程序是不是存在bug,例如:應用程序可能在計算數組的大小時,存在算法錯誤,導致數組的size很大,從而導致巨大的數組被分配。

6、 OOM for small swap=>例如:Exception in thread "main": java.lang.OutOfMemoryError: request <size> bytes for <reason>. Out of swap space?

分  析

拋出這類錯誤,是由于從native堆中分配內存失敗,并且堆內存可能接近耗盡。這類錯誤可能跟應用程序沒有關系,例如下面兩種原因也會導致錯誤的發生:

(1)操作系統配置了較小的交換區

(2)系統的另外一個進程正在消耗所有的內存

解決方法

(1)、檢查os的swap是不是沒有設置或者設置的過小

(2)、檢查是否有其他進程在消耗大量的內存,從而導致當前的JVM內存不夠分配。

注意:雖然有時<reason>部分顯示導致OOM的原因,但大多數情況下,<reason>顯示的是提示分配失敗的源模塊的名稱,所以有必要查看日志文件,如crash時的hs文件。

上述就是小編為大家分享的Java中關于OOM的場景及解決方法是什么了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女