Alibaba Arthas 3.1.0版本:在線教程、內存編譯器和強大的自動補全

Arthas

Arthas是Alibaba開源的Java診斷工具,深受開發者喜愛。

從Arthas上個版本發佈,已經過去兩個多月了,Arthas 3.1.0版本不僅帶來大家投票出來的新LOGO,還帶來強大的新功能和更好的易用性,下面一一介紹。

  • Github: https://github.com/alibaba/arthas

  • 文檔:https://alibaba.github.io/arthas

在線教程

在新版本Arthas裏,增加了在線教程,用戶可以在線運行Demo,一步步學習Arthas的各種用法,推薦新手嘗試:

  • Arthas基礎教程: 

    https://alibaba.github.io/arthas/arthas-tutorials?language=cn

  • Arthas進階教程: 

    https://alibaba.github.io/arthas/arthas-tutorials?language=cn&id=arthas-advanced

非常歡迎大家來完善這些教程。

增加內存編譯器支持,在線編輯熱更新代碼

3.1.0版本里新增命令mc,不是方塊遊戲mc,而是Memory Compiler。

在之前版本里,增加了redefine命令,可以熱更新字節碼。但是有個不方便的地方:需要把.class文件上傳到服務器上。

3.1.0版本里,結合jad/mc/redefine 可以完美實現熱更新代碼。

以 Arthas在線教程 裏的UserController爲例:

  1. 使用jad反編譯代碼

    jad --source-only com.example.demo.arthas.user.UserController > /tmp/UserController.java
  2. 使用vim編輯代碼
    當 user id 小於1時,也正常返回,不拋出異常:

        @GetMapping("/user/{id}")
        public User findUserById(@PathVariable Integer id) {
            logger.info("id: {}" , id);
            if (id != null && id < 1) {
                return new User(id, "name" + id);
                // throw new IllegalArgumentException("id < 1");
            } else {
                return new User(id, "name" + id);
            }
        }
  3. 使用mc命令編譯修改後的UserController.java

    $ mc /tmp/UserController.java -d /tmp
    Memory compiler output:
    /tmp/com/example/demo/arthas/user/UserController.class
    Affect(row-cnt:1) cost in 346 ms
  4. 使用redefine命令,因爲可以熱更新代碼

    redefine /tmp/com/example/demo/arthas/user/UserController.class
    redefine success, size: 1

絲滑的自動補全

在新版本里,改進了很多命令的自動補全,比如 watch/trace/tt/monitor/stack等。

下面是watch命令的第一個Tab補全結果,用戶可以很方便的一步步補全類名,函數名:

$ watch
com.   sun.   javax. ch.    io.    demo.  jdk.   org.   java.

另外,新增加了 jad/sc/sm/redefine 等命令的自動補全支持,多按Tab有驚喜。

新版本的Web console

新版本的Web Console切換到了xtermd.js,更好地支持現代瀏覽器。

  • 支持Ctrl + C複製

  • 支持全屏

web console

Docker鏡像支持

Arthas支持Docker鏡像了

  • 用戶可以很方便地診斷Docker/k8s裏的Java進程

  • 也可以很方便地把Arthas加到自己的基礎鏡像裏

參考: https://alibaba.github.io/arthas/docker.html

重定向重新設計

之前的版本里,Arthas的重定向是會放到一個~/logs/arthas-cache/目錄裏,違反直覺。

在新版本里,重定向和Linux下面的一致,>/>>的行爲也和Linux下一致。

並且,增加了 cat/pwd命令,可以配置使用。

總結

總之,3.1.0版本的Arthas帶了非常多的新功能,改進了很多的用戶體驗,歡迎大家使用反饋。

  • Arthas在線教程可以學到很多技巧

  • jad/mc/redefine 一條龍非常強大

  • 絲滑的自動補全值得嘗試

  • 新版本的Web Console有驚奇

Release Note: 

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章