chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

Arthas可以解決哪些問(wèn)題

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

掃碼添加小助手

加入工程師交流群

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

什么是Arthas

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

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

Arthas能解決什么問(wèn)題?

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

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

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

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

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

快速開(kāi)始

下載并啟動(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)程編號(hào),回車(chē)后Arthas會(huì)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常用命令

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

dashboard

使用dashboard命令會(huì)顯示以下信息:

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í)長(zhǎng)等。

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í)行以上命令后,控制臺(tái)會(huì)hold在被監(jiān)控的方法上,此時(shí)再次點(diǎn)擊頁(yè)面上的按鈕,控制臺(tái)就會(huì)打印此次的調(diào)用結(jié)果。

trace

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

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

tt

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

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

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

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

tt -l

重做一次調(diào)用。tt 命令由于保存了當(dāng)時(shí)調(diào)用的所有現(xiàn)場(chǎng)信息,所以我們可以自己主動(dòng)對(duì)一個(gè) INDEX 編號(hào)的時(shí)間片自主發(fā)起一次調(diào)用,從而解放你的溝通成本。此時(shí)你需要 -p 參數(shù)。通過(guò) --replay-times 指定 調(diào)用次數(shù),通過(guò) --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ù)邏輯;反編譯出來(lái)的源碼是帶語(yǔ)法高亮的,閱讀更方便。當(dāng)我們看到某個(gè)方法的調(diào)用時(shí)長(zhǎng)明顯過(guò)長(zhǎng),或者時(shí)空隧道中某方法拋出異常,這個(gè)時(shí)候就可以直接反編譯相關(guān)的方法,看看是否能找出原因。

其他

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

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

案例

案例1

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

@RestControllerpublic class DemoController {

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

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

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

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

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

接下來(lái)我們用vim修改反編譯出來(lái)的代碼

查詢加載原有DemoController類(lèi)的ClassLoader

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

重新編譯修改后的類(lèi)

mc -c 685f4c2e /tmp/DemoController.java

重新加載修改后的類(lèi)

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

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

案例2

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

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

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

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

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)了問(wèn)題

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

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

