一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Arthas可以解決哪些問題

電子設(shè)計(jì) ? 來源:電子設(shè)計(jì) ? 作者:電子設(shè)計(jì) ? 2020-12-24 14:22 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

轉(zhuǎn)載本文需注明出處:微信公眾號EAWorld,違者必究。

什么是Arthas

Java 診斷利器 Arthas,是阿里的一款開源工具。Github-alibaba/arthas 上可以看到它的介紹。

在日常開發(fā)中,當(dāng)我們發(fā)現(xiàn)應(yīng)用的某個(gè)接口響應(yīng)比較慢,這個(gè)時(shí)候想想要分析一下原因,找到代碼中耗時(shí)的部分,比較容易想到的是在接口鏈路的 IO 操作上下游打印時(shí)間日志,再根據(jù)幾個(gè)時(shí)間點(diǎn)的日志算出耗時(shí)長的 IO 操作。這種方式?jīng)]有問題,但是加日志需要發(fā)布,既繁瑣又低效,這個(gè)時(shí)候可以引入一些線上 debug 的工具,arthas 就是很好的一種,除了分析耗時(shí),還可以打印調(diào)用棧、方法入?yún)⒓胺祷兀惣虞d情況,線程池狀態(tài),系統(tǒng)參數(shù)等等,其實(shí)現(xiàn)原理是解析 JVM 在操作系統(tǒng)中的文件,大部分操作是只讀的,對服務(wù)進(jìn)程沒有侵入性,因此可以放心使用。

Arthas能解決什么問題?

從我個(gè)人的使用經(jīng)驗(yàn)來看,Arthas至少幫我解決了以下幾個(gè)問題:

監(jiān)控某方法查看其整個(gè)調(diào)用鏈路,從而找出某次調(diào)用的性能瓶頸。

反編譯某個(gè)類,查看線上的代碼是否與本地代碼一致,避免沒有提交代碼而導(dǎo)致的問題。

站在全局視角查看整個(gè)系統(tǒng)的運(yùn)行情況,比如觀察內(nèi)存增長、GC的情況。

在微服務(wù)架構(gòu)背景下,通常本地沒有完整的環(huán)境,此時(shí)可以直接在測試環(huán)境監(jiān)控某個(gè)方法傳入的參數(shù)是否正確,返回值是否正確。

快速開始

下載并啟動(dòng)arthas

輸入以下命令啟動(dòng)arthas程序

curl -O https://arthas.a(chǎn)liyun.com/arthas-demo.jarjava -jar arthas-demo.jar

選擇需要監(jiān)控應(yīng)用的進(jìn)程編號,回車后Arthas會attach到目標(biāo)進(jìn)程上,并輸出日志:

容器中使用

docker exec -it arthas-demo /bin/sh -c "java -jar /opt/arthas/arthas-boot.jar"

甚至我們可以直接把a(bǔ)rthas放到容器鏡像文件中:

COPY --from=hengyunabc/arthas:latest /opt/arthas /opt/arthas

Arthas常用命令

下面簡要為大家介紹一下Arthas常用的幾個(gè)命令。

dashboard

使用dashboard命令會顯示以下信息:

1. 當(dāng)前最繁忙的一些線程

2. 顯示應(yīng)用當(dāng)前使用的內(nèi)存信息,包括堆內(nèi)存、新生代伊甸區(qū)、老年代、非堆內(nèi)存的使用情況。

3. 顯示程序的GC情況,包括YGC次數(shù)、總花費(fèi)時(shí)間,F(xiàn)GC的次數(shù)、總花費(fèi)時(shí)間。

4. 當(dāng)前程序的一些信息,包括系統(tǒng)版本、JDK版本、程序運(yùn)行時(shí)長等。

Thread

查看當(dāng)前線程信息,查看線程的堆棧

// 查看 CPU 使用率 top n 的線程的棧,當(dāng)前最忙的前 n 個(gè)線程:thread -n 3// 查看 5 秒內(nèi)的 CPU 使用率 top n 的線程棧:thread -n 3 -i 5000

// 查看線程是否有阻塞:thread -b

watch

有時(shí)候我們不太方便進(jìn)行本地調(diào)試,這個(gè)時(shí)候可以使用watch監(jiān)控某個(gè)方法,然后點(diǎn)擊相關(guān)的功能,查看該方法的調(diào)用情況:

watch com.primeton.dgp.a(chǎn)ssets.controller.DsResourcePoolController getResourcePool "{params,returnObj}" -x 2

執(zhí)行以上命令后,控制臺會hold在被監(jiān)控的方法上,此時(shí)再次點(diǎn)擊頁面上的按鈕,控制臺就會打印此次的調(diào)用結(jié)果。

