new ArrayList 不當導致 CPU 飆升。。

来源:https://www.cnblogs.com/javastack/archive/2023/08/10/17619404.html
-Advertisement-
Play Games

來源:juejin.cn/post/7139202066362138654 昨天線上容器突然cpu飆升,也是第一次排查這種問題所以記錄一下~ ## 前言 首先問題是這樣的,周五正在寫文檔,突然收到了線上報警,發現cpu占用達到了90多,上平臺監控系統查看容器,在jvm監控中發現有一個pod在兩個小時 ...


來源:juejin.cn/post/7139202066362138654

昨天線上容器突然cpu飆升,也是第一次排查這種問題所以記錄一下~

前言

首先問題是這樣的,周五正在寫文檔,突然收到了線上報警,發現cpu占用達到了90多,上平臺監控系統查看容器,在jvm監控中發現有一個pod在兩個小時內產生了61次youngGc一次fullGc,這個問題特別嚴重且少見,由於我之前也沒有排查過此類問題,所以也是百度,但整個過程也有一些自己的思考,所以跟大家分享一下~

推薦一個開源免費的 Spring Boot 實戰項目:

https://github.com/javastacks/spring-boot-best-practice

當時場景

我先給大家看一下一副正常的gc曲線監控(為保密性,我自己按照平臺監控畫了出來):

正常的jvm監控曲線圖

正常的jvm監控曲線圖

產生問題的jvm監控曲線圖

產生問題的jvm監控曲

可以看的出來,正常情況下該系統很少gc(具體看業務系統使用情況、jvm記憶體分配),但是在圖二中出現了大量異常的gc情況甚至觸發了fullGc,所以我當時立馬進行了分析。

具體分析

首先異常gc的情況只出現在一個pod上(系統有多個pod),在監控系統找到對應的pod,進入pod內部查看問題原因,排查問題一定要冷靜

進入pod之後,輸入top查看各linux進程對系統資源的使用情況(因我這是事後補稿,資源使用不高,大家看步驟即可)

分析資源使用情況在當時的情況下

top

當時我的pid為1的進程cpu上到了130(多核)那我認定就是java應用出問題了,control+c退出繼續往下走

輸入top -H -p pid 通過此命令可以查看實際占用CPU最高的的線程的id,pid為剛纔資源使用高的pid號

top -H -p pid

出現具體線程的資源使用情況,表格裡的pid代表線程的id,我們稱他為tid

tid

我記得當時的tip為746(上述圖片只是我給大家重覆步驟),使用命令printf "%x\n" 746,將線程tid轉換為16進位

tid轉換為16進位

因為我們線程id號在堆棧里是16進位的所以需要做一個進位轉換

輸入jstack pid | grep 2ea >gc.stack

jstack pid | grep 2ea >gc.stack

jstack

解釋一下,jstack是jdk給提供的監控調優小工具之一,jstack會生成JVM當前時刻的線程快照,然後我們可以通過它查看某個Java進程內的線程堆棧信息,之後我們把堆棧信息通過管道收集2ea線程的信息,然後將信息生成為gc.stack文件,我隨便起的,隨意

當時我先cat gc.stack 發現數據有點多在容器里看不方便,於是我下載到本地瀏覽,因為公司對各個機器的訪問做了限制,我只能用跳板機先找到一臺沒用的機器a,把文件下載到a然後我再把a里的文件下載到本地(本地訪問跳板機OK),先輸入python -m SimpleHTTPServer 8080,linux自帶python,這個是開啟一個簡單http服務供外界訪問

開啟http服務

然後登錄跳板機,使用curl下載curl -o http://ip地址/gcInfo.stack

為方便演示,我在圖中把ip換了一個假的

curl

之後用同樣的方法從本地下載跳板機就可以了,記得關閉python開啟的建議服務嗷

把文件下載到了本地,打開查看編輯器搜索2ea,找到nid為2ea的堆棧信息

找到nid為2ea的堆棧信息

之後找到對應的impl根據行數分析程式

