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

聊聊如何打印GC日志排查的問題

 更新時間:2021年09月14日 09:12:40   作者:犀牛飼養(yǎng)員  
這篇文章主要介紹了聊聊如何打印GC日志排查的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

如何打印GC日志排查問題

在工作當(dāng)中,有時候我們會需要打印GC的相關(guān)信息來定位問題。該如何做呢?

先來看個示例

public static void main(String[] args) {
        List<Integer> list0 = new ArrayList<>();
        long start0 = System.currentTimeMillis();
        for (int i = 0; i < 1000000; i++) {
            list0.add(i);
        }
        System.out.println("cost: " + (System.currentTimeMillis() - start0));

        List<Integer> list1 = new ArrayList<>();
        long start1 = System.currentTimeMillis();
        for (int i = 0; i < 1000000; i++) {
            list1.add(i);
        }
        System.out.println("cost: " + (System.currentTimeMillis() - start1));
    }

直接運(yùn)行,結(jié)果如下

cost: 135

cost: 85

你應(yīng)該覺得奇怪,同樣的往一個list插入100萬條數(shù)據(jù),為啥第一個耗時比較久?

這種時候,有經(jīng)驗(yàn)的工程師應(yīng)該能馬上懷疑是GC的問題,我們可以通過在運(yùn)行時添加JVM參數(shù)來打印程序運(yùn)行時的GC情況。

-XX:+PrintGCDetails

如果是使用IDEA來運(yùn)行,可以在 run configurations 的 VM options添加上面的參數(shù)即可。

再次運(yùn)行,輸出如下

[GC (Allocation Failure) [PSYoungGen: 1536K->512K(1536K)] 1884K->1234K(262144K), 0.0009030 secs] [Times: user=0.01 sys=0.00, real=0.00 secs]
[GC (Allocation Failure) [PSYoungGen: 1302K->1017K(2560K)] 2025K->1948K(263168K), 0.0012290 secs] [Times: user=0.01 sys=0.01, real=0.01 secs]
[GC (Allocation Failure) [PSYoungGen: 2553K->1504K(3072K)] 3484K->3051K(263680K), 0.0017210 secs] [Times: user=0.02 sys=0.00, real=0.00 secs]
[GC (Allocation Failure) [PSYoungGen: 3040K->2033K(4608K)] 4587K->4228K(265216K), 0.0023170 secs] [Times: user=0.02 sys=0.00, real=0.00 secs]
[GC (Allocation Failure) [PSYoungGen: 4593K->2560K(5120K)] 8195K->6681K(265728K), 0.0249700 secs] [Times: user=0.31 sys=0.00, real=0.03 secs]
[GC (Allocation Failure) [PSYoungGen: 5120K->3584K(6656K)] 11352K->11408K(267264K), 0.0241680 secs] [Times: user=0.30 sys=0.01, real=0.03 secs]
[GC (Allocation Failure) [PSYoungGen: 6656K->3296K(7680K)] 17645K->17909K(268288K), 0.0349010 secs] [Times: user=0.45 sys=0.00, real=0.03 secs]
[GC (Allocation Failure) [PSYoungGen: 6368K->3328K(10240K)] 25729K->25825K(270848K), 0.0314260 secs] [Times: user=0.40 sys=0.00, real=0.03 secs]
cost: 137
[GC (Allocation Failure) [PSYoungGen: 8166K->4469K(10240K)] 30663K->30103K(270848K), 0.0285370 secs] [Times: user=0.36 sys=0.01, real=0.03 secs]
[GC (Allocation Failure) [PSYoungGen: 9166K->3785K(13312K)] 34800K->33427K(273920K), 0.0226780 secs] [Times: user=0.28 sys=0.01, real=0.02 secs]
[GC (Allocation Failure) [PSYoungGen: 11465K->6142K(13824K)] 41107K->38511K(274432K), 0.0065540 secs] [Times: user=0.08 sys=0.00, real=0.00 secs]
[GC (Allocation Failure) [PSYoungGen: 13822K->7837K(19456K)] 46191K->44246K(280064K), 0.0099720 secs] [Times: user=0.11 sys=0.01, real=0.01 secs]
cost: 79

所以你大概明白了,第一次minor gc的次數(shù)比第二次多,所以運(yùn)行時間比較長。

那么上面打印出來的日志,具體是什么意思呢?

已經(jīng)有人畫出了很詳細(xì)的圖,我借來用下

