開源Java診斷工具Arthas:開篇之watch實戰

来源:https://www.cnblogs.com/javalover123/archive/2023/08/21/java-arthas-watch-jad.html
-Advertisement-
Play Games

## 一、前言 - 還在為排查Java程式線上問題頭痛嗎,看我們用阿裡開源的診斷神器 Arthas 來幫您 - 本文開篇主要介紹 阿裡開源的診斷神器Arthas 3.7.0版本,watch、jad、classloader 命令,以 Debian 11、openjdk 11 為例 ## 二、Artha ...


一、前言

  • 還在為排查Java程式線上問題頭痛嗎,看我們用阿裡開源的診斷神器 Arthas 來幫您
  • 本文開篇主要介紹 阿裡開源的診斷神器Arthas 3.7.0版本,watch、jad、classloader 命令,以 Debian 11、openjdk 11 為例

二、Arthas 簡介和安裝

1. 簡介

  • Arthas 是一款線上監控診斷產品,通過全局視角實時查看應用 load、記憶體、gc、線程的狀態信息
  • 並能在不修改應用代碼的情況下,對業務問題進行診斷,包括查看方法調用的出入參、異常
  • 監測方法執行耗時,類載入信息等,大大提升線上問題排查效率。

2. 安裝和啟動

  • 執行該程式的用戶需要和目標進程具有相同的許可權,最好和目標進程的用戶一致
  • 啟動以後,輸入 數字 選擇要觀察的進程,也可增加 --select jar名稱 自動選擇進程,提高操作效率
  • 還可以在 末尾增加 進程號(啟動後也不用選擇進程了)
curl -O https://arthas.aliyun.com/arthas-boot.jar && java -jar arthas-boot.jar

三、watch命令

1. 基本用法

  • 觀察指定函數的調用情況,如 入參、返回值、拋出異常,通過編寫 OGNL 表達式查看
  • 命令格式:watch 類全名或類名錶達式 函數名錶達式 {觀察表達式} -x 輸出深度 -n 次數
  • 觀察表達式:預設 {params, target, returnObj},分別是 參數列表、被觀察對象、返回值
  • -x 輸出深度:預設為 1,最大為 4。預設的 觀察表達式中 params + 輸出深度 1,只能輸出 params 是否 empty,size 是 幾,要看到內容就要加大 輸出深度 或 改為 params[0]
  • 很多時候,我們都不關註 被觀察對象 target,指定 觀察表達式 可以降低干擾,尤其是 屬性多 或 輸出深度大的時候
  • 觀察執行頻繁的方法,最好指定 -n 次數,避免刷屏
    arthas-watch.png

2. 只想看滿足條件的

  • 如 測試環境 同時有其他人訪問,只想看到自己的請求
  • 命令格式:watch 類全名或類名錶達式 函數名錶達式 {觀察表達式} '條件' -x 輸出深度 -n 次數
    arthas-watch-condition.png

3. 只想看耗時長的

  • 命令格式:條件 替換為 #cost>毫秒數
    arthas-watch-cost.png

4. 重載方法

  • 重載方法,可通過參數 個數、類型 篩選
  • 命令格式:watch 類全名或類名錶達式 函數名錶達式 {觀察表達式} 'params.length== 參數個數 && params[0] instanceof java.lang.String
    arthas-watch-overload.png

5. 實現類 和 代理類 輸出2次

  • 增加參數,非代理類才輸出: --exclude-class-pattern *Enhance*
  • 不匹配子類:options disable-sub-class true
    arthas-watch-proxy.png

6. 匹配類數量超限(預設50個)

  • 錯誤信息:The number of matched classes is 1501, greater than the limit value 50
  • 增加參數 -m 數量,指定 Class 最大匹配數量,預設值為 50,註意值小於實際類匹配數時報錯,也就是說 只能大於等於 類匹配數
  • 類名錶達式 包含 * 導致匹配類太多的,建議把 類名錶達式 寫的更精確
  • 子類太多:試試用 子類全名 + 方法,或 不匹配子類:options disable-sub-class true,或 提高匹配類數量 -m 2000
    arthas-watch-maxMatch.png

7. 觀察異常

  • 4 個觀察事件點,即 -b 函數調用前,-e 函數異常後,-s 函數返回後,-f 函數結束後(預設)
  • 命令格式:watch 類全名或類名錶達式 函數名錶達式 {throwExp} -e
    arthas-watch-exception.png

