成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

阿里開源的那個牛X的問題排查工具,推出IDEA插件了!

新聞 開發(fā)工具
作為小開發(fā)的我,日常需要排查線上運(yùn)營同學(xué)提的各種 bug、各種線上問題診斷、日常運(yùn)維、線上問題優(yōu)化等等。 Arthas 對于很多 Java 開發(fā)者來說,已經(jīng)不可分割了,在我們?nèi)粘i_發(fā)、線上問題排查中扮演了非常重要的角色。

Arthas 對于很多 Java 開發(fā)者來說,已經(jīng)不可分割了,在我們?nèi)粘i_發(fā)、線上問題排查中扮演了非常重要的角色。作為小開發(fā)的我,日常需要排查線上運(yùn)營同學(xué)提的各種 bug、各種線上問題診斷、日常運(yùn)維、線上問題優(yōu)化等等。

在剛來公司時,我是比較恐懼運(yùn)維任務(wù)的,代碼不熟悉、各種問題比較多...幾乎崩潰的狀態(tài),運(yùn)維的一周基本上沒有干活,完全是全身心投入到運(yùn)維的任務(wù)中,排查問題效率低下。

由于深刻體驗到了這種奔潰,我一直想改變這種狀態(tài),直到 Arthas 的開源,讓我在這種崩潰的狀態(tài)中減輕了不少負(fù)擔(dān),同時也讓我成為了同事們咨詢 Arthas 排查問題的小幫手~~ 雖然使用 Arthas 特別方便,但在此過程中也遇到一些問題,作為問題咨詢小幫手也感到有點不方便,因此才造就了 Arthas idea 插件的誕生。

目前 Arthas 官方的工具還不夠簡單,需要記住一些命令,特別是一些擴(kuò)展性特別強(qiáng)的高級語法,比如 ognl 獲取 spring context 為所欲為,watch、trace 不夠簡單,需要構(gòu)造一些命令工具的信息,因此只需要一個能夠簡單處理字符串信息的插件即可使用。

當(dāng)在處理線上問題的時候需要最快速、最便捷的命令,因此 Idea Arthas plugin 插件還是有存在的意義和價值的。---這個是最初編寫這個插件的最核心的理由。

Arthas IDEA plugin 實踐

Arthas 的功能點非常的多(詳見下方大圖),這里就不一一的講解了,可以參考使用文檔 ,不過最近一直在更新,使用文檔中的命令名稱可能有變化。

插件安裝

下載 arthas idea 插件: https://plugins.jetbrains.com/ ... -idea

  • Mac:  Preferences  ->  Plugins
  • Windows: Settings  ->  Plugins

Install Plugin form Disk... 導(dǎo)入插件

安裝之后重啟 IDEA 就可以愉快的使用啦!

獲取 static 變量

首先要獲取 classloader 的 hash 值,然后獲取命令,這個是一個交互流程需要連貫性,后續(xù)只要是 static 的通過 static spring context 的都需要有這個交互的流程,連貫的,都在同一個界面進(jìn)行操作.粘貼執(zhí)行,然后獲取結(jié)果即可。

這里的 classloader 的 hash 值緩存起來的

最后合并的腳本如下。

  1. yaml 
  2.  
  3. ognl  -x  3 '@com.wangji92.arthas.plugin.demo.controller.StaticTest@INVOKE_STATIC_NAME' -c 316bc132 

反射設(shè)置 static field

通過反射進(jìn)行設(shè)置 static field ,參考: https://github.com/WangJi92/ar ... ues/1

填寫你想要修改的值、默認(rèn)根據(jù)類型設(shè)置默認(rèn)值 Str->"" Long -> 0L 等等。

  1. yaml 
  2.  
  3. ognl -x 3  '#field=@com.wangji92.arthas.plugin.demo.controller.StaticTest@class.getDeclaredField("INVOKE_STATIC_FINAL"),#modifiers=#field.getClass().getDeclaredField("modifiers"),#modifiers.setAccessible(true),#modifiers.setInt(#field,#field.getModifiers() & ~@java.lang.reflect.Modifier@FINAL),#field.setAccessible(true),#field.set(null,"設(shè)置的值")' -c 316bc132 

Spring Context Invoke

通過 spring context 進(jìn)行調(diào)用 bean 的方法、字段的內(nèi)容。

Static Spring Context Invoke Method Field

首頁要設(shè)置一下 static spring context 的路徑。

由于都是通過 ognl 調(diào)用 static 的 spring context 都需要 classloader,這個就是配置的 spring conetxt 的地址信息:

@com.wangji92.arthas.plugin.demo.common.ApplicationContextProvider@context 參考 demo 就需要配置這個地址。

  1. yaml 
  2.  
  3. ognl -x 3 '#springContext=@com.wangji92.arthas.plugin.demo.common.ApplicationContextProvider@context,#springContext.getBean("commonController").getRandomInteger()' -c 316bc132 

Watch Spring Context Invoke Method Field

watch 這個是支持在 spring mvc 場景,通過 watch 間接的獲取 spring context,需要出發(fā)一次接口的調(diào)用,可以參考 : https://github.com/WangJi92/ar ... ues/5

  1. yaml 
  2.  
  3. watch -x 3 -n 1  org.springframework.web.servlet.DispatcherServlet doDispatch '@org.springframework.web.context.support.WebApplicationContextUtils@getWebApplicationContext(params[0].getServletContext()).getBean("commonController").getRandomInteger()' 

TimeTunnel Spring Context Invoke Method Field

這個是參考了橫云斷嶺的 arthas 通過 tt 獲取 spring context 為所欲為 ,可以參考這個文檔: https://github.com/WangJi92/ar ... ues/4 這里做了些什么?將整個連貫了起來,不需要記住參數(shù)信息,然后對于調(diào)用的參數(shù)進(jìn)行簡單的默認(rèn)封裝,復(fù)雜的參數(shù)場景不支持,需要手動拼接。

記錄獲取 spring context

  1. yaml 
  2.  
  3. tt -t org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter invokeHandlerMethod 

然后根據(jù)這個 target 獲取 spring context 調(diào)用方法

  1. yaml 
  2.  
  3. tt -w 'target.getApplicationContext().getBean("commonController").getRandomInteger()' -x 3 -i 1000 

獲取某個 spring 環(huán)境變量

獲取 spring 環(huán)境變量這里依托,static spring context ,當(dāng)然這個 watch 、和 tt 獲取 spring context 的場景也是支持的。在線上環(huán)境、測試環(huán)境程序多復(fù)雜,你怎么知道環(huán)境中的變量一定是你配置的?在 nacos 等等配置中心的場景,估計手速慢了一點點,可能就沒有上去,這個時候就有這種需求獲取當(dāng)前的環(huán)境變量。選中變量,然后右鍵執(zhí)行命令。由于使用靜態(tài)的 static spring context 依然需要 classloader 的值。這里已經(jīng)基本上是 arthas 的上層應(yīng)用啦。

  1. yaml 
  2.  
  3. ognl -x 3 '#springContext=@com.wangji92.arthas.plugin.demo.common.ApplicationContextProvider@context,#springContext.getEnvironment().getProperty("custom.name")' -c 316bc132 

獲取全部的 spring 環(huán)境變量

比較優(yōu)先級,最前面的一定優(yōu)先級最高,你一定被 spring 的各種優(yōu)先級順序搞暈了,那么怎么辦呢?arthas idea plugin 支持獲取當(dāng)前的全部的環(huán)境變量,依次打印出來, 這樣就可以了解優(yōu)先級 ,特別是接入了 nacos、diamond 等遠(yuǎn)程的配置中心,實現(xiàn)不一樣肯定更暈了。

參考文檔: https://blog.csdn.net/xunjiush ... 50139

  1. yaml 
  2.  
  3. ognl -x 3 '#springContext=@com.wangji92.arthas.plugin.demo.common.ApplicationContextProvider@context,#allProperties={},#standardServletEnvironment=#propertySourceIterator=#springContext.getEnvironment(),#propertySourceIterator=#standardServletEnvironment.getPropertySources().iterator(),#propertySourceIterator.{#key=#this.getName(),#allProperties.add("                "),#allProperties.add("------------------------- name:"+#key),#this.getSource() instanceof java.util.Map ?#this.getSource().entrySet().iterator.{#key=#this.key,#allProperties.add(#key+"="+#standardServletEnvironment.getProperty(#key))}:#{}},#allProperties' -c 316bc132 

TimeTunnel Tt

