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

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

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

背景

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

臨時(shí)解決辦法

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

但沒(méi)過(guò)多久,上游調(diào)用方的同學(xué)又找來(lái)了,反饋當(dāng)前服務(wù)又不可用了,果然該來(lái)的總是會(huì)來(lái);

現(xiàn)象

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

gc日志顯示,當(dāng)前java服務(wù)在頻繁的進(jìn)行FullGC;

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

細(xì)細(xì)想來(lái),F(xiàn)ullGC的原因無(wú)非那么幾種:

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

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

其實(shí)到這里就很明了了,元數(shù)據(jù)區(qū)內(nèi)存使用率97.26%,上次GC原因?yàn)椋篗etadata GC Threshold,當(dāng)前GC原因?yàn)椋篖ast ditch collection;

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

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

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

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

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

反思與總結(jié)

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

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

相關(guān)文章

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

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

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

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

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

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

    在Java中,字符串拼接是開(kāi)發(fā)過(guò)程中非常常見(jiàn)的操作,根據(jù)不同的需求和性能考慮,有多種方式可以實(shí)現(xiàn)字符串的拼接,本文給大家介紹了五種拼接方式,并通過(guò)代碼講解的非常詳細(xì),需要的朋友可以參考下
    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ò)程中兩個(gè)關(guān)鍵字經(jīng)常被用到,需要的朋友可以參考下
    2016-03-03
  • shardingJdbc3.x?版本的分頁(yè)bug問(wèn)題解析

    shardingJdbc3.x?版本的分頁(yè)bug問(wèn)題解析

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

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

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

    SpringBoot中Excel處理完全指南分享

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

    Java ConcurrentHashMap的使用示例

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

    Java Jwt庫(kù)的簡(jiǎn)介及使用詳解

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

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

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

最新評(píng)論