trace

trace 命令能主動(dòng)搜索 class-pattern/method-pattern 對應(yīng)的方法調(diào)用路徑,渲染和統(tǒng)計(jì)整個(gè)調(diào)用鏈路上的所有性能開銷和追蹤調(diào)用鏈路。通常我們用這個(gè)方法可以看到整個(gè)調(diào)用路徑的耗時(shí),從而找出真正的性能瓶頸,幫助解決問題。

trace com.primeton.dgp.a(chǎn)ssets.controller.DsResourcePoolController getResourcePool

tt

tt方法執(zhí)行數(shù)據(jù)的時(shí)空隧道,記錄下指定方法每次調(diào)用的入?yún)⒑头祷匦畔?,并能對這些不同的時(shí)間下調(diào)用進(jìn)行觀測,使用方法如下:

tt -t com.primeton.dgp.a(chǎn)ssets.controller.DsResourcePoolController getResourcePool

執(zhí)行此命令后,arthas會記錄下指定方法的每次調(diào)用環(huán)境現(xiàn)場,并打印一些相關(guān)的信息,如調(diào)用時(shí)長、是否正常返回、是否拋出異常等。

顯示所有被記錄的調(diào)用列表

tt -l

重做一次調(diào)用。tt 命令由于保存了當(dāng)時(shí)調(diào)用的所有現(xiàn)場信息,所以我們可以自己主動(dòng)對一個(gè) INDEX 編號的時(shí)間片自主發(fā)起一次調(diào)用,從而解放你的溝通成本。此時(shí)你需要 -p 參數(shù)。通過 --replay-times 指定 調(diào)用次數(shù),通過 --replay-interval 指定多次調(diào)用間隔(單位ms, 默認(rèn)1000ms)

tt -i 1001 -p --replay-times 3 --replay-interval 3000

jad

jad 命令將 JVM 中實(shí)際運(yùn)行的 class 的 byte code 反編譯成 java 代碼,便于你理解業(yè)務(wù)邏輯;反編譯出來的源碼是帶語法高亮的,閱讀更方便。當(dāng)我們看到某個(gè)方法的調(diào)用時(shí)長明顯過長,或者時(shí)空隧道中某方法拋出異常,這個(gè)時(shí)候就可以直接反編譯相關(guān)的方法,看看是否能找出原因。

其他

除了以上很常用的命令以外,arthas還有很多實(shí)用命令,大家可以參考官方文檔來使用

另外,每一個(gè)命令都支持-h(huán)elp參數(shù),可以查看該命令的說明、參數(shù),甚至包括了使用例子,可以說是非常貼心了

案例

案例1

我們準(zhǔn)備了一個(gè)簡單的springboot應(yīng)用,應(yīng)用內(nèi)有一個(gè)Controller,返回一個(gè)字符串,代碼如下:

@RestControllerpublic class DemoController {

@GetMapping(value = "/getDemo")public String getDemo(){return "demo 1"; }}

啟動(dòng)程序,訪問剛剛準(zhǔn)備好的controller得到了下面的結(jié)果

接下來我們要嘗試在沒有源碼的情況下修改demo controller的返回值,并在不重啟應(yīng)用的情況下,使我們修改的返回值生效。

首先啟動(dòng)arthas并織入到剛才的demo,然后反編譯DemoController到臨時(shí)文件夾。

jad --source-only com.example.a(chǎn)rthas.DemoController > /tmp/DemoController.java

接下來我們用vim修改反編譯出來的代碼

查詢加載原有DemoController類的ClassLoader

sc -d com.example.a(chǎn)rthas.DemoController

重新編譯修改后的類

mc -c 685f4c2e /tmp/DemoController.java

重新加載修改后的類

redefine -c 685f4c2e /opt/arthas/demo/com/example/arthas/DemoController.class

此時(shí),無需重啟應(yīng)用,我們重新訪問剛才的controller,會發(fā)現(xiàn)返回結(jié)果已經(jīng)成功更改了。

案例2

某燃?xì)庀到y(tǒng)由于被眾多地區(qū)的燃?xì)夤舅褂?,所以版本繁多,?jīng)歷過很多輪的測試,其中比較耗時(shí)的當(dāng)屬性能測試了。以往性能測試工作通常耗時(shí)很長,主要是性能測試人員并不一定熟悉項(xiàng)目代碼,導(dǎo)致壓力測試出現(xiàn)問題的時(shí)候不容易找到問題的所在。

在本次的表具接口的性能測試中,我們使用Arthas工具進(jìn)行故障的快速定位,大幅減少了性能測試的時(shí)間,達(dá)到了很好的效果。

