亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

自帶IDEA插件的阿里開源診斷神器Arthas線上項目BUG調(diào)試

 更新時間:2022年06月20日 16:15:52   作者:MacroZheng  
這篇文章主要為大家介紹了自帶IDEA插件阿里開源診斷神器Arthas線上項目BUG調(diào)試,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

前言

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

SpringBoot實戰(zhàn)電商項目mall(50k+star)地址:https://github.com/macrozheng/mall

Arthas簡介

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

ArthasTunnel

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

首先我們需要下載ArthasTunnel的安裝包,下載地址:

https://github.com/alibaba/arthas/releases

由于官方只提供了JAR包,如果你想通過Docker方式啟動的話,可以自行打包Docker鏡像,打包使用的Dockerfile腳本如下:

# 該鏡像需要依賴的基礎(chǔ)鏡像
FROM java:8
# 將當前目錄下的jar包復(fù)制到docker容器的/目錄下
ADD arthas-tunnel-server.jar /arthas-tunnel-server.jar
# 聲明服務(wù)運行的端口
EXPOSE 8080 7777
# 指定docker容器啟動時運行jar包
ENTRYPOINT ["java", "-jar","/arthas-tunnel-server.jar"]
# 指定維護者的名字
MAINTAINER macro

這里再提供一個一鍵打包運行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----'

接下來吧ArthasTunnel的JAR包、Dockerfile文件、執(zhí)行腳本run.sh上傳到Linux服務(wù)器上,然后使用./run.sh命令運行即可;

運行成功后,可以直接訪問ArthasTunnel的Web控制臺,訪問地址:http://192.168.3.105:8080

SpringBoot集成

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

首先在項目的pom.xml中添加如下依賴,可以對比下Arthas使用教程 中的使用方法,直接集成確實簡單不少;

<!--集成Java診斷利器Arthas-->
<dependency>
    <groupId>com.taobao.arthas</groupId>
    <artifactId>arthas-spring-boot-starter</artifactId>
    <version>3.6.1</version>
</dependency>

然后修改配置文件application.yml,記住這個agent-id,ArthasTunnel連接需要使用,由于我們將會把應(yīng)用容器通過--link的方式連接到ArthasTunnel容器,這里的tunnel-server按下面進行配置;

management:
  endpoints:
    web:
      exposure:
        # 暴露端點`/actuator/arthas`
        include: 'arthas'
arthas:
  agent-id: mall-tiny-arthas
  tunnel-server: ws://arthas-tunnel-server:7777/ws

接下來通過之前的Dockerfile和run.sh打包應(yīng)用,run.sh與之前對比,只多了一行通過--link連接到ArthasTunnel容器的命令;

打包使用的Dockerfile和運行腳本run.sh都已經(jīng)包含在示例代碼中了,結(jié)構(gòu)如下;

接下來在ArthasTunnel的Web控制臺中輸入AgentIdmall-tiny-arthas,并點擊Connect按鈕即可開始診斷Java應(yīng)用了;

比如通過dashboard命令來顯示當前系統(tǒng)的實時數(shù)據(jù)面板,包括線程信息、JVM內(nèi)存信息及JVM運行時參數(shù);

再比如說使用thread命令查看當前線程信息,查看線程的堆棧,可以找出當前最占CPU的線程;

當然Arthas的功能非常強大,遠不止這些,支持動態(tài)修改日志和熱更新等,具體可以參考Arthas使用教程 。

IDEA插件

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

直接在IDEA的插件市場搜索arthas即可找到該插件,然后點擊安裝即可;

安裝完成后我們來聊聊如何使用,比如當我們覺得線上代碼和預(yù)期不一致,可以使用jad命令反編譯下看看,直接選擇類,右鍵選擇Arthas命令然后選擇Jad反編譯;

此時將會直接把命令拷貝到剪切板,然后到ArthasTunnel右鍵粘貼即可使用,比手打命令簡單多了吧!

如果你想觀察方法執(zhí)行過程中的參數(shù)和返回值,可以使用watch命令,選擇需要觀察的方法右鍵選擇即可;

這里觀察下Controller中的方法的執(zhí)行過程;

我們還可單獨修改某個類的日志級別,選中類名后右鍵選擇logger命令;

先拷貝下logger sc命令查看下當前類的日志級別為INFO

拷貝下ClassLoader的Hash值,這里由于在Linux中Ctrl+C鍵有沖突,使用Ctrl+Insert組合來拷貝;

