一款不可錯過的Java應(yīng)用診斷利器Arthas
一、Arthas的介紹
Arthas是一款基于Java的命令行工具,可以在運行時對Java應(yīng)用進行調(diào)試和診斷,其主要功能包括:實時查看JVM狀態(tài)、方法調(diào)用鏈路追蹤、監(jiān)控系統(tǒng)資源消耗、動態(tài)修改代碼等。
同時Arthas也是阿里巴巴開源的Java診斷工具,集成了較多的功能,包括進程狀態(tài)查看、Java類、方法的查找和監(jiān)控、異常信息分析、線程狀態(tài)監(jiān)控、JVM統(tǒng)計信息查看等。相比其他Java診斷工具,Arthas有以下幾個優(yōu)點:
- 操作簡單:只需要在目標機上執(zhí)行一個腳本即可。
- 功能強大:支持從線上診斷到本地診斷場景,并且能夠解決大部分日常開發(fā)遇到的問題。
- 方便快捷:可以動態(tài)修改代碼,方便調(diào)試。
- 支持多種使用方式:命令行使用方式、WebUI使用方式、telnet響應(yīng)式命令行交互使用方式。
- 針對Java應(yīng)用的特征進行優(yōu)化,包括注重性能、穩(wěn)定性、安全性。
- 多年在線大規(guī)模使用證明了Arthas的高性能、低影響性和實用性。
Arthas的安裝非常簡單,只需要通過Maven將其依賴添加到項目中即可:
<dependency> <groupId>com.alibaba</groupId> <artifactId>arthas-client</artifactId> <version>3.5.4</version> </dependency>
二、Arthas的使用
1. 進入Arthas Shell
在使用Arthas之前,我們需要先進入Arthas Shell??梢酝ㄟ^以下命令進入:
./as.sh
出現(xiàn)如下界面即表示成功進入Arthas Shell:
$ as.sh / \ _ _ _ __ (_) ___| |__ ___ _ __ ___ / _ \| | | | '_ \| |/ __| '_ \ / _ \ '__/ __| / ___ \ |_| | | | | | (__| | | | __/ | \__ \ \/ \/\__,_|_| |_|_|\___|_| |_|\___|_| |___/ Welcome to Arthas, enjoy it. More info please visit: https://alibaba.github.io/arthas $ _
2. 查看JVM狀態(tài)
在Arthas Shell中,我們可以通過以下命令查看當前JVM的狀態(tài):
$ jvm
執(zhí)行以上命令后,會輸出類似于以下的信息:
[INFO] [arthas-jvm] [0.140s] [pid:5102] [user:binjie] [hostname:localhost.localdomain] [cwd:/home/binjie] [command:/usr/lib/jvm/java-8-oracle/bin/java -jar /home/binjie/demo/target/demo-1.0-SNAPSHOT.jar] [args:] [state:RUNNING] [os:Linux 4.18.0-147.5.1.el8_1.x86_64 amd64] [Java home:/usr/lib/jvm/java-8-oracle]
其中,我們可以看到當前JVM的進程ID、用戶、主機等信息。
3. 方法調(diào)用鏈路追蹤
有時我們需要查看某個方法被調(diào)用了多少次、被哪些方法調(diào)用了,甚至是每一次調(diào)用的參數(shù)和返回值。這時可以使用Arthas的trace命令。以下是一些常用的示例:
(1)追蹤某個方法的所有調(diào)用
$ trace com.example.demo.service.UserService getUserById
這條命令將會追蹤com.example.demo.service.UserService
類中的getUserById
方法的所有調(diào)用。
(2)追蹤某個類中所有方法的調(diào)用
$ trace com.example.demo.service.UserService
這條命令將會追蹤com.example.demo.service.UserService
類中的所有方法調(diào)用。
(3)追蹤某個方法的詳細信息
$ trace com.example.demo.service.UserService getUserById -n 5
這條命令將會追蹤com.example.demo.service.UserService
類中的getUserById
方法的前5次調(diào)用,并打印出每次調(diào)用的參數(shù)和返回值。
4. 監(jiān)控系統(tǒng)資源消耗
在Arthas Shell中,我們可以通過以下命令監(jiān)控系統(tǒng)資源的消耗情況:
(1)監(jiān)控CPU占用率
$ dashboard
執(zhí)行以上命令后,會輸出一個監(jiān)控面板,其中包含了CPU占用率、Java線程數(shù)、內(nèi)存使用情況等信息。
(2)監(jiān)控線程
$ thread
執(zhí)行以上命令后,會輸出當前JVM中所有線程的信息。
(3)監(jiān)控GC
$ gc
執(zhí)行以上命令后,會輸出GC的相關(guān)信息。
5. 動態(tài)修改代碼
Arthas還支持在運行時動態(tài)修改代碼,以下是一些常用的示例:
(1)修改某個類的某個方法的返回值
$ redefine com.example.demo.service.UserService getUserById "return \"Hello Arthas!\";"
這條命令將會修改com.example.demo.service.UserService
類中的getUserById
方法的返回值為"Hello Arthas!"
。
(2)添加某個類的某個方法
$ redefine -c com.example.demo.service.UserService -m addUser --params-string "java.lang.String name, java.lang.Integer age" "logger.info(\"addUser invoked! name:{} age:{}\", name, age); return true;"
這條命令將會在com.example.demo.service.UserService
類中添加一個名為addUser
的方法,并且該方法的參數(shù)為String name
和Integer age
,最后將會輸出日志并返回true
。
6. 其他常用命令
除了以上的命令之外,Arthas還有許多其他的實用命令,以下列舉一些常用的:
(1)查看方法調(diào)用次數(shù)
$ sc -d 3 com.example.demo.service.UserService getUserById
這條命令將會查看com.example.demo.service.UserService
類中的getUserById
方法在最近的3秒鐘內(nèi)被調(diào)用的次數(shù)。
(2)查看線程堆棧
$ thread -i [線程ID]
這條命令將會輸出指定ID的線程的堆棧信息。
(3)查看類的加載情況
$ classloader -c com.example.demo.service.UserService
這條命令將會查看com.example.demo.service.UserService
類的加載情況。
三、 連接應(yīng)用
使用 Arthas 前需要先連接到相應(yīng)的 Java 應(yīng)用程序,Arthas 支持兩種連接方式:默認連接和 Telnet 連接。
1. 默認連接
默認連接是指 Arthas 自動連接當前機器上正在運行的 Java 應(yīng)用程序??梢酝ㄟ^以下命令啟動默認連接:
$ java -jar arthas-boot.jar
啟動后會自動連接當前機器上正在運行的 Java 應(yīng)用程序。
$ java -jar arthas-boot.jar --target-ip 127.0.0.1 --telnet-port 3658
啟動后會嘗試連接指定的 IP 地址和端口號上的 Java 應(yīng)用程序。
2. Telnet 連接
Telnet 連接是指通過 Telnet 協(xié)議連接到 Java 應(yīng)用程序??梢酝ㄟ^以下命令啟動 Telnet 連接:
$ telnet 127.0.0.1 3658
連接成功后可以輸入 help 命令查看 Arthas 的幫助信息。
四、小結(jié)一下
Arthas就像是Java應(yīng)用程序的救世主,它會讓你在調(diào)試過程中不再感到“糾結(jié)”和“郁悶”,而是變成“順風(fēng)順水”和“樂在其中”。使用Arthas,你可以輕松地查看JVM信息、調(diào)用鏈追蹤、方法監(jiān)控等等,就像使用神奇的魔棒一樣。使得你在調(diào)試過程中可以開開心心地喝著茶、說著笑話,并且在芝士多多的群里大顯身手,展現(xiàn)你的技術(shù)實力和幽默感。Arthas就是你成功找到Bug的必備良藥,讓我們一起來擁抱這個優(yōu)秀的工具吧!
以上就是一款不可錯過的Java應(yīng)用診斷利器Arthas的詳細內(nèi)容,更多關(guān)于Java應(yīng)用診斷利器Arthas的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
javaweb 國際化:DateFormat,NumberFormat,MessageFormat,ResourceBu
本文主要介紹javaWEB國際化的知識,這里整理了詳細的資料及實現(xiàn)代碼,有興趣的小伙伴可以參考下2016-09-09java 字符串內(nèi)存分配的分析與總結(jié)(推薦)
下面小編就為大家?guī)硪黄猨ava 字符串內(nèi)存分配的分析與總結(jié)(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08SpringBoot實現(xiàn)MD5加鹽算法的示例代碼
加鹽算法是一種用于增強密碼安全性的技術(shù),本文主要介紹了SpringBoot實現(xiàn)MD5加鹽算法的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2025-03-03