本次壓力測試的過程中我們發(fā)現(xiàn),當(dāng)并發(fā)達(dá)到一定數(shù)量的時(shí)候系統(tǒng)會卡死,大量新的請求會超時(shí)。使用dashboard查看發(fā)現(xiàn)系統(tǒng)的大量線程處于block或者wating中。

使用trace命令,將壓力測試的方法進(jìn)行監(jiān)控,并保存到日志文件中,接著重新跑一輪壓力測試。

trace -n 150000 com.towngas.tcis.interfaces.nb.NbInfoServlet getService >> tt-2020-10-17-NbServlet-getService

監(jiān)控日志,當(dāng)用戶數(shù)達(dá)到500+的時(shí)候果然發(fā)現(xiàn)了問題

繼續(xù)使用trace命令跟蹤,發(fā)現(xiàn)了可能出現(xiàn)問題的方法

使用jad命令反編譯該代碼可以看到HttpClient并沒有被立即關(guān)閉,使用release的釋放后關(guān)閉通常沒有問題,但是釋放資源有一個(gè)過程通常是180秒,所以如果短時(shí)間有大量接口調(diào)用,會導(dǎo)致打開的socket連接數(shù)量超過系統(tǒng)設(shè)定值。找到原因后問題得以順利解決,壓力測試得以順利完成。

小結(jié)

本次的分享為大家介紹了Arthas的基本概念與基礎(chǔ)的使用方法。更為詳細(xì)的使用方法、命令的更多參數(shù),還請查看Arthas的官方文檔。

關(guān)于作者:李云濤,普元高級開發(fā)工程師,擅長性能調(diào)優(yōu)、微服務(wù)、容器、消息隊(duì)列等技術(shù)。先后參與郵儲銀行Java開發(fā)平臺、中移總ERP流程平臺、中煤信息技術(shù)中臺等平臺的的架構(gòu)設(shè)計(jì)與平臺研發(fā)工作。

