一种简单快捷的 java 热部署方式

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
可观测可视化 Grafana 版,10个用户账号 1个月
简介: 本文热部署插件(Arthas Hot Swap)是基于 Arthas redefine 命令实现的,使用该插件进行远程热部署无需任何配置,无需使用 debug 端口,只需几个简单动作就能完成。

1.png

作者 | 周忠太 阿里巴巴淘系技术部的一个搬砖工

【Arthas 官方社区正在举行征文活动,参加即有奖品拿~点击投稿

Arthas Hot Swap 插件介绍

引言

热部署是帮助开发人员提高效率的利器,如果你的开发语言是 java,开发环境是远程服务器,远程服务器 debug 端口被限制,那么你可能无法通过 debug HotSwap 实现热部署,那么本文介绍的 IntelliJ IDEA 插件可以帮助你在远程服务器实现热部署,而且操作简单快捷。

本文热部署插件(Arthas Hot Swap)是基于 Arthas redefine 命令实现的,使用该插件进行远程热部署无需任何配置,无需使用 debug 端口,只需几个简单动作就能完成。gitHub 地址:https://github.com/xxxtai/arthas-hotswap

使用方法

  1. IntelliJ IDEA 安装插件“Arthas Hot Swap”,从 gitHub Releases 下载安装包;
  2. 热部署使用的是 class 文件,所以需要先使用“mvn compile”编译相关工程,后续可以使用 IDEA 的 Recompile 编译单个文件,节省编译时间;
  3. 选择需要热部署的 java 源文件或者 class 文件,在类名或方法名上单击右键,选择“Arthas Hot Swap”的“Swap this class”,插件后台执行成功后会把热部署需要的命令复制到粘贴板;
  4. 登录远程服务器,粘贴热部署命令并执行,热部署完成,该机器运行着最新的class。机器第一次执行热部署命令,可能失败,再执行一次试下。

2.png

第一步:选择 Arthas Hot Swap 插件选项

3.png

第二步:登录远程服务器粘贴命令并执行

4.png

第三步:执行完成,热部署成功

热部署的限制

由于是基于 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 插件执行流程

  1. 根据用户选择的源文件找到 class 文件,默认在 /target/classes 路径下面查找,用户也可以直接选择 class 文件;
  2. 使用 AES-128 加密 class 文件,输出 base64 编码;
  3. 加密的 class 文件上传至 oss,返回 oss 访问地址;
  4. 渲染热部署需要执行的脚本,渲染后的脚本也上传至 oss,返回 oss 访问地址;
  5. 组装热部署命令,并自动复制到粘贴板。

远程服务端热部署执行流程

  1. 登录远程服务器,粘贴热部署命令并执行;
  2. 下载热部署脚本,执行热部署脚本;
  3. 创建工作空间;
  4. 检查是否安装 openssl,没有安装则进行安装;
  5. 下载 AES-128 加密的 class 文件;
  6. 使用 openssl enc 解密得到 class 二进制文件;
  7. 通过脚本方式安装 arthas;
  8. 创建与 arthas 通信的管道并启动 arthas;
  9. arthas 选择 java 进程,默认选择第一个;
  10. arthas 执行 redefine 命令热替换 class 文件;
  11. 打印热替换结果。

Arthas 征文活动火热进行中

Arthas 官方正在举行征文活动,如果你有:

  • 使用 Arthas 排查过的问题
  • 对 Arthas 进行源码解读
  • 对 Arthas 提出建议
  • 不限,其它与 Arthas 有关的内容

欢迎参加征文活动,还有奖品拿哦~点击投稿

阿里巴巴云原生关注微服务、Serverless、容器、Service Mesh 等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,做最懂云原生开发者的公众号。”

相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
相关文章
|
8月前
|
Java 应用服务中间件
javaweb的热部署
javaweb的热部署
42 0
|
12月前
|
Java Maven Spring
Java 最常见的面试题:spring boot 有哪些方式可以实现热部署?
Java 最常见的面试题:spring boot 有哪些方式可以实现热部署?
|
Java
java热部署
热部署【devtools】 改完代码不需要重启,等待系统反应一两秒就可以
118 0
java热部署
|
Java
【Java】【SpringBoot】CP03:热部署
【Java】【SpringBoot】CP03:热部署
128 0
【Java】【SpringBoot】CP03:热部署
|
IDE Java 应用服务中间件
IDEA/Tomcat 原理:如何将 Tomcat 集成到 IDEA?实现由传统部署延伸到热部署 Java EE 项目?
IDEA/Tomcat 原理:如何将 Tomcat 集成到 IDEA?实现由传统部署延伸到热部署 Java EE 项目?
121 0
IDEA/Tomcat 原理:如何将 Tomcat 集成到 IDEA?实现由传统部署延伸到热部署 Java EE 项目?
|
XML 设计模式 前端开发
Java笔记:SpringBoot热部署与热加载
Java笔记:SpringBoot热部署与热加载
680 0
Java:Springboot 实现热部署的两种方式
Java:Springboot 实现热部署的两种方式
Java:Springboot 实现热部署的两种方式
|
Java 程序员
Java 项目热部署,节省构建时间的正确姿势
上周末,帮杨小邪(我的大学室友)远程调试项目。SpringBoot 构建,没有热部署,改一下就得重启相关模块。小小的 bug ,搞了我一个多小时,大部分时间都还在构建上(特么,下次得收钱才行)。我跟他说有个热部署插件叫 Jrebel,可以热部署,每次修改完代码需要测试的时候,只要 Build 一下就行?所有 Java 项目都能使用,他居然不知道。作为一个英俊男孩,我不得不写下这篇文章教他使用热部署。
Java 项目热部署,节省构建时间的正确姿势
|
Java 应用服务中间件 编译器
javaWeb第一天~搭建和部署javaWeb项目【简单部署和热部署】
javaWeb第一天~搭建和部署javaWeb项目【简单部署和热部署】
172 0
javaWeb第一天~搭建和部署javaWeb项目【简单部署和热部署】
|
Java 应用服务中间件 Android开发
IDEA 出现问题:tomcat热部署没反应解决方案(JAVA 小虚竹,建议收藏)
IDEA 出现问题:tomcat热部署没反应解决方案(JAVA 小虚竹,建议收藏)
587 0
IDEA 出现问题:tomcat热部署没反应解决方案(JAVA 小虚竹,建议收藏)