線上項(xiàng)目出BUG沒法調(diào)試?這款阿里開源的診斷神器,自帶IDEA插件真香!

記得之前寫過(guò)一篇Arthas使用教程,通過(guò)使用Arthas我們既可以實(shí)現(xiàn)線上調(diào)試,還可以實(shí)現(xiàn)熱修復(fù)。最近逛了下Arthas的官網(wǎng),發(fā)現(xiàn)它已經(jīng)支持直接集成到SpringBoot應(yīng)用中去,并且還出了專用的IDEA插件。今天我們?cè)賮?lái)體驗(yàn)下它,看看它的功能是不是更強(qiáng)大了!

Arthas簡(jiǎn)介

Arthas是Alibaba開源的Java診斷利器,深受開發(fā)者喜愛,目前在Github上已有29K+Star。它采用命令行交互模式,同時(shí)提供豐富的 Tab 自動(dòng)補(bǔ)全功能,進(jìn)一步方便進(jìn)行問題的定位和診斷。
image.png

ArthasTunnel

為了演示一個(gè)更加真實(shí)的線上環(huán)境,接下來(lái)我們將對(duì)Docker容器中的SpringBoot應(yīng)用進(jìn)行診斷。我們將使用ArthasTunnel來(lái)實(shí)現(xiàn),ArthasTunnel相當(dāng)于一個(gè)Web控制臺(tái),使用它我們無(wú)需進(jìn)入應(yīng)用容器即可對(duì)應(yīng)用進(jìn)行診斷,非常方便。

首先我們需要下載ArthasTunnel的安裝包:https://github.com/alibaba/arthas/releases

  • 由于官方只提供了JAR包,如果你想通過(guò)Docker方式啟動(dòng)的話,可以自行打包Docker鏡像,打包使用的Dockerfile腳本如下:
# 該鏡像需要依賴的基礎(chǔ)鏡像
FROM java:8
# 將當(dāng)前目錄下的jar包復(fù)制到docker容器的/目錄下
ADD arthas-tunnel-server.jar /arthas-tunnel-server.jar
# 聲明服務(wù)運(yùn)行的端口
EXPOSE 8080 7777
# 指定docker容器啟動(dòng)時(shí)運(yùn)行jar包
ENTRYPOINT ["java", "-jar","/arthas-tunnel-server.jar"]
# 指定維護(hù)者的名字
MAINTAINER macro
  • 這里再提供一個(gè)一鍵打包運(yùn)行ArthasTunnel容器的執(zhí)行腳本run.sh,腳本內(nèi)容如下;
#!/usr/bin/env bash
# 定義應(yīng)用組名
group_name='mall-tiny'
# 定義應(yīng)用名稱
app_name='arthas-tunnel-server'
# 定義應(yīng)用版本
app_version='1.0-SNAPSHOT'
echo '----copy jar----'
docker stop ${app_name}
echo '----stop container----'
docker rm ${app_name}
echo '----rm container----'
docker rmi ${group_name}/${app_name}:${app_version}
echo '----rm image----'
# 打包編譯docker鏡像
docker build -t ${group_name}/${app_name}:${app_version} .
echo '----build image----'
docker run -p 8080:8080 -p 7777:7777 --name ${app_name} \
-e TZ="Asia/Shanghai" \
-v /etc/localtime:/etc/localtime \
-v /mydata/app/${app_name}/logs:/var/logs \
-d ${group_name}/${app_name}:${app_version}
echo '----start container----'
  • 接下來(lái)吧ArthasTunnel的JAR包、Dockerfile文件、執(zhí)行腳本run.sh上傳到Linux服務(wù)器上,然后使用./run.sh命令運(yùn)行即可;
    image.png
  • 運(yùn)行成功后,可以直接訪問ArthasTunnel的Web控制臺(tái),訪問地址:http://192.168.3.105:8080
    image.png

SpringBoot集成

在SpringBoot應(yīng)用中直接集成Arthas并使用,無(wú)疑是最方便的,接下來(lái)我們將采用此種方法。

  • 首先在項(xiàng)目的pom.xml中添加如下依賴,可以對(duì)比下Arthas使用教程 中的使用方法,直接集成確實(shí)簡(jiǎn)單不少;
