热部署是帮助开发人员提高效率的利器,如果你的开发语言是java,开发环境是远程服务器,远程服务器debug端口被限制,那么你可能无法通过debug HotSwap实现热部署,那么本文介绍的IntelliJ IDEA插件可以帮助你在远程服务器实现热部署,而且操作简单快捷。本文热部署插件( Arthas Hot Swap )是基于Arthas redefine命令实现的,使用该插件进行远程热部署无需任何配置,无需使用debug端口,只需几个简单动作就能完成。
由于是基于Arthas的 redefine 命令实现的热部署,redefine又是基于Instrumentation API实现的热部署,所以和IDEA的debug HotSwap是有一样的限制。限制如下:无法修改类名、方法名,无法修改类属性名称,无法新增类属性,无法新增非静态方法。由于本插件暂时无法获取内部类的class文件,所以暂时不支持修改内部类。
Arthas 是阿里巴巴开源的Java代码诊断工具。Arthas的 redefine命令 是基于Instrumentation API实现的热部署,因此和HotSwap热部署方式一样,有同样的限制。Arthas的redefine命令其实是把Instrumentation API的redefineClasses方法包装后提供给用户,那么我们就可以根据redefine命令发挥想象力,实现热部署。
Arthas官方文档推荐使用jad/mc/redefine等一连串命令实现class远程热替换,流程大概是:jad命令对老class进行反编译->vim编辑源码->mc命令编译源码->redefine热替换class。这种方式存在两个问题:一是太麻烦,二是mc编译大概率会失败。如果能这样就好,本地修改代码编译后上传class文件到远程服务器,再使用redefine命令热替换class。因此官方文档又推荐,首先将class二进制文件转换成base64编码,然后再复制粘贴到远程服务器,再把base64编码转换成class文件,最后,使用redefine进行热替换。这么麻烦,还不如重新部署呢。所以redefine命令比较鸡肋。
Arthas官方推荐的热替换方法最大的问题在于,上传class文件到远程服务器进行热替换的流程太麻烦,那么这些麻烦且固定的流程为何不交给机器来做呢。所以,本文推荐的“Arthas Hot Swap”插件就有必要了,该插件就是为了提升使用Arthas进行热替换的效率,几个简单的动作就能热替换一个class文件,可以解决开发过程中80%的热部署需求,剩下的20%用重新部署解决就好了。