方法執(zhí)行數(shù)據(jù)的時空隧道,記錄下指定方法每次調(diào)用的入?yún)⒑头祷匦畔?,并能對這些不同的時間下調(diào)用進(jìn)行觀測(可以重新觸發(fā),周期觸發(fā),唯一缺點對于 ThreadLocal 信息丟失[隱含參數(shù)]、引用對象數(shù)據(jù)變更無效),這個方便二次觸發(fā),特別是自己調(diào)試不方便的情況下記錄下來,二次觸發(fā)、周期觸發(fā),不過自從段嶺大神 tt 為所欲為之后都被帶偏了。這里 arthas 插件做了一些什么?增加了二次觸發(fā)的一些常用的命令,不讓使用者愁于記憶,整個過程更加的具有連貫性。

stack 堆棧

獲取方法從哪里執(zhí)行的調(diào)用棧(用途:源碼學(xué)習(xí)調(diào)用堆棧,了解調(diào)用流程) 這個是非常好用的功能,對于喜歡樂于排查問題的小伙伴真是福音,arthas idea 插件只是修改的命令的集成,之前也處理自己編碼過程中的問題,源碼、問題排查技巧-Java Debug and Arthas: https://blog.csdn.net/u0128819 ... 91529

  1. yaml 
  2.  
  3. stack com.wangji92.arthas.plugin.demo.controller.CommonController getRandomInteger -n 5 

Decompile Class Jad

反編譯方法、類的源碼, 有時候需要查看提交的代碼是否上線呢?這個功能就非常的友好。

參考文檔: https://github.com/WangJi92/arth!

as-idea-plugin/issues/2

  1. yaml 
  2.  
  3. jad --source-only com.wangji92.arthas.plugin.demo.controller.CommonController getRandomInteger 

watch、trace

增加了默認(rèn)參數(shù)、默認(rèn)展開的層級限制次數(shù),使用者不用知道這些核心的參數(shù),簡單的使用就好了,要使用更加的高級的自己help 一下就知道了。

  1. yaml 
  2.  
  3. watch com.wangji92.arthas.plugin.demo.controller.CommonController getRandomInteger '{params,returnObj,throwExp}' -n 5 -x 3 
  4.  
  5. trace com.wangji92.arthas.plugin.demo.controller.CommonController getRandomInteger -n 5 

trace -E(層級的打印 trace)

trace -E 自己構(gòu)造起來非常的麻煩,通過界面操作簡化了一下,需要觀察多個類、多個方法的場景。選擇你需要的場景繼續(xù)添加即可。

  1. yaml 
  2.  
  3. trace -E com.wangji92.arthas.plugin.demo.controller.CommonController|com.wangji92.arthas.plugin.demo.service.ArthasTestService traceE|doTraceE -n 5 

Heap Dump

打印堆棧,有點類似 jmap -dump:format=b,file=/temp/dump.hprof pid 下載下來使用 MAT 分析即可。

  1. yaml 
  2.  
  3. heapdump  /tmp/dump.hprof 打印堆棧信息 

特殊用法鏈接

這個必須要說一下,這個特殊用法的鏈接在線上自己束手無措的時候可以查看一下,非常有用。

對于通過 spring context 調(diào)用方法說明

通過 spring context 調(diào)用復(fù)雜的方法其實是不支持的,由于這個操作起來不方便,還是必須手工處理一下。

比如這里的 Map names 的處理方式可以借鑒一下子。