<!--集成Java診斷利器Arthas-->
<dependency>
    <groupId>com.taobao.arthas</groupId>
    <artifactId>arthas-spring-boot-starter</artifactId>
    <version>3.6.1</version>
</dependency>
  • 然后修改配置文件application.yml,記住這個(gè)agent-id,ArthasTunnel連接需要使用,由于我們將會(huì)把應(yīng)用容器通過(guò)--link的方式連接到ArthasTunnel容器,這里的tunnel-server按下面進(jìn)行配置;
management:
  endpoints:
    web:
      exposure:
        # 暴露端點(diǎn)`/actuator/arthas`
        include: 'arthas'
arthas:
  agent-id: mall-tiny-arthas
  tunnel-server: ws://arthas-tunnel-server:7777/ws
  • 接下來(lái)通過(guò)之前的Dockerfile和run.sh打包應(yīng)用,run.sh與之前對(duì)比,只多了一行通過(guò)--link連接到ArthasTunnel容器的命令;
    image.png
  • 打包使用的Dockerfile和運(yùn)行腳本run.sh都已經(jīng)包含在示例代碼中了,結(jié)構(gòu)如下;
    image.png
  • 接下來(lái)在ArthasTunnel的Web控制臺(tái)中輸入AgentId為mall-tiny-arthas,并點(diǎn)擊Connect按鈕即可開始診斷Java應(yīng)用了;
    image.png
  • 比如通過(guò)dashboard命令來(lái)顯示當(dāng)前系統(tǒng)的實(shí)時(shí)數(shù)據(jù)面板,包括線程信息、JVM內(nèi)存信息及JVM運(yùn)行時(shí)參數(shù);
    image.png
  • 再比如說(shuō)使用thread命令查看當(dāng)前線程信息,查看線程的堆棧,可以找出當(dāng)前最占CPU的線程;
    image.png
  • 當(dāng)然Arthas的功能非常強(qiáng)大,遠(yuǎn)不止這些,支持動(dòng)態(tài)修改日志和熱更新等

IDEA插件

由于Arthas的功能很強(qiáng)大,需要記住的命令很多,有時(shí)候?qū)嵲谟洸蛔?,于是有了這款I(lǐng)DEA插件,該插件主要用于幫助生成Arthas命令。

  • 直接在IDEA的插件市場(chǎng)搜索arthas即可找到該插件,然后點(diǎn)擊安裝即可;

    image.png

  • 安裝完成后我們來(lái)聊聊如何使用,比如當(dāng)我們覺得線上代碼和預(yù)期不一致,可以使用jad命令反編譯下看看,直接選擇類,右鍵選擇Arthas命令然后選擇Jad反編譯;
    image.png
  • 此時(shí)將會(huì)直接把命令拷貝到剪切板,然后到ArthasTunnel右鍵粘貼即可使用,比手打命令簡(jiǎn)單多了吧!
    image.png
  • 如果你想觀察方法執(zhí)行過(guò)程中的參數(shù)和返回值,可以使用watch命令,選擇需要觀察的方法右鍵選擇即可;
    image.png
  • 這里觀察下Controller中的方法的執(zhí)行過(guò)程;
    image.png
  • 我們還可單獨(dú)修改某個(gè)類的日志級(jí)別,選中類名后右鍵選擇logger命令;
    image.png
  • 先拷貝下logger sc命令查看下當(dāng)前類的日志級(jí)別為INFO;
    image.png
  • 拷貝下ClassLoader的Hash值,這里由于在Linux中Ctrl+C鍵有沖突,使用Ctrl+Insert組合來(lái)拷貝;
    image.png
  • 接下來(lái)輸入ClassLoader的Hash值,修改下日志級(jí)別,然后拷貝修改日志級(jí)別的命令;
    image.png
  • 執(zhí)行完后再查看下日志級(jí)別,已經(jīng)被改為了DEBUG級(jí)別
    image.png

總結(jié)

今天體驗(yàn)了一把新版的Arthas,搭配ArthasTunnel和IDEA插件使用,確實(shí)非常方便!并且它還能和SpringBoot無(wú)縫集成,確實(shí)非常給力

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容