一种简单快捷的 java 热部署方式
作者 | 周忠太 阿里巴巴淘系技术部的一个搬砖工
【Arthas 官方社区正在举行征文活动,参加即有奖品拿~点击投稿】
Arthas Hot Swap 插件介绍
引言
热部署是帮助开发人员提高效率的利器,如果你的开发语言是 java,开发环境是远程服务器,远程服务器 debug 端口被限制,那么你可能无法通过 debug HotSwap 实现热部署,那么本文介绍的 IntelliJ IDEA 插件可以帮助你在远程服务器实现热部署,而且操作简单快捷。
本文热部署插件(Arthas Hot Swap)是基于 Arthas redefine 命令实现的,使用该插件进行远程热部署无需任何配置,无需使用 debug 端口,只需几个简单动作就能完成。gitHub 地址:https://github.com/xxxtai/arthas-hotswap
使用方法
- IntelliJ IDEA 安装插件“Arthas Hot Swap”,从 gitHub Releases 下载安装包;
- 热部署使用的是 class 文件,所以需要先使用“mvn compile”编译相关工程,后续可以使用 IDEA 的 Recompile 编译单个文件,节省编译时间;
- 选择需要热部署的 java 源文件或者 class 文件,在类名或方法名上单击右键,选择“Arthas Hot Swap”的“Swap this class”,插件后台执行成功后会把热部署需要的命令复制到粘贴板;
- 登录远程服务器,粘贴热部署命令并执行,热部署完成,该机器运行着最新的class。机器第一次执行热部署命令,可能失败,再执行一次试下。
第一步:选择 Arthas Hot Swap 插件选项
第二步:登录远程服务器粘贴命令并执行
第三步:执行完成,热部署成功
热部署的限制
由于是基于 Arthas 的 redefine 命令实现的热部署,redefine 又是基于 Instrumentation API 实现的热部署,所以和 IDEA 的 debug HotSwap 是有一样的限制。限制如下:无法修改类名、方法名,无法修改类属性名称,无法新增类属性,无法新增非静态方法。由于本插件暂时无法获取内部类的 class 文件,所以暂时不支持修改内部类。
Arthas Hot Swap 插件原理
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% 用重新部署解决就好了。
Arthas Hot Swap 插件执行流程
- 根据用户选择的源文件找到 class 文件,默认在 /target/classes 路径下面查找,用户也可以直接选择 class 文件;
- 使用 AES-128 加密 class 文件,输出 base64 编码;
- 加密的 class 文件上传至 oss,返回 oss 访问地址;
- 渲染热部署需要执行的脚本,渲染后的脚本也上传至 oss,返回 oss 访问地址;
- 组装热部署命令,并自动复制到粘贴板。
远程服务端热部署执行流程
- 登录远程服务器,粘贴热部署命令并执行;
- 下载热部署脚本,执行热部署脚本;
- 创建工作空间;
- 检查是否安装 openssl,没有安装则进行安装;
- 下载 AES-128 加密的 class 文件;
- 使用 openssl enc 解密得到 class 二进制文件;
- 通过脚本方式安装 arthas;
- 创建与 arthas 通信的管道并启动 arthas;
- arthas 选择 java 进程,默认选择第一个;
- arthas 执行 redefine 命令热替换 class 文件;
- 打印热替换结果。
Arthas 征文活动火热进行中
Arthas 官方正在举行征文活动,如果你有:
- 使用 Arthas 排查过的问题
- 对 Arthas 进行源码解读
- 对 Arthas 提出建议
- 不限,其它与 Arthas 有关的内容
欢迎参加征文活动,还有奖品拿哦~点击投稿
“阿里巴巴云原生关注微服务、Serverless、容器、Service Mesh 等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,做最懂云原生开发者的公众号。”

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
java安全编码指南之:拒绝Denial of Service
简介 DOS不是那个windows的前身,而是Denial of Service,有做过系统安全方面的小伙伴可能对这个再熟悉不过了,简单点讲,DOS就是服务型响应不过来,从而拒绝了正常的服务请求。 今天本文不是要讲怎么发起一个DOS攻击,而是讲一下怎么在java的代码层面尽量减少DOS的可能性。 为什么会有DOS 为什么会有DOS呢?排除恶意攻击的情况下,DOS的原因就是资源的使用不当。一般意义上我们所说的资源有CPU周期,内存,磁盘空间,和文件描述符等。 如果这些资源受到了恶意使用,那么很有可能会影响正常的系统服务响应,从而产生DOS。 怎么在编码层面上,解决DOS问题呢? 不合理的资源使用 如果系统有不合理的资源使用的话,就会造成资源紧缺,从而会产生问题。我们这里举一些不合理使用资源的例子。 请求用于矢量图的SVG文件和字体文件 SVG (全称是 Scalable Vector Graphics) 是一个跟分辨率无关的图形格式。因为SVG是基于XML的,并且保存着大量的复杂路径信息,所以它的体积一般比较大。我们在使用的时候要考虑。 同时如果使用大量的字体文件也会加重系统的资源负担。...
- 下一篇
巧用HashMap一行代码统计单词出现次数
简介 JDK是在一直在迭代更新的,很多我们熟悉的类也悄悄的添加了一些新的方法特性。比如我们最常用的HashMap。 今天给大家讲一下HashMap在JDK8中添加的两个新方法compute和merge,从而实现一行代码实现单词统计的功能。一起来看看吧。 爱在JDK8之前 JDK8为我们引入了很多非常非常有用新特性,比如Stream和lambda表达式,可以让我们的程序更加简洁。 如果我们需要统计一个数组中单词出现的次数该怎么做呢? 这里不是讲算法,所以可以直接使用HashMap: public void countBefore8(){ Map<String,Integer> wordCount= new HashMap<>(); String[] wordArray= new String[]{"we","are","the","world","we"}; for(String word: wordArray){ //如果存在则加1,否则将值设置为1 if(wordCount.containsKey(word)) { wordCount.put(word, wo...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7,8上快速安装Gitea,搭建Git服务器
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- 设置Eclipse缩进为4个空格,增强代码规范
- SpringBoot2整合Redis,开启缓存,提高访问速度
- Windows10,CentOS7,CentOS8安装Nodejs环境