欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

測試環(huán)境頻繁Full GC問題的解決思路分析

 更新時間:2025年01月03日 08:43:22   作者:萊特昂  
全文介紹了作者通過與調(diào)用方交互,發(fā)現(xiàn)welink-front服務(wù)不可用的問題,通過jmap-heap和jstat-gccause命令,作者找到了問題的原因是元數(shù)據(jù)區(qū)內(nèi)存使用率過高,觸發(fā)了FullGC,作者通過分析GC日志和堆內(nèi)存使用情況,確定了問題的根本原因

背景

上游調(diào)用方,反饋當前welink-front服務(wù)不可用;

臨時解決辦法

手動重啟welink-front服務(wù),重啟之后觀測到業(yè)務(wù)日志正常刷,說明該問題暫時得到了解決;

但沒過多久,上游調(diào)用方的同學又找來了,反饋當前服務(wù)又不可用了,果然該來的總是會來;

現(xiàn)象

直接jmap -heap [pid]打印堆內(nèi)存大小,瞧著內(nèi)存使用情況挺正常的;

gc日志顯示,當前java服務(wù)在頻繁的進行FullGC;

這里有個點,就是FullGC后,堆可用內(nèi)存大小基本沒怎么變化,GC了個寂寞;

細細想來,F(xiàn)ullGC的原因無非那么幾種:

  • 1、實際業(yè)務(wù)導(dǎo)致堆內(nèi)存短時間內(nèi)暴增,例如高并發(fā)場景;
  • 2、大對象;
  • 3、內(nèi)存泄漏,老年代存在大量釋放不掉的對象;
  • 4、元數(shù)據(jù)區(qū)滿了;
  • 5、堆外內(nèi)存;
  • 6、System.gc();

其實糾結(jié)那么多干嘛,直接jstat -gccause [pid]看GC原因就好了;

其實到這里就很明了了,元數(shù)據(jù)區(qū)內(nèi)存使用率97.26%,上次GC原因為:Metadata GC Threshold,當前GC原因為:Last ditch collection;

  • Metadata GC Threshold:metaspace空間不能滿足分配時觸發(fā),這個階段不會清理軟引用;
  • Last ditch collection:經(jīng)過Metadata GC Threshold觸發(fā)的full gc后還是不能滿足條件,這個時候會觸發(fā)再一次的gc cause為Last ditch collection的full gc,這次full gc會清理掉軟引用;

到這里基本可以斷定,就是元數(shù)據(jù)區(qū)內(nèi)存不夠霍霍了;根據(jù)前面堆內(nèi)存打印顯示,元數(shù)據(jù)區(qū)內(nèi)最大為128M;這個也跟前面GC日志的結(jié)果相吻合;

所以解決方案就是直接調(diào)大堆內(nèi)存和元數(shù)據(jù)區(qū)內(nèi)存;

為什么是直接調(diào)大元數(shù)據(jù)區(qū)的內(nèi)存大小呢?

是因為在測試環(huán)境的發(fā)布模板中,我們通常會直接將內(nèi)存調(diào)小;

反思與總結(jié)

測試環(huán)境的問題,發(fā)現(xiàn)了應(yīng)當立即定位分析根本原因,然后評估影響并確定解決方案,不要把懸念帶上生產(chǎn);

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java將日期類型Date時間戳轉(zhuǎn)換為MongoDB的時間類型數(shù)據(jù)

    Java將日期類型Date時間戳轉(zhuǎn)換為MongoDB的時間類型數(shù)據(jù)

    今天小編就為大家分享一篇關(guān)于Java將日期類型Date時間戳轉(zhuǎn)換為MongoDB的時間類型數(shù)據(jù),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • Spring Cloud下OAUTH2注銷的實現(xiàn)示例

    Spring Cloud下OAUTH2注銷的實現(xiàn)示例

    本篇文章主要介紹了Spring Cloud下OAUTH2注銷的實現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • Java中字符串常見的拼接方式小結(jié)

    Java中字符串常見的拼接方式小結(jié)

    在Java中,字符串拼接是開發(fā)過程中非常常見的操作,根據(jù)不同的需求和性能考慮,有多種方式可以實現(xiàn)字符串的拼接,本文給大家介紹了五種拼接方式,并通過代碼講解的非常詳細,需要的朋友可以參考下
    2024-10-10
  • 舉例講解Java編程中this關(guān)鍵字與super關(guān)鍵字的用法

    舉例講解Java編程中this關(guān)鍵字與super關(guān)鍵字的用法

    這篇文章主要介紹了Java編程中this關(guān)鍵字與super關(guān)鍵字的用法示例,super是this的父輩,在繼承過程中兩個關(guān)鍵字經(jīng)常被用到,需要的朋友可以參考下
    2016-03-03
  • shardingJdbc3.x?版本的分頁bug問題解析

    shardingJdbc3.x?版本的分頁bug問題解析

    這篇文章主要為大家介紹了shardingJdbc3.x?版本的分頁問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • java中如何使用泛型方法比較大小

    java中如何使用泛型方法比較大小

    這篇文章主要介紹了java中如何使用泛型方法比較大小,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • SpringBoot中Excel處理完全指南分享

    SpringBoot中Excel處理完全指南分享

    這篇文章主要介紹了SpringBoot中Excel處理完全指南,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • Java ConcurrentHashMap的使用示例

    Java ConcurrentHashMap的使用示例

    這篇文章主要介紹了Java ConcurrentHashMap的使用示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下
    2021-04-04
  • Java Jwt庫的簡介及使用詳解

    Java Jwt庫的簡介及使用詳解

    JWT 是開放的行業(yè)標準RFC7591,用來實現(xiàn)端到端安全驗證,就是通過一些算法對加密字符串和JSON對象之間進行加解密,下面通過本文給大家介紹Java Jwt庫的簡介及使用,感興趣的朋友一起看看吧
    2021-11-11
  • 深入了解Java中Synchronized的各種使用方法

    深入了解Java中Synchronized的各種使用方法

    在Java當中synchronized關(guān)鍵字通常是用來標記一個方法或者代碼塊。本文將通過示例為大家詳細介紹一下Synchronized的各種使用方法,需要的可以參考一下
    2022-08-08

最新評論