在這里插入圖片描述

在這里插入圖片描述

如果想了解 GC 的更多的內(nèi)容,可以看看 oracle 官方對于 HosSpotJVM GC的詳細(xì)介紹

小結(jié)一下

了解GC日志的打印方法,并且能看懂GC日志,對于查找定位問題非常有幫助的。

我自己就遇到過生產(chǎn)上一個CPU飆到好幾百的情況,打印GC日志發(fā)現(xiàn) JVM 一直在 fullGC,而且每次GC之后內(nèi)存基本沒有變化,從而定位到應(yīng)用程序可能存在內(nèi)存泄漏的問題。

gc日志打印時間戳

今天發(fā)現(xiàn)在jvm參數(shù)中,用-XX:+PrintGCDateStamps 替換 -XX:PrintGCTimeStamps,就可以打印真實(shí)的gc時間信息,而不像現(xiàn)在相對啟動時間的秒數(shù)。

有了真實(shí)時間戳,可以方便與應(yīng)用的log做對比,便于分析排查問題。

線下實(shí)驗(yàn)過,真實(shí)有效gc日志打印時間戳

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

相關(guān)文章

  • Java8中的Stream?流實(shí)踐操作

    Java8中的Stream?流實(shí)踐操作

    這篇文章主要介紹了Java8中的Stream?流實(shí)踐操作,Stream?是?java8?中處理集合的抽象概念,可以執(zhí)行非常復(fù)雜的查詢、過濾和映射數(shù)據(jù)等操作,下文更多相關(guān)資料介紹,需要的朋友可以參考一下
    2022-05-05
  • WebsocketClient斷線的一些常見原因及解決辦法

    WebsocketClient斷線的一些常見原因及解決辦法

    這篇文章主要給大家介紹了關(guān)于WebsocketClient斷線的一些常見原因及解決辦法,文中通過代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用WebsocketClient斷線具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-12-12
  • Spring Cloud出現(xiàn)Options Forbidden 403問題解決方法

    Spring Cloud出現(xiàn)Options Forbidden 403問題解決方法

    本篇文章主要介紹了Spring Cloud出現(xiàn)Options Forbidden 403問題解決方法,具有一定的參考價值,有興趣的可以了解一下
    2017-11-11
  • Spring Boot集成教程之異步調(diào)用Async

    Spring Boot集成教程之異步調(diào)用Async

    在項(xiàng)目中,當(dāng)訪問其他人的接口較慢或者做耗時任務(wù)時,不想程序一直卡在耗時任務(wù)上,想程序能夠并行執(zhí)行,我們可以使用多線程來并行的處理任務(wù),也可以使用spring提供的異步處理方式@Async。需要的朋友們下面來一起看看吧。
    2018-03-03
  • Java使用OTP動態(tài)口令(每分鐘變一次)進(jìn)行登錄認(rèn)證

    Java使用OTP動態(tài)口令(每分鐘變一次)進(jìn)行登錄認(rèn)證

    這篇文章主要介紹了Java使用OTP動態(tài)口令(每分鐘變一次)進(jìn)行登錄認(rèn)證,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • 基于Servlet實(shí)現(xiàn)技術(shù)問答網(wǎng)站系統(tǒng)

    基于Servlet實(shí)現(xiàn)技術(shù)問答網(wǎng)站系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了基于Servlet實(shí)現(xiàn)技術(shù)問答網(wǎng)站系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • Spring注入Bean的一些方式總結(jié)

    Spring注入Bean的一些方式總結(jié)

    這篇文章主要給大家總結(jié)介紹了關(guān)于Spring注入Bean的一些方式,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Spring具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • SpringBoot2整合activiti6環(huán)境搭建過程解析

    SpringBoot2整合activiti6環(huán)境搭建過程解析

    這篇文章主要介紹了SpringBoot2整合activiti6環(huán)境搭建過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • 詳解JAVA常用的時間操作【實(shí)用】

    詳解JAVA常用的時間操作【實(shí)用】

    本文主要介紹了JAVA一些常用的時間操作,很實(shí)用,相信大家在開發(fā)項(xiàng)目時會用到,下面就跟小編一起來看下吧
    2016-12-12
  • spring MVC cors跨域?qū)崿F(xiàn)源碼解析

    spring MVC cors跨域?qū)崿F(xiàn)源碼解析

    本文主要介紹了spring MVC cors跨域?qū)崿F(xiàn)源碼解析。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02

最新評論