java獲取到heapdump文件後,如何快速分析?

来源:https://www.cnblogs.com/codelogs/archive/2023/04/21/17342022.html
-Advertisement-
Play Games

原創:扣釘日記(微信公眾號ID:codelogs),歡迎分享,非公眾號轉載保留此聲明。 簡介 在之前的OOM問題復盤之後,本周,又一Java服務出現了記憶體問題,這次問題不嚴重,只會觸發堆記憶體占用高報警,沒有觸發OOM,但好在之前的復盤中總結了dump腳本,會在堆占用高時自動執行jstack與jmap ...


原創:扣釘日記(微信公眾號ID:codelogs),歡迎分享,非公眾號轉載保留此聲明。

簡介

在之前的OOM問題復盤之後,本周,又一Java服務出現了記憶體問題,這次問題不嚴重,只會觸發堆記憶體占用高報警,沒有觸發OOM,但好在之前的復盤中總結了dump腳本,會在堆占用高時自動執行jstack與jmap,使得我們成功保留了問題現場。

查看堆占用分佈

發現有heapdump文件後,我立馬拷貝到本機,並使用MAT分析,如下:
mat
很顯然,好像是什麼介面分配了非常大的String對象,一個String對象約200MB,那它是哪分配的呢?

查找大對象分配線程

這個分配行為肯定是某個線程做的,而線程是最常見的GC Root,因此只要查找對象的GC Root即可,如下:
gc_root
找到了大對象對應的分配線程是http-nio-8088-exec-6,如下:
image_2023-04-21_20230421200748

查看線程棧

如何查看這個線程在乾什麼呢?在MAT中摸索了一會,沒找到相關內容,回想起我們的dump腳本中記錄了jstack,打開看看,如下:
jstack
可以發現,這個線程正在做json序列化,但我仔細找了好一會,也沒有找到相關介面的Controller,這是因為線程已經執行完了Controller裡面的邏輯,之後返回介面響應數據時分配的大對象。

可是,線程棧中沒有業務代碼,就沒法定位是哪個介面有問題了。。。

檢查accesslog日誌

考慮到分配大對象的介面肯定會很慢,於是我轉向查看tomcat的accesslog日誌,如下:
accesslog
終於,找到了問題介面,這個介面是用來查詢商品數據的,當輸入3時會查詢出所有3開頭的商品,而這有20w+數據,解決問題很簡單,加個limit完事。

排查過程復盤

然而,我一直有個習慣,就是解決一個問題後,我會反思一下問題解決過程中有多少運氣成分。

如果你經常閱讀排查問題類的技術文章,就會發現不少文章,中間突然有一步定位到了問題根因,可能是突然發現了一個線索,或是硬看代碼看出來的,或是猜測某處有問題,我覺得這種排查過程都有不少運氣成分,我希望問題是通過多年理論基礎的積累和對診斷工具的熟練使用,而有章法的一步步查出來的。

而上面通過accesslog能夠定位到問題,有一定的運氣成分,因為本次記憶體問題不極端,如果此介面請求量大,那就會瞬間觸發多次FGC,進而會影響其它介面也變慢,進而無法分辨出哪個是導致問題的介面!

我想,從理論上來說,Java堆文件裡面,應該有線程棧以及線程棧上的參數,因為線程是對象,參數也是對象,它們理應都在堆里,於是我找了個空閑時間,又摸索起MAT這個工具了。

MAT查看線程棧

摸索了一會,我就發現有這樣一個按鈕,可以查看線程信息,如下:
mat_thread

找到前面說的線程http-nio-8088-exec-6,展開後,就可以發現線程棧以及棧上的參數,如下:
mat_thread_stack

這就找到了請求的Request參數對象,再將Request對象多次展開後,就可以找到介面url信息,如下:
mat_request
嗯,這樣分析heapdump文件真tm的高效啊

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、簡單瞭解JS 1. JavaScript(簡稱JS)是作為開發Web頁面的腳本語言。 2. JS是從1995年由網景公司的布蘭德開發。 3. JavaScript的標準是ECMAScript。 4. JS代碼是從上往下執行的。 二、變數 1. 變數名的值可以重覆賦值(值可以修改),變數可以重覆聲 ...
  • HTML input type="number" 隱藏預設的步進箭頭 number 類型的 <input> 元素用於讓用戶輸入一個數字,其包括內置驗證以拒絕非數字輸入。 瀏覽器可能會選擇提供步進箭頭,讓用戶可以使用滑鼠增加和減少輸入的值,或者只需用指尖敲擊即可。但有些場景需要隱藏預設的步進箭頭。 要 ...
  • devServer 是一個用於配置開發伺服器的選項對象。它可以用來配置伺服器的各種選項,例如代理,埠號,HTTPS 等。 以下是一些常用的 devServer 參數和設置: port:指定開發伺服器的埠號,預設為 8080。 host:指定開發伺服器的主機名,預設為 localhost。 htt ...
  • 我們設計目前的門戶基座,可以快速瀏覽各個平臺,同時串聯數據開發與管理的工作,減少用戶的試錯成本,提升工作效率。 ...
  • 可以將Axios攔截器封裝成一個單獨的request文件,以便在整個應用程式中重覆使用。 以下是一個示例,展示如何將Axios攔截器封裝成一個request文件: 1、創建一個名為request.js的新文件,並導入Axios: import axios from 'axios'; 2、創建一個名為 ...
  • 簡介 觀察者模式(Observer Pattern)是一種行為型模式。它定義對象間的一種一對多的依賴關係,當一個對象的狀態發生改變時,所有依賴於它的對象都得到通知並被自動更新。 觀察者模式使用三個類Subject、Observer和Client。Subject對象帶有綁定觀察者到Client對象和從 ...
  • 本文首發於公眾號:Hunter後端 原文鏈接:Django筆記二十七之資料庫函數之文本函數 這篇筆記將介紹如何使用資料庫函數里的文本函數。 顧名思義,文本函數,就是針對文本欄位進行操作的函數,如下是目錄彙總: Concat() —— 合併 Left() —— 從左邊開始截取 Length() —— ...
  • 1 腐蝕操作 用於圖片的去毛刺,內容削減 1 #腐蝕操作 2 #cv2.erode(src,kernel,iterations) 3 #src是圖片數字化數組 4 #kernel則是一個盒,對該盒內的像素進行覆試操作,值越小腐蝕能力越狠 5 #iterations是一個迭代次數,就是說你對這個圖片進 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...