为了账号安全,请及时绑定邮箱和手机立即绑定

使用Arthas实现不停机更新

标签:
Java JVM

@TOC

背景

生产服务器的缺陷往往需要进行紧急更新,即使是多节点部署也避免不了需要重新启动服务器,使新的逻辑代码更新,所以不停机更新文件显得至关重要,今天介绍一下使用阿里的arthas实现不停机更新文件。

大致思路:我们都知道class文件的加载都是依附于类加载器的,所以我们要做的就是让原本的类加载器重新去加载类文件,这样就可以实现不重启服务器更新应用。而arthas做的就是面向jvm,拿到指定的累加器和待更新的class编译文件,剩下的交给arthas就可以了。

测试前的demo应用返回值:
在这里插入图片描述

下载安装

  • 下载
curl -O https://alibaba.github.io/arthas/arthas-boot.jar
  • 安装启动
java -jar arthas-boot.jar
  • 选择对应的应用程序
    输入序号或者进程号即可

查询需要替换的文件的类加载器

  • 查询指定类的信息
 sc -d *UserController

sc为search class的简写,-d参数表示输出当前类的详细信息,详细信息如下:
在这里插入图片描述

  • 查询指定类的类加载器
    如上图所示,class-loader参数即为类加载器的信息,还可以使用grep进行查询过滤
sc -d *UserController | grep class-loader

在这里插入图片描述

我们要的就是类加载器的hash值,用于后面class文件加载指定

加载指定的class文件

  • 将修改后的文件上传至服务器
  • 指定上述的类加载器去加载新的class文件
redefine -c 33909752 /root/secKill/UserController.class

当返回success时,即为替换成功。
查询验证即可
在这里插入图片描述

注意

当然了,Arthas虽然功能强大,但也不是万金油

1、不能增加或删除field/method
2、没有退出的函数不能生效,比如一个函数体内是一个where(true)循环,永远不会结束,那么我们修改的代码也永远不会生效。

更多命令和高阶用法,可以参考官方文档,友情链接一下

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消