審核編輯:符乾江
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4895

    瀏覽量

    70500
  • 編譯
    +關(guān)注

    關(guān)注

    0

    文章

    676

    瀏覽量

    33890
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    智能IC卡可以做什么工藝呢?

    1、IC卡可以根據(jù)客戶提供的素材進(jìn)行版面設(shè)計(jì),也可由客戶提供設(shè)計(jì)稿2、IC卡的厚度從0.5mm到2mm,一般國際標(biāo)準(zhǔn)厚度0.84MM3、IC卡的標(biāo)準(zhǔn)大小是85.5mmX54mm,圓角104、IC卡
    的頭像 發(fā)表于 04-01 14:51 ?231次閱讀
    智能IC卡<b class='flag-5'>可以</b>做什么工藝呢?

    GitHub Copilot 可以免費(fèi)使用了!

    “ ?這個(gè)標(biāo)題有點(diǎn)標(biāo)題黨,雖然 Github Copilot 確實(shí)是可以免費(fèi)使用,但這個(gè)免費(fèi)是有限制的,聊天互動(dòng)每月限制50次,代碼補(bǔ)全(或者建議)每月2000次。不過這個(gè) Copiot 真的是很好
    的頭像 發(fā)表于 12-22 11:19 ?2737次閱讀
    GitHub Copilot <b class='flag-5'>可以</b>免費(fèi)使用了!

    激光可以投下陰影?

    研究人員發(fā)現(xiàn),激光束可以像不透明物體一樣投射出影子。這一發(fā)現(xiàn)挑戰(zhàn)了人們對陰影的傳統(tǒng)理解,為利用一束激光控制另一束激光的技術(shù)提供了新的可能性。
    的頭像 發(fā)表于 12-02 09:34 ?448次閱讀
    激光<b class='flag-5'>可以</b>投下陰影?

    光纖可以接ap面板嗎

    光纖可以接AP面板。光纖收發(fā)器可以直接連接AP(無線接入點(diǎn)),在WLAN(無線局域網(wǎng))中,光收發(fā)器可以接到交換機(jī),這通常是因?yàn)楣饫w收發(fā)器端口數(shù)的限制,而交換機(jī)可以接入多個(gè)AP,并且
    的頭像 發(fā)表于 11-21 09:26 ?1454次閱讀

    相同電感量的電感外形不同可以互換嗎

    電子發(fā)燒友網(wǎng)站提供《相同電感量的電感外形不同可以互換嗎.docx》資料免費(fèi)下載
    發(fā)表于 10-28 11:11 ?0次下載

    使用Arthas火焰圖工具的Java應(yīng)用性能分析和優(yōu)化經(jīng)驗(yàn)

    分享作者在使用Arthas火焰圖工具進(jìn)行Java應(yīng)用性能分析和優(yōu)化的經(jīng)驗(yàn)。
    的頭像 發(fā)表于 10-28 09:27 ?1186次閱讀
    使用<b class='flag-5'>Arthas</b>火焰圖工具的Java應(yīng)用性能分析和優(yōu)化經(jīng)驗(yàn)

    如何限制容器可以使用的CPU資源

    默認(rèn)情況下容器可以使用的主機(jī) CPU 資源是不受限制的。和內(nèi)存資源的使用一樣,如果不對容器可以使用的 CPU 資源進(jìn)行限制,一旦發(fā)生容器內(nèi)程序異常使用 CPU 的情況,很可能把整個(gè)主機(jī)的 CPU 資源耗盡,從而導(dǎo)致更大的災(zāi)難。本文將介紹如何限制容器
    的頭像 發(fā)表于 10-24 17:04 ?649次閱讀
    如何限制容器<b class='flag-5'>可以</b>使用的CPU資源

    光纖跳線可以熔接嗎

    光纖跳線在斷裂時(shí)是可以采取熔接的方式進(jìn)行修復(fù)的。不過,是否需要熔接以及熔接的具體方式,需要根據(jù)光纖跳線的類型、斷裂情況、使用環(huán)境以及修復(fù)成本等因素綜合考慮。 一、光纖跳線的類型與熔接 光纖跳線通常
    的頭像 發(fā)表于 10-21 10:15 ?817次閱讀

    前級功放可以單獨(dú)使用嗎

    可以,前級功放(Pre-amplifier)是音響系統(tǒng)中的一個(gè)重要組成部分,它可以單獨(dú)使用,也可以與其他音響設(shè)備配合使用。 前級功放單獨(dú)使用指南 1. 前級功放概述 前級功放,也稱為前級放大器
    的頭像 發(fā)表于 10-09 10:09 ?2416次閱讀

    網(wǎng)線不夠長可以接嗎

    網(wǎng)線不夠長是可以接的。當(dāng)網(wǎng)線長度不足以覆蓋所需連接的距離時(shí),可以通過幾種方法來延長網(wǎng)線。 網(wǎng)線連接器(耦合器):使用網(wǎng)線連接器(也稱為耦合器或中繼器)可以將兩根網(wǎng)線連接在一起。這種方法簡單快捷,但
    的頭像 發(fā)表于 09-12 09:33 ?4115次閱讀

    貼片屏蔽功率電感嘯叫可以不管嗎

    電子發(fā)燒友網(wǎng)站提供《貼片屏蔽功率電感嘯叫可以不管嗎.docx》資料免費(fèi)下載
    發(fā)表于 09-02 14:51 ?0次下載

    java反編譯的代碼可以修改么

    Java反編譯是一種將編譯后的Java字節(jié)碼(.class文件)轉(zhuǎn)換回源代碼的過程。反編譯后的代碼可以進(jìn)行修改,但是需要注意,反編譯代碼的質(zhì)量和可讀性可能會受到原始編譯代碼的混淆、優(yōu)化等因素
    的頭像 發(fā)表于 09-02 11:00 ?1224次閱讀

    hex可以轉(zhuǎn)成源代碼么

    Hex文件可以轉(zhuǎn)換成源代碼的近似形式,但無法直接還原為原始的、完全相同的源代碼 。這是因?yàn)镠ex文件是二進(jìn)制文件,包含了程序編譯后的機(jī)器碼,這些機(jī)器碼與原始的源代碼在結(jié)構(gòu)和表達(dá)上存在顯著的差異。不過
    的頭像 發(fā)表于 09-02 10:41 ?2186次閱讀

    開關(guān)可以控制電路的通和斷對嗎

    開關(guān)是電子電路中非常重要的一種元件,它可以用來控制電路的通斷狀態(tài)。通過控制開關(guān)的開合,可以實(shí)現(xiàn)對電路的控制和調(diào)節(jié)。 一、開關(guān)的工作原理 開關(guān)的基本結(jié)構(gòu) 開關(guān)主要由兩個(gè)導(dǎo)電觸點(diǎn)和一個(gè)操作機(jī)構(gòu)組成。導(dǎo)電
    的頭像 發(fā)表于 08-25 09:52 ?1997次閱讀

    java子類可以繼承父類的什么

    Java是一種面向?qū)ο蟮木幊陶Z言,它支持繼承的概念。繼承是面向?qū)ο缶幊痰娜筇匦灾?,它允許一個(gè)類(稱為子類或派生類)繼承另一個(gè)類(稱為父類或基類)的屬性和方法。在Java中,子類可以繼承父類
    的頭像 發(fā)表于 08-20 11:02 ?2265次閱讀