国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Arthas可以解決哪些問題

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

掃碼添加小助手

加入工程師交流群

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

什么是Arthas

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

在日常開發中,當我們發現應用的某個接口響應比較慢,這個時候想想要分析一下原因,找到代碼中耗時的部分,比較容易想到的是在接口鏈路的 IO 操作上下游打印時間日志,再根據幾個時間點的日志算出耗時長的 IO 操作。這種方式沒有問題,但是加日志需要發布,既繁瑣又低效,這個時候可以引入一些線上 debug 的工具,arthas 就是很好的一種,除了分析耗時,還可以打印調用棧、方法入參及返回,類加載情況,線程池狀態,系統參數等等,其實現原理是解析 JVM 在操作系統中的文件,大部分操作是只讀的,對服務進程沒有侵入性,因此可以放心使用。

Arthas能解決什么問題?

從我個人的使用經驗來看,Arthas至少幫我解決了以下幾個問題:

監控某方法查看其整個調用鏈路,從而找出某次調用的性能瓶頸。

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

站在全局視角查看整個系統的運行情況,比如觀察內存增長、GC的情況。

在微服務架構背景下,通常本地沒有完整的環境,此時可以直接在測試環境監控某個方法傳入的參數是否正確,返回值是否正確。

快速開始

下載并啟動arthas

輸入以下命令啟動arthas程序

curl -O https://arthas.aliyun.com/arthas-demo.jarjava -jar arthas-demo.jar

選擇需要監控應用的進程編號,回車后Arthas會attach到目標進程上,并輸出日志:

容器中使用

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

甚至我們可以直接把arthas放到容器鏡像文件中:

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

Arthas常用命令

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

dashboard

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

1. 當前最繁忙的一些線程

2. 顯示應用當前使用的內存信息,包括堆內存、新生代伊甸區、老年代、非堆內存的使用情況。

3. 顯示程序的GC情況,包括YGC次數、總花費時間,FGC的次數、總花費時間。

4. 當前程序的一些信息,包括系統版本、JDK版本、程序運行時長等。

Thread

查看當前線程信息,查看線程的堆棧

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

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

watch

有時候我們不太方便進行本地調試,這個時候可以使用watch監控某個方法,然后點擊相關的功能,查看該方法的調用情況:

watch com.primeton.dgp.assets.controller.DsResourcePoolController getResourcePool "{params,returnObj}" -x 2

執行以上命令后,控制臺會hold在被監控的方法上,此時再次點擊頁面上的按鈕,控制臺就會打印此次的調用結果。

trace

trace 命令能主動搜索 class-pattern/method-pattern 對應的方法調用路徑,渲染和統計整個調用鏈路上的所有性能開銷和追蹤調用鏈路。通常我們用這個方法可以看到整個調用路徑的耗時,從而找出真正的性能瓶頸,幫助解決問題。

trace com.primeton.dgp.assets.controller.DsResourcePoolController getResourcePool

tt

tt方法執行數據的時空隧道,記錄下指定方法每次調用的入參和返回信息,并能對這些不同的時間下調用進行觀測,使用方法如下:

tt -t com.primeton.dgp.assets.controller.DsResourcePoolController getResourcePool

執行此命令后,arthas會記錄下指定方法的每次調用環境現場,并打印一些相關的信息,如調用時長、是否正常返回、是否拋出異常等。

顯示所有被記錄的調用列表

tt -l

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

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

jad

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

其他

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

另外,每一個命令都支持-help參數,可以查看該命令的說明、參數,甚至包括了使用例子,可以說是非常貼心了

案例

案例1

我們準備了一個簡單的springboot應用,應用內有一個Controller,返回一個字符串,代碼如下:

@RestControllerpublic class DemoController {

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

啟動程序,訪問剛剛準備好的controller得到了下面的結果

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

首先啟動arthas并織入到剛才的demo,然后反編譯DemoController到臨時文件夾。

jad --source-only com.example.arthas.DemoController > /tmp/DemoController.java

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

查詢加載原有DemoController類的ClassLoader

sc -d com.example.arthas.DemoController

重新編譯修改后的類

mc -c 685f4c2e /tmp/DemoController.java

重新加載修改后的類

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

此時,無需重啟應用,我們重新訪問剛才的controller,會發現返回結果已經成功更改了。

案例2

某燃氣系統由于被眾多地區的燃氣公司所使用,所以版本繁多,經歷過很多輪的測試,其中比較耗時的當屬性能測試了。以往性能測試工作通常耗時很長,主要是性能測試人員并不一定熟悉項目代碼,導致壓力測試出現問題的時候不容易找到問題的所在。

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

本次壓力測試的過程中我們發現,當并發達到一定數量的時候系統會卡死,大量新的請求會超時。使用dashboard查看發現系統的大量線程處于block或者wating中。

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

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

監控日志,當用戶數達到500+的時候果然發現了問題

繼續使用trace命令跟蹤,發現了可能出現問題的方法

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

小結

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

關于作者:李云濤,普元高級開發工程師,擅長性能調優、微服務、容器、消息隊列等技術。先后參與郵儲銀行Java開發平臺、中移總ERP流程平臺、中煤信息技術中臺等平臺的的架構設計與平臺研發工作。

審核編輯:符乾江
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 代碼
    +關注

    關注

    30

    文章

    4967

    瀏覽量

    73954
  • 編譯
    +關注

    關注

    0

    文章

    694

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    同軸光源 細小劃痕都可以被“看見”

    同軸光源可以對物體表面的微小不規則現象進行成像。
    的頭像 發表于 01-09 17:40 ?185次閱讀
    同軸光源 細小劃痕都<b class='flag-5'>可以</b>被“看見”