接下來輸入ClassLoader的Hash值,修改下日志級別,然后拷貝修改日志級別的命令;

執(zhí)行完后再查看下日志級別,已經(jīng)被改為了DEBUG級別

總結(jié)

今天體驗了一把新版的Arthas,搭配ArthasTunnel和IDEA插件使用,確實非常方便!并且它還能和SpringBoot無縫集成,確實非常給力,更多Arthas的使用可以參考Arthas使用教程 。

參考資料

項目官網(wǎng):https://github.com/alibaba/arthas

官方文檔:https://arthas.aliyun.com/doc/index.html

DEA插件使用文檔:https://www.yuque.com/arthas-idea-plugin

項目源碼地址

https://github.com/macrozheng/mall-learning/tree/master/mall-tiny-arthas2

更多關(guān)于Arthas線上項目BUG調(diào)試的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 老生常談設(shè)計模式之動態(tài)代理

    老生常談設(shè)計模式之動態(tài)代理

    下面小編就為大家?guī)硪黄仙U勗O(shè)計模式之動態(tài)代理。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • springboot+vue實現(xiàn)登錄功能

    springboot+vue實現(xiàn)登錄功能

    這篇文章主要為大家詳細介紹了springboot+vue實現(xiàn)登錄功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • MyBatis?如何使項目兼容多種數(shù)據(jù)庫的解決方案

    MyBatis?如何使項目兼容多種數(shù)據(jù)庫的解決方案

    要想做兼容多種數(shù)據(jù)庫,那毫無疑問,我們首先得明確我們要兼容哪些數(shù)據(jù)庫,他們的數(shù)據(jù)庫產(chǎn)品名稱是什么,本次我們講解了一套使項目兼容多種數(shù)據(jù)庫的方案,對MyBatis項目兼容多種數(shù)據(jù)庫操作方法感興趣的朋友一起看看吧
    2024-05-05
  • IDEA下創(chuàng)建SpringBoot+MyBatis+MySql項目實現(xiàn)動態(tài)登錄與注冊功能

    IDEA下創(chuàng)建SpringBoot+MyBatis+MySql項目實現(xiàn)動態(tài)登錄與注冊功能

    這篇文章主要介紹了IDEA下創(chuàng)建SpringBoot+MyBatis+MySql項目實現(xiàn)動態(tài)登錄與注冊功能,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Java中如何模擬HTTP請求并驗證功能

    Java中如何模擬HTTP請求并驗證功能

    要模擬HTTP請求并驗證功能,你可以使用Spring Boot提供的MockMvc工具,它允許我們在沒有實際啟動HTTP服務(wù)器的情況下測試Spring MVC控制器,下面給大家分享如何模擬HTTP請求并驗證功能,感興趣的朋友一起看看吧
    2024-05-05
  • Spark JDBC操作MySQL方式詳細講解

    Spark JDBC操作MySQL方式詳細講解

    這篇文章主要介紹了Spark JDBC操作MySQL方式,Spark SQL可以通過JDBC從傳統(tǒng)的關(guān)系型數(shù)據(jù)庫中讀寫數(shù)據(jù),讀取數(shù)據(jù)后直接生成的是DataFrame,然后再加上借助于Spark SQL豐富的API來進行各種操作
    2023-02-02
  • Java?如何通過注解實現(xiàn)接口輸出時數(shù)據(jù)脫敏

    Java?如何通過注解實現(xiàn)接口輸出時數(shù)據(jù)脫敏

    這篇文章主要介紹了Java?如何通過注解實現(xiàn)接口輸出時數(shù)據(jù)脫敏,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Maven中exec插件執(zhí)行Java程序的實現(xiàn)

    Maven中exec插件執(zhí)行Java程序的實現(xiàn)

    在Maven項目中,可以使用Maven的插件來執(zhí)行Java程序,本文主要介紹了Maven中exec插件執(zhí)行Java程序的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • Mybatis如何動態(tài)創(chuàng)建表

    Mybatis如何動態(tài)創(chuàng)建表

    這篇文章主要介紹了Mybatis如何動態(tài)創(chuàng)建表問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Javafx簡單實現(xiàn)【我的電腦資源管理器】效果

    Javafx簡單實現(xiàn)【我的電腦資源管理器】效果

    這篇文章主要介紹了Javafx簡單實現(xiàn)【我的電腦資源管理器】效果,涉及Javafx操作系統(tǒng)文件模擬資源管理器的實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-09-09

最新評論