發現是在文件非同步導出excel的時候,導出介面使用了公共列表查詢介面,列表介面查詢數據最多為分頁200一批,而導出數據量每個人的許可權幾萬到十幾萬不等

導出excel

並且該判斷方法使用了嵌套迴圈里判斷,且結合業務很容易 get 不到 value,Java 下的new ArrayList 就是返回一個 List 集合(好像不用說這麼細 (;一_一 ),在整個方法結束之前,產生的 lists生命周期還在所以發生多次gc觸發重啟之後還影響到了別的pod。然後對代碼進行了fix,緊急上線,問題解決~

結束語

遇到生產問題,大家不要害怕,遇到問題先保證服務是否可用,然後通過有限的信息層層解析,找出最終的問題。如果你會 arthas,排查起來會更輕鬆!

近期熱文推薦:

1.1,000+ 道 Java面試題及答案整理(2022最新版)

2.勁爆!Java 協程要來了。。。

3.Spring Boot 2.x 教程,太全了!

4.別再寫滿屏的爆爆爆炸類了,試試裝飾器模式,這才是優雅的方式!!

5.《Java開發手冊(嵩山版)》最新發佈,速速下載!

覺得不錯,別忘了隨手點贊+轉發哦!


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

-Advertisement-
Play Games
更多相關文章
  • 原文在[這裡](https://go.dev/blog/go1.21)。 > 由Eli Bendersky, on behalf of the Go team 發佈於 8 August 2023 Go團隊今天非常高興地發佈了Go 1.21版本,你可以通過訪問[下載頁面](https://go.dev ...
  • ## JSR-303 規範 在程式進行數據處理之前,對數據進行準確性校驗是我們必須要考慮的事情。儘早發現數據錯誤,不僅可以防止錯誤向核心業務邏輯蔓延,而且這種錯誤非常明顯,容易發現解決。 JSR303 規範(Bean Validation 規範)為 JavaBean 驗證定義了相應的元數據模型和 A ...
  • Go最新面經分享:演算法、併發模型、緩存落盤、etcd、actor模型、epoll等等... 本文先分享2段面經,文末總結了關鍵問題的復盤筆記。一定要看到最後! ...
  • ## 1 BUG現象 系統併發請求,系統停滯無法使用,所有介面都是無法與後端進行交互的狀態,系統並沒有宕機 ## 2 BUG的業務流程 1. 插入分數方法 涉及插入表ABCD 加了聲明式事務 2. 查詢分數方法 涉及表ABCD ``` controller() { @Transactional in ...
  • 映射列值是指將一個列中的某些特定值映射為另外一些值,常用於數據清洗和轉換。 使用映射列值的場景有很多,以下是幾種常見的場景: 1. 將字元串類型的列中的某些值映射為數字。例如,將“男”和“女”分別映射為 0 和 1,以便進行機器學習演算法的訓練和預測。 2. 將縮寫替換為全稱。例如,將“USA”和“U ...
  • PeFile模塊是`Python`中一個強大的攜帶型第三方`PE`格式分析工具,用於解析和處理`Windows`可執行文件。該模塊提供了一系列的API介面,使得用戶可以通過`Python`腳本來讀取和分析PE文件的結構,包括文件頭、節表、導入表、導出表、資源表、重定位表等等。此外,PEfile模塊還... ...
  • 源碼請到:自然語言處理練習: 學習自然語言處理時候寫的一些代碼 (gitee.com) 數據來源: 搜狗新聞語料庫 由於鏈接失效,現在使用百度網盤分享 鏈接:https://pan.baidu.com/s/1RTx2k7V3Ujgg9-Rv8I8IRA?pwd=ujn3 提取碼:ujn3 停用詞 來 ...
  • ## 前言 C++可以動態的分類記憶體(但是得主動釋放記憶體,避免記憶體泄漏),而java並不能這樣,java的記憶體分配和垃圾回收統一由JVM管理,是不是java就不能操作記憶體呢?當然有其他辦法可以操作記憶體,接下來有請`Unsafe`出場,我們一起看看`Unsafe`是如何花式操作記憶體的。 ## Unsa ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...