前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Arthas 开源一周年,Github Star 16K,我们一直在坚持什么?

Arthas 开源一周年,Github Star 16K,我们一直在坚持什么?

作者头像
kirito-moe
发布2019-10-09 16:19:14
9160
发布2019-10-09 16:19:14
举报

缘起

最近看到一个很流行的标题,《开源 XX 年,star XXX,我是如何坚持的》。

看到这样的标题,忽然发觉 Arthas 从 2018 年 9 月开源以来,刚好一年了,正好在这个秋高气爽的时节做下总结和回顾。

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

  • Github:https://github.com/alibaba/arthas[1]
  • 文档:https://alibaba.github.io/arthas[2]

回顾 Arthas Star 数的历史,一直保持快速增长,目前已经突破 16K。

Arthas Github Star历史曲线

感谢用户的支持,既是压力也是动力。在过去开源的一年里,Arthas 发布了 7 个 Release 版本,我们一直坚持三点:

  • 持续改进易用性
  • 持续增加好用的命令
  • 从开源社区中获取力量,回报社区

持续改进易用性

Arthas 一直把易用性放在第一位,在开源之后,我们做了下面的改进:

  • 开发 arthas boot,支持 Windows/Linux/Mac 统一体验
  • 丝滑的自动补全,参考了 jshell 的体验
  • 高效的历史命令匹配, Up/Down 直达
  • 改进类搜索匹配功能,更好支持 lambda 和内部类
  • 完善重定向机制
  • 支持 JDK 9/10/11
  • 支持 Docker
  • 支持 rpm/deb 包安装

尽管我们在易用性下了很大的功夫,但是发现很多时候用户比较难入门,因此,我们参考了 k8s 的 Interactive Tutorial,推出了 Arthas 的在线教程:

  • Arthas 基础教程 [3]
  • Arthas 进阶教程 [4]

通过基础教程,可以在交互终端里一步步入门,通过进阶教程可以深入理解 Arthas 排查问题的案例。

另外,为了方便用户大规模部署,我们实现了 tunnel server 和用户数据回报功能:

  • 增加 tunnel server,统一管理 Agent 连接
  • 增加用户数据回报功能,方便做安全管控

持续增加好用的命令

Arthas 号称是 Java 应用诊断利器,那么我们自己要对得起这个口号。在开源之后,Arthas 持续增加了 10 多个命令。

  • ognl 命令任意代码执行
  • mc 线上内存编译器
  • redefine 命令线上热更新代码
  • logger 命令一键查看应用里的所有 logger 配置
  • sysprop 查看更新 System Properties
  • sysenv 查看环境变量
  • vmoption 查看更新 VM option
  • logger 查看 logger 配置,更新 level
  • mbean 查看 JMX 信息
  • heapdump 堆内存快照

下面重点介绍两个功能。

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

通过 logger 命令查看配置,修改 level

在网站压力大的时候(比如双 11),有个缓解措施就是把应用的日志 level 修改为 ERROR。那么有两个问题:

  • 复杂应用的日志系统可能会有多个,那么哪个日志系统配置真正生效了?
  • 怎样在线上动态修改 logger 的 level?

通过 logger 命令,可以查看应用里 logger 的详细配置信息,比如 FileAppender 输出的文件, AsyncAppender 是否 blocking

代码语言:javascript
复制
[arthas@2062]$ logger
 name                                   ROOT
 class                                  ch.qos.logback.classic.Logger
 classLoader                            sun.misc.Launcher$AppClassLoader@2a139a55
 classLoaderHash                        2a139a55
 level                                  INFO
 effectiveLevel                         INFO
 additivity                             true
 codeSource                             file:/Users/hengyunabc/.m2/repository/ch/qos/logback/logback-classic/1.2.3/logback-classic-1.2.3.jar
 appenders                              name            CONSOLE
                                        class           ch.qos.logback.core.ConsoleAppender
                                        classLoader     sun.misc.Launcher$AppClassLoader@2a139a55
                                        classLoaderHash 2a139a55
                                        target          System.out
                                        name            APPLICATION
                                        class           ch.qos.logback.core.rolling.RollingFileAppender
                                        classLoader     sun.misc.Launcher$AppClassLoader@2a139a55
                                        classLoaderHash 2a139a55
                                        file            app.log
                                        name            ASYNC
                                        class           ch.qos.logback.classic.AsyncAppender
                                        classLoader     sun.misc.Launcher$AppClassLoader@2a139a55
                                        classLoaderHash 2a139a55
                                        blocking        false
                                        appenderRef     [APPLICATION]

也可以在线修改 logger 的 level:

代码语言:javascript
复制
[arthas@2062]$ logger --name ROOT --level debug
update logger level success.

从开源社区中获取力量,回报社区

感谢 67 位 Contributors

Arthas 开源以来,一共有 67 位 Contributors,感谢他们贡献的改进:

Arthas Contributors

社区提交了一系列的改进,下面列出一些点(不完整):

  • 翻译了大部分英文文档的
  • trace 命令支持行号
  • 打包格式支持 rpm/deb
  • 改进命令行提示符为 arthas@pid
  • 改进对 windows 的支持
  • 增加 mbean 命令
  • 改进 web console 的体验

另外,有 83 个公司 / 组织登记了他们的使用信息,欢迎更多的用户来登记:

Arthas Users

洐生项目

基于 Arthas,还产生了一些洐生项目,下面是其中两个:

  • Bistoury: 去哪儿网开源的集成了 Arthas 的项目
  • arthas-mvel: 一个使用 MVEL 脚本的 fork

用户案例分享

广大用户在使用 Arthas 排查问题过程中,分享了很多排查过程和心得,欢迎大家来分享。

Arthas 用户案例分享

回馈开源

Arthas 本身使用了很多开源项目的代码,在开源过程中,我们给 netty, ognl, cfr 等都贡献了改进代码,回馈上游。

后记

在做 Arthas 宣传小册子时,Arthas 的宣传语是:

“赠人玫瑰之手,经久犹有余香”

希望 Arthas 未来能帮助到更多的用户解决问题,也希望广大的开发者对 Arthas 提出更多的改进和建议。

参考资料

[1]

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

[2]

Arthas 文档: https://alibaba.github.io/arthas

[3]

Arthas基础教程: https://alibaba.github.io/arthas/arthas-tutorials?language=cn&id=arthas-basics

[4]

Arthas进阶教程: https://alibaba.github.io/arthas/arthas-tutorials?language=cn&id=arthas-advanced

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-09-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Kirito的技术分享 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 缘起
  • 持续改进易用性
  • 持续增加好用的命令
    • jad/mc/redefine 一条龙热更新线上代码
    • 从开源社区中获取力量,回报社区
      • 感谢 67 位 Contributors
        • 洐生项目
          • 用户案例分享
            • 回馈开源
            • 后记
            • 参考资料
            相关产品与服务
            日志服务
            日志服务(Cloud Log Service,CLS)是腾讯云提供的一站式日志服务平台,提供了从日志采集、日志存储到日志检索,图表分析、监控告警、日志投递等多项服务,协助用户通过日志来解决业务运维、服务监控、日志审计等场景问题。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档