8. 觀察函數調用前的入參

  • 這種情況比較少,一般是 入參、出參 是同一個 集合 或 對象,方法中修改了 內容
  • 命令格式:watch 類全名或類名錶達式 函數名錶達式 {觀察表達式} -b,觀察表達式 中 returnObj 是 null 哦,因為還沒執行完返回

四、拓展

1. 懷疑代碼不一致,jad 反編譯 確認一下吧

  • 命令格式:jad 類全名或類名錶達式 函數名錶達式,方法名 是 可選的(代碼行數多的類建議加 方法名,避免刷屏),不傳就反編譯整個類
  • 只顯示源代碼,不顯示 ClassLoader、Location:--source-only
  • 不顯示行號:--lineNumber false
    arthas-jad.png

2. 啥,jad 找不到類

  • 有一次,發版發了幾次都看不到效果,原來是 發錯服務了,囧,誰讓服務名稱首碼是一樣的呢,只能怪自己了
  • 手動要載入也是可以的,classloader | arthas (aliyun.com),需指定 classLoader,如下示例
  • classloader --classLoaderClass org.springframework.boot.loader.LaunchedURLClassLoader --load java.lang.String
    arthas-classloader-load.png

五、總結

  • Arthas 可以幫我們診斷不少線上問題,如 查看方法調用的出入參、異常,監測方法執行耗時,類載入信息等,大大提升線上問題排查效率。
  • FAQ | arthas (aliyun.com)
  • 後記:想當年還用過 阿裡大神開源的 greys,一轉眼用 Arthas 也幾年了,而 Arthas 也是基於 greys 開發的

本文遵守【CC BY-NC】協議,轉載請保留原文出處及本版權聲明,否則將追究法律責任。
本文首先發佈於 https://www.890808.xyz/ ,其他平臺需要審核更新慢一些。

javalover123


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

-Advertisement-
Play Games
更多相關文章
  • ##### 4 屬性選擇器 屬性選擇器是通過元素的屬性及屬性值來選擇元素的。下麵介紹屬性選擇器的用法。 1. 第一種用法 ``` 作用:選擇含有指定屬性的元素。 語法:[屬性名]{} ``` 示例如下: ```html 屬性選擇器 用戶名: 密 碼: 數據量: ``` 運行結果: ![image]( ...
  • ##### 8 JavaScript函數 在JS中聲明函數和python差不多. 也要有一個關鍵字頂在前面. python是`def`, 到了JS里換成了`function`, 只不過在JS中沒有像python那麼死板, 必須`def`後面必須跟上函數名. 這也為我們未來做逆向提供了第一個超大的伏筆 ...
  • 在當今快節奏的社會中,技術變化日新月異。作為一名技術博客站長,我深切感受到了學習和傳播知識的重要性。為了更好地滿足讀者的需求,我決定採用VuePress搭建一個功能強大且易於維護的知識庫平臺,名為LearnData。本文將介紹我如何利用VuePress構建LearnData,並展示一些相關的代碼示例... ...
  • ## 直連 直連模式下,選擇一個玩家充當伺服器(房主)。如果游戲出現不同步,那麼均按房主的世界來,玩家1可以作弊修改其游戲來影響其他玩家的世界 針對兩個玩家來說,直連連接質量更好,延遲小 如果玩家數量很多,不同玩家間的通信則需要靠房主為中介,那通信質量與房主主機配置、網路情況有很大關係 ## 專用服 ...
  • 從研發的角度來看如果系統上下文清晰、應用架構設計簡單、應用拆分合理應該稱之為架構合理。基於以上的定義可以從以下三個方面來梳理評估: ...
  • ### 歡迎訪問我的GitHub > 這裡分類和彙總了欣宸的全部原創(含配套源碼):[https://github.com/zq2599/blog_demos](https://github.com/zq2599/blog_demos) ### 本篇概覽 - 前文[《Docker下elasticse ...
  • ## 面向對象三要素 封裝:顧名思義,將函數或變數集中定義在類中,而非散亂分佈。 繼承:擴展類的功能。 多態:在擴展類的功能的基礎之上,實現其內部方法的多樣性。 ### 多態的本質 針對某個類型的方法調用,其真正執行的方法取決於運行時期實際類型的方法。 ```java package Project ...
  • 之前用的python2.7+robotframework進行的自動化測試,python3的還沒嘗試,今天嘗試了下,搭建環境的時候也是各種報錯,搞了幾小時才搞好了。 一、python安裝 下載python然後安裝,地址:https://www.python.org/,安裝時勾選添加到環境變數,安裝後c ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...