继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

使用Arthas实现不停机更新

殷浩
关注TA
已关注
手记 1
粉丝 4
获赞 0

@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)循环,永远不会结束,那么我们修改的代码也永远不会生效。

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

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP