日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
JVM發(fā)生內(nèi)存溢出的8種原因、及解決辦法

JVM發(fā)生內(nèi)存溢出的8種原因、及解決辦法

作者:Java架構(gòu)學(xué)習(xí)交流 2019-08-29 14:29:42
云計算
虛擬化 應(yīng)用程序過度使用 finalizer。finalizer 對象不能被 GC 立刻回收。finalizer 由結(jié)束隊列服務(wù)的守護線程調(diào)用,有時 finalizer 。

創(chuàng)新互聯(lián)于2013年成立,先為寧國等服務(wù)建站,寧國等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為寧國企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

 1. Java 堆空間

發(fā)生頻率:5顆星

造成原因

  • 無法在 Java 堆中分配對象
  • 吞吐量增加
  • 應(yīng)用程序無意中保存了對象引用,對象無法被 GC 回收
  • 應(yīng)用程序過度使用 finalizer。finalizer 對象不能被 GC 立刻回收。finalizer 由結(jié)束隊列服務(wù)的守護線程調(diào)用,有時 finalizer 線程的處理能力無法跟上結(jié)束隊列的增長

解決方案

  • 使用 -Xmx 增加堆大小
  • 修復(fù)應(yīng)用程序中的內(nèi)存泄漏

2. GC 開銷超過限制

發(fā)生頻率:5顆星

造成原因

  • Java 進程98%的時間在進行垃圾回收,恢復(fù)了不到2%的堆空間,最后連續(xù)5個(編譯時常量)垃圾回收一直如此。

解決方案

  • 使用 -Xmx 增加堆大小
  • 使用 -XX:-UseGCOverheadLimit 取消 GC 開銷限制
  • 修復(fù)應(yīng)用程序中的內(nèi)存泄漏

3. 請求的數(shù)組大小超過虛擬機限制

發(fā)生頻率:2顆星

造成原因

  • 應(yīng)用程序試圖分配一個超過堆大小的數(shù)組

解決方案

  • 使用 -Xmx 增加堆大小
  • 修復(fù)應(yīng)用程序中分配巨大數(shù)組的 bug

4. Perm gen 空間

發(fā)生頻率:3顆星

造成原因

Perm gen 空間包含:

  • 類的名字、字段、方法
  • 與類相關(guān)的對象數(shù)組和類型數(shù)組
  • JIT 編譯器優(yōu)化

當(dāng) Perm gen 空間用盡時,將拋出異常。

解決方案

  • 使用 -XX: MaxPermSize 增加 Permgen 大小
  • 不重啟應(yīng)用部署應(yīng)用程序可能會導(dǎo)致此問題。重啟 JVM 解決

5. Metaspace

發(fā)生頻率:3顆星

造成原因

  • 從 Java 8 開始 Perm gen 改成了 Metaspace,在本機內(nèi)存中分配 class 元數(shù)據(jù)(稱為 metaspace)。如果 metaspace 耗盡,則拋出異常

解決方案

  • 通過命令行設(shè)置 -XX: MaxMetaSpaceSize 增加 metaspace 大小
  • 取消 -XX: maxmetsspacedize
  • 減小 Java 堆大小,為 MetaSpace 提供更多的可用空間
  • 為服務(wù)器分配更多的內(nèi)存
  • 可能是應(yīng)用程序 bug,修復(fù) bug

6. 無法新建本機線程

發(fā)生頻率:5顆星

造成原因

  • 內(nèi)存不足,無法創(chuàng)建新線程。由于線程在本機內(nèi)存中創(chuàng)建,報告這個錯誤表明本機內(nèi)存空間不足

解決方案

  • 為機器分配更多的內(nèi)存
  • 減少 Java 堆空間
  • 修復(fù)應(yīng)用程序中的線程泄漏。
  • 增加操作系統(tǒng)級別的限制
  • ulimit -a
  • 用戶進程數(shù)增大 (-u) 1800
  • 使用 -Xss 減小線程堆棧大小

7. 殺死進程或子進程

發(fā)生頻率:1顆星

造成原因

  • 內(nèi)核任務(wù):內(nèi)存不足結(jié)束器,在可用內(nèi)存極低的情況下會殺死進程

解決方案

  • 將進程遷移到不同的機器上
  • 給機器增加更多內(nèi)存
  • 與其他 OOM 錯誤不同,這是由操作系統(tǒng)而非 JVM 觸發(fā)的。

8. 發(fā)生 stack_trace_with_native_method

發(fā)生頻率:1顆星

造成原因

  • 本機方法(native method)分配失敗
  • 打印的堆棧跟蹤信息,最頂層的幀是本機方法

解決方案

使用操作系統(tǒng)本地工具進行診斷


網(wǎng)站標(biāo)題:JVM發(fā)生內(nèi)存溢出的8種原因、及解決辦法
瀏覽路徑:http://m.5511xx.com/article/cospijg.html