手记

使用Arthas实现不停机更新

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

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

0人推荐
随时随地看视频
慕课网APP