    遠心鏡頭可以調倍率嗎?

    也有一些例外。比如東莞銳星視覺技術提供了雙遠心鏡頭,還有三倍率/雙倍率雙遠心鏡頭。這些鏡頭在保留遠心特性的基礎上,讓同一個鏡頭可以更換兩種倍率,也就是可以根據具體需
    的頭像 發表于 12-03 17:22 ?352次閱讀
    遠心鏡頭<b class='flag-5'>可以</b>調倍率嗎?

    有多少種方法可以進行頻響曲線測量?

    APx500軟件提供了頻響曲線的多種測量方法,對一個音頻產品的頻響特性進行測量分析。如果只用一個測量對一個音頻產品進行評價,那這個測量就是頻響曲線,APx500軟件提供了多種方法可以進行頻響曲線測量
    的頭像 發表于 11-14 11:29 ?865次閱讀
    有多少種方法<b class='flag-5'>可以</b>進行頻響曲線測量?

    哪些電容可以替代CBB81電容

    CBB81電容屬于高壓諧振薄膜電容器,主要用于高壓、高頻、大電流電路中,事實上,有很多電容器的作用和CBB81電容是一樣的,可以互相替代,cbb81電容用什么可以代替?
    的頭像 發表于 08-26 14:23 ?1209次閱讀

    科普|高通量衛星可以用來打電話嗎?

    在應急指揮環境下,衛星資源的應用是必須的,當地面運營商基站遭到破壞時,利用衛星仍然可以實現應急的通信。一般應急現場可以使用衛星電話設備進行電話溝通,衛星電話的使用方法與普通電話也沒有什么差別,只需要
    的頭像 發表于 08-18 18:12 ?963次閱讀
    科普|高通量衛星<b class='flag-5'>可以</b>用來打電話嗎?

    工業組態云平臺可以實現哪些功能

    工業組態云平臺可以實現數據采集與監控、報警通知、遠程控制與運維、數據分析與決策、組態設計與可視化等多種功能,以下是具體介紹: 1、數據采集與監控 實時數據采集:通過內置多種工業設備驅動,支持主流
    的頭像 發表于 08-18 14:36 ?471次閱讀

    網線可以串聯嗎?為什么

    網線可以串聯,但通常不建議這樣做,尤其在需要穩定高速網絡連接的場景中。 以下是具體分析: 一、網線串聯的可行性 從技術層面看,網線(如常見的超五類、六類網線)可以通過以下方式串聯: 直接對接 將兩根
    的頭像 發表于 08-06 10:14 ?3350次閱讀

    干擾可以提高測量精度,是真的嗎?

    一、前言 水可以引燃蠟燭,是真的嗎?是真的! 蛇怕雄黃,是真的嗎?是假的! 上述兩個現象,已經由央視 財經頻道《是真的嗎?》揭秘。 今天要探討的是: 干擾可以提高測量精度,是真的嗎? 通常情況下
    的頭像 發表于 08-04 09:28 ?698次閱讀
    干擾<b class='flag-5'>可以</b>提高測量精度,是真的嗎?

    光纖跳線可以彎曲嗎

    光纖跳線可以彎曲,但彎曲程度必須控制在合理范圍內,過度彎曲會導致信號衰減增加、傳輸性能下降甚至光纖損壞。以下是詳細解釋: 一、光纖跳線為何能彎曲? 光纖跳線由光纖和保護層組成,光纖本身是柔性的玻璃或
    的頭像 發表于 07-25 10:17 ?1123次閱讀

    一片主板可以有多少路CPU?

    CPU是計算機的中央處理器,可以直接影響到服務器的并行處理能力。CPU路數越多,服務器可以同時處理的任務數量就越多,從而提高了整體的處理效率和性能,特別是在處理大量并發任務時,多路服務器具有明顯優勢?。
    的頭像 發表于 06-13 09:14 ?717次閱讀
    一片主板<b class='flag-5'>可以</b>有多少路CPU?

    門鈴語音芯片有哪幾種型號可以選擇?

    門鈴語音芯片的選擇可以很廣泛!因為簡單的OTP語音芯片也可以用,高級一點的FLASH語音芯片,或者在高端一點的語音識別芯片,或者集成藍牙又或者紅外等等,有非常多的方案,具體可以看自己詳細的需求。 以
    的頭像 發表于 06-09 15:58 ?705次閱讀

    光纖可以傳輸控制信號嗎

    光纖可以傳輸控制信號,以下從原理、應用場景、優勢、注意事項等方面為你詳細分析: 原理 光信號轉換:控制信號通常是電信號,在利用光纖傳輸時,需要先將電信號轉換為光信號。這一過程通過發送端的光電轉換器
    的頭像 發表于 05-28 09:27 ?1038次閱讀

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

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

    異形拼接處理器可以實現的效果

    異形拼接處理器可以實現的效果非常多樣化和創新,以下是對其可實現效果的進一步補充: 一、創意拼接顯示 1、任意角度拼接:異形拼接處理器支持0~360度任意角度的拼接顯示,使得顯示屏可以以各種角度進行
    的頭像 發表于 03-21 12:39 ?669次閱讀
    異形拼接處理器<b class='flag-5'>可以</b>實現的效果

    單模單纖可以收發嗎

    單模單纖可以收發。單模單纖使用一根光纖進行雙向通信,即在同一根光纖上同時進行發送和接收操作。這通常需要使用特殊的收發器(如BiDi收發器)和波分復用(WDM)技術來實現雙向通信。 具體來說,單模單纖
    的頭像 發表于 03-17 09:51 ?1285次閱讀