Arthas 3.4.6 版本发布,全新版本的热更新功能

栏目: 软件资讯 · 发布时间: 3年前

内容简介:Arthas是 Alibaba 开源的 Java 诊断工具,深受开发者喜爱。 内部Gitlab: http://gitlab.alibaba-inc.com/middleware-container/arthas 内部在线诊断:http://start.alibaba-inc.com/arthas/web-console Github: ...

Arthas 3.4.6 版本发布,全新版本的热更新功能

Arthas是 Alibaba 开源的 Java 诊断工具,深受开发者喜爱。

Arthas 3.4.6 版本带来下面全新的特性:

  • 增加 retransform 命令,可以实现更完善的热更新代码功能
  • watch 打印调用发生的具体位置,即函数入口/退出/异常退出,可以直观定位
  • watch/trace等命令支持 --exclude-class-pattern 选项,可以排除掉指定的类
  • 大幅改进HTTP API的稳定性

retransform 命令工作原理

在之前,Arthas里通过 redefine 命令可以实现热更新功能。但是 redefine命令有缺陷:

  • redefine命令和jad/watch/trace/monitor/tt等命令会冲突。执行完redefine之后,如果再执行上面提到的命令,则会把redefine的字节码重置。
  • 原因是JDK本身redefine和retransform是不同的机制,同时使用两种机制来更新字节码,只有最后修改的会生效。

那么新增加的 retransform 命令和 watch/trace命令等是同一机制下实现的。如果对同一个类执行多个命令,则会经过下面的处理:

retransform 命令 -> watch 命令 -> trace命令

所以,我们可以看到,retransform 命令执行后,不会影响watch/trace命令。

retransform 使用参考

加载外部的.class文件,retransform jvm已加载的类。

retransform /tmp/Test.class
retransform -l
retransform -d 1                    # delete retransform entry
retransform --deleteAll             # delete all retransform entries
retransform --classPattern demo.*   # triger retransform classes
retransform -c 327a647b /tmp/Test.class /tmp/Test\$Inner.class
retransform --classLoaderClass 'sun.misc.Launcher$AppClassLoader' /tmp/Test.class

retransform 结合 jad/mc 命令使用

jad --source-only com.example.demo.arthas.user.UserController > /tmp/UserController.java

mc /tmp/UserController.java -d /tmp

retransform /tmp/com/example/demo/arthas/user/UserController.class
  • jad命令反编译,然后可以用其它编译器,比如vim来修改源码
  • mc命令来内存编译修改过的代码
  • 用retransform命令加载新的字节码

mc-retransform在线教程: https://arthas.aliyun.com/doc/arthas-tutorials?language=cn&id=command-mc-retransform

watch 打印调用发生的具体位置

可以看到输出结果里多了location=AtExceptionExitlocation=AtExit这样子的信息。

$ watch demo.MathGame primeFactors
Press Q or Ctrl+C to abort.
Affect(class count: 1 , method count: 1) cost in 58 ms, listenerId: 1
method=demo.MathGame.primeFactors location=AtExceptionExit
ts=2021-01-15 11:34:30; [cost=0.929596ms] result=@ArrayList[
    @Object[][isEmpty=false;size=1],
    @MathGame[demo.MathGame@439f5b3d],
    null,
]
method=demo.MathGame.primeFactors location=AtExit
ts=2021-01-15 11:34:31; [cost=0.153708ms] result=@ArrayList[
    @Object[][isEmpty=false;size=1],
    @MathGame[demo.MathGame@439f5b3d],
    @ArrayList[isEmpty=false;size=2],
]

watch/trace等命令支持 --exclude-class-pattern 选项

当watch一个接口时,会匹配到它的所有实现子类,但有的时候我们排除掉一些特定的类,则比较困难,需要写很复杂的正则表达式。

所以增加了一个 --exclude-class-pattern参数,可以很方便地排除掉不需要增强的类。

watch javax.servlet.Filter * --exclude-class-pattern com.demo.TestFilter

大幅改进HTTP API的稳定性

主要改进了HTTP API里json的处理,避免各种json格式化出现的问题。

总结


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

编写高质量代码

编写高质量代码

秦小波 / 机械工业出版社华章公司 / 2011-12-28 / 59.00元

在通往“Java技术殿堂”的路上,本书将为你指点迷津!内容全部由Java编码的最佳实践组成,从语法、程序设计和架构、工具和框架、编码风格和编程思想等五大方面对Java程序员遇到的各种棘手的疑难问题给出了经验性的解决方案,为Java程序员如何编写高质量的Java代码提出了151条极为宝贵的建议。对于每一个问题,不仅以建议的方式从正反两面给出了被实践证明为十分优秀的解决方案和非常糟糕的解决方案,而且还......一起来看看 《编写高质量代码》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具