小結(jié)

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

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

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

    關(guān)注

    30

    文章

    4959

    瀏覽量

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

    關(guān)注

    0

    文章

    692

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    同軸光源 細(xì)小劃痕都可以被“看見(jiàn)”

    同軸光源可以對(duì)物體表面的微小不規(guī)則現(xiàn)象進(jìn)行成像。
    的頭像 發(fā)表于 01-09 17:40 ?149次閱讀
    同軸光源 細(xì)小劃痕都<b class='flag-5'>可以</b>被“看見(jiàn)”

    遠(yuǎn)心鏡頭可以調(diào)倍率嗎?

    也有一些例外。比如東莞銳星視覺(jué)技術(shù)提供了雙遠(yuǎn)心鏡頭,還有三倍率/雙倍率雙遠(yuǎn)心鏡頭。這些鏡頭在保留遠(yuǎn)心特性的基礎(chǔ)上,讓同一個(gè)鏡頭可以更換兩種倍率,也就是可以根據(jù)具體需
    的頭像 發(fā)表于 12-03 17:22 ?301次閱讀
    遠(yuǎn)心鏡頭<b class='flag-5'>可以</b>調(diào)倍率嗎?

    有多少種方法可以進(jìn)行頻響曲線測(cè)量?

    APx500軟件提供了頻響曲線的多種測(cè)量方法,對(duì)一個(gè)音頻產(chǎn)品的頻響特性進(jìn)行測(cè)量分析。如果只用一個(gè)測(cè)量對(duì)一個(gè)音頻產(chǎn)品進(jìn)行評(píng)價(jià),那這個(gè)測(cè)量就是頻響曲線,APx500軟件提供了多種方法可以進(jìn)行頻響曲線測(cè)量
    的頭像 發(fā)表于 11-14 11:29 ?766次閱讀
    有多少種方法<b class='flag-5'>可以</b>進(jìn)行頻響曲線測(cè)量?

    哪些電容可以替代CBB81電容

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

    科普|高通量衛(wèi)星可以用來(lái)打電話嗎?

    在應(yīng)急指揮環(huán)境下,衛(wèi)星資源的應(yīng)用是必須的,當(dāng)?shù)孛孢\(yùn)營(yíng)商基站遭到破壞時(shí),利用衛(wèi)星仍然可以實(shí)現(xiàn)應(yīng)急的通信。一般應(yīng)急現(xiàn)場(chǎng)可以使用衛(wèi)星電話設(shè)備進(jìn)行電話溝通,衛(wèi)星電話的使用方法與普通電話也沒(méi)有什么差別,只需要
    的頭像 發(fā)表于 08-18 18:12 ?894次閱讀
    科普|高通量衛(wèi)星<b class='flag-5'>可以</b>用來(lái)打電話嗎?

    工業(yè)組態(tài)云平臺(tái)可以實(shí)現(xiàn)哪些功能

    工業(yè)組態(tài)云平臺(tái)可以實(shí)現(xiàn)數(shù)據(jù)采集與監(jiān)控、報(bào)警通知、遠(yuǎn)程控制與運(yùn)維、數(shù)據(jù)分析與決策、組態(tài)設(shè)計(jì)與可視化等多種功能,以下是具體介紹: 1、數(shù)據(jù)采集與監(jiān)控 實(shí)時(shí)數(shù)據(jù)采集:通過(guò)內(nèi)置多種工業(yè)設(shè)備驅(qū)動(dòng),支持主流
    的頭像 發(fā)表于 08-18 14:36 ?435次閱讀

    網(wǎng)線可以串聯(lián)嗎?為什么

    網(wǎng)線可以串聯(lián),但通常不建議這樣做,尤其在需要穩(wěn)定高速網(wǎng)絡(luò)連接的場(chǎng)景中。 以下是具體分析: 一、網(wǎng)線串聯(lián)的可行性 從技術(shù)層面看,網(wǎng)線(如常見(jiàn)的超五類(lèi)、六類(lèi)網(wǎng)線)可以通過(guò)以下方式串聯(lián): 直接對(duì)接 將兩根
    的頭像 發(fā)表于 08-06 10:14 ?2949次閱讀

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

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

    光纖跳線可以彎曲嗎

    光纖跳線可以彎曲,但彎曲程度必須控制在合理范圍內(nèi),過(guò)度彎曲會(huì)導(dǎo)致信號(hào)衰減增加、傳輸性能下降甚至光纖損壞。以下是詳細(xì)解釋?zhuān)?一、光纖跳線為何能彎曲? 光纖跳線由光纖和保護(hù)層組成,光纖本身是柔性的玻璃或
    的頭像 發(fā)表于 07-25 10:17 ?930次閱讀

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

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

    門(mén)鈴語(yǔ)音芯片有哪幾種型號(hào)可以選擇?

    門(mén)鈴語(yǔ)音芯片的選擇可以很廣泛!因?yàn)楹?jiǎn)單的OTP語(yǔ)音芯片也可以用,高級(jí)一點(diǎn)的FLASH語(yǔ)音芯片,或者在高端一點(diǎn)的語(yǔ)音識(shí)別芯片,或者集成藍(lán)牙又或者紅外等等,有非常多的方案,具體可以看自己詳細(xì)的需求。 以
    的頭像 發(fā)表于 06-09 15:58 ?654次閱讀

    光纖可以傳輸控制信號(hào)嗎

    光纖可以傳輸控制信號(hào),以下從原理、應(yīng)用場(chǎng)景、優(yōu)勢(shì)、注意事項(xiàng)等方面為你詳細(xì)分析: 原理 光信號(hào)轉(zhuǎn)換:控制信號(hào)通常是電信號(hào),在利用光纖傳輸時(shí),需要先將電信號(hào)轉(zhuǎn)換為光信號(hào)。這一過(guò)程通過(guò)發(fā)送端的光電轉(zhuǎn)換器
    的頭像 發(fā)表于 05-28 09:27 ?955次閱讀

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

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

    異形拼接處理器可以實(shí)現(xiàn)的效果

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

    單模單纖可以收發(fā)嗎

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