更多可以參考 demo: https://github.com/WangJi92/arthas-plugin-demo

  1. yaml 
  2.  
  3. /** 
  4.  
  5.      * 復(fù)雜參數(shù)調(diào)用 場景 
  6.  
  7.      * static spring context 
  8.  
  9.      * ognl -x 3 '#user=new com.wangji92.arthas.plugin.demo.controller.User(),#user.setName("wangji"),#user.setAge(27L),#springContext=@com.wangji92.arthas.plugin.demo.common.ApplicationContextProvider@context,#springContext.getBean("commonController").complexParameterCall(#{"wangji":#user})' -c e374b99 
  10.  
  11.      * 
  12.  
  13.      * watch get spring context 備注 需要調(diào)用一次方法 
  14.  
  15.      * watch -x 3 -n 1  org.springframework.web.servlet.DispatcherServlet doDispatch '#user=new com.wangji92.arthas.plugin.demo.controller.User(),#user.setName("wangji"),#user.setAge(27L),@org.springframework.web.context.support.WebApplicationContextUtils@getWebApplicationContext(params[0].getServletContext()).getBean("commonController").complexParameterCall(#{"wangji":#user})' 
  16.  
  17.      * 
  18.  
  19.      * tt get spring context ,only first get time index ok 
  20.  
  21.      * tt -w '#user=new com.wangji92.arthas.plugin.demo.controller.User(),#user.setName("wangji"),#user.setAge(27L),target.getApplicationContext().getBean("commonController").complexParameterCall(#{"wangji":#user})' -x 3 -i 1000 
  22.  
  23.      * @return 
  24.  
  25.      */ 
  26.  
  27.     @RequestMapping("complexParameterCall"
  28.  
  29.     @ResponseBody 
  30.  
  31.     public String complexParameterCall(@RequestBody  Map<String, User> names) { 
  32.  
  33.         if (names == null) { 
  34.  
  35.             return "EMPTY"
  36.  
  37.         } 
  38.  
  39.         return names.toString(); 
  40.  
  41.     } 

總結(jié)

本文簡單介紹了 Arthas IDEA 插件的安裝與使用技巧,該插件解放了大家對于 Arthas 使用的一些記憶、機(jī)械性的重復(fù)工作,歡迎大家試用!

Arthas 官方舉行了征文活動,于 3 月 26 日—— 4 月 26 日舉辦,如果你有:

  • 使用 Arthas 排查過的問題
  • 對 Arthas 進(jìn)行源碼解讀
  • 對 Arthas 提出建議
  • 不限,其它與 Arthas 有關(guān)的內(nèi)容

 

責(zé)任編輯:張燕妮 來源: http://dockone.io
相關(guān)推薦

2019-11-15 14:38:04

JavaLinux阿里

2019-11-15 08:40:53

Java開發(fā)代碼

2020-03-23 10:06:05

工具代碼開發(fā)

2021-05-19 17:04:29

Python阿里自動化工具

2018-12-10 10:30:40

阿里Linux命令

2020-12-07 11:12:16

MySOLBinlogOtter

2025-03-18 08:10:00

iodump開源I/O

2021-10-20 08:57:46

LinuxUbuntuSysmon

2019-02-15 15:33:00

Java開發(fā)代碼

2009-12-15 17:37:43

Visual Sort

2021-06-30 13:57:07

Arthas JVMTI

2017-11-03 17:05:11

開源

2021-08-26 10:29:47

工具Root框架

2016-09-22 09:37:14

GCC內(nèi)聯(lián)語法

2022-04-15 11:52:07

模型開源代碼

2021-06-25 10:24:30

Google開源漏洞數(shù)據(jù)庫

2016-02-23 15:18:26

開源問題追蹤工具

2017-05-16 12:42:12

服務(wù)器

2020-05-11 09:48:28

網(wǎng)絡(luò)故障路由器Linux

2024-03-11 00:02:00

Vite開源工具
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 久久精品欧美电影 | 精品国产视频 | 国产女人与拘做受免费视频 | 国产精品成人国产乱一区 | 亚洲一区视频在线播放 | 久久一| 欧美久久一区二区三区 | 高清黄色毛片 | 成人av播放| 成人羞羞国产免费视频 | 午夜精品久久久久久久久久久久 | 蜜桃一区二区三区 | 欧美精品在线免费观看 | 伊人久久大香线 | 一级黄色短片 | 久久久久久久久久久久久九 | 国产亚洲黄色片 | 在线观看你懂的网站 | 日韩欧美一区二区三区免费看 | 成人午夜影院 | 伊人免费观看视频 | 美女视频黄色的 | 日韩美女爱爱 | 国产精品久久久久久久粉嫩 | 久久成人免费 | 日本成人毛片 | 中文字幕1区 | 久久精品国产免费 | 日韩成人精品一区二区三区 | 免费色网址| www.久久99| 九九热精品视频在线观看 | 99伊人网| 欧美在线a | 欧美福利在线 | 国产成人精品免费视频大全最热 | 少妇性l交大片免费一 | 韩日在线视频 | 免费视频二区 | 欧美视频一区二区三区 | 国产日韩一区二区三区 |