@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)循环,永远不会结束,那么我们修改的代码也永远不会生效。
更多命令和高阶用法,可以参考官方文档,友情链接一下