目录
1.什么是热部署
2.为什么需要热部署
3.热部署产品
3.1.JRebel
3.2.IDEA HotSwap
3.3.HotSwapAgent
3.4.Spring Boot DevTools
3.5.FastHotSwapper
4.FastHotSwapper安装使用
参考:
1.什么是热部署
热部署(Hot Deployment)是指在应用程序运行过程中,对部分代码或资源进行修改后,无需停止整个应用程序就可以立即生效的一种技术。热部署通常用于开发和测试环境,可以节省时间和提高效率,让开发人员可以更快地验证代码修改的效果。在生产环境中,热部署也可以用于修复一些轻微的问题或更新应用程序的部分功能,避免整个应用程序停机时间过长导致的影响。
2.为什么需要热部署
我们研发同学在日常开发调试阶段经常会遇到下面一些情况:
- spring bean中的属性遗漏@Resource或者@Autowired注解
- mybatis sql配置文件中的sql编写错误
- 实体类中增加(修改或者删除)属性导致Fastjson、Jackson无法正常序列化和反序列化
- 方法签名需要增加一个参数或者需要增加一个CheckedException的申明
- 类中增加静态Logger属性以增加日志输出
上面所列举的一些场景,我们研发同学必须通过重启服务(如tomcat)才能够使修改的代码生效。对于一些小型的系统重启一次可能只需要花费1分钟左右的时间,而对于大型系统重启一次往往需要5分钟左右。如果系统中大量使用到了dubbo、mq等技术,由于启动过程中需要建立大量的连接,重启所花费的时间可能会更长。据统计,研发同学每天大概需要重启服务10-20次。频繁的重启服务,严重影响了研发同学开发、调试的节奏,影响整体的工作效率。
热部署技术正是为了解决这一问题,热部署能够使研发人员对代码的绝大部分修改都能够立即生效。在不重启应用程序的情况下快速测试和调试代码,帮助研发减少频繁的重启服务次数,节省碎片化的时间。
避免应用程序因为更新而需要停机维护,从而提高了应用程序的可用性和稳定性。
3.热部署产品
目前市面上成熟的热部署产品不是特别多,主要有JRebel、IDEA HotSwap、HotSwapAgent、Spring Boot DevTools,都可以实现代码的热部署。
3.1.JRebel
一款功能强大的热部署收费产品,以IDEA作为用户操作入口,生态较为庞大,基本上覆盖了Java生态下主流技术框架的热部署。其主要的缺点就是国产框架(fastjson、mybatis-plus等)基本上都不支持,并且是一款收费产品,需要破解。
3.2.IDEA HotSwap
IDEA自带的热部署,能力相对较弱,仅支持方法体的变更。诸如增加属性、增加方法、修改类的继承关系等变更类结构的操作都是被禁止的,并且spring、mybatis等Java主流框架均不支持。支持的场景非常有限,功能较为单一,难以满足研发同学的日常开发。
3.3.HotSwapAgent
一款免费开源的热部署Agent(github.com/HotswapProj… 国外团队开发的,同样也是不支持国产框架,但是由于其是完全免费开源的,我们可以基于它进行二次开发来支持国产框架的热部署。也正是因为是免费开源的,通过深入研究其源代码,发现其很多热部署场景支持的都存在一些问题,包括mybatis代理接口,spring框架整体支持上都存在一些问题。
标准的JVM在运行时只允许修改类的方法体,不允许修改类结构。HotSwapAgent团队为了解决这一来自JVM的限制研发了DCEVM补丁(github.com/dcevm/dcevm… 该补丁允许研发同学在运行期对类进行任何修改。也正是由于这一补丁的出现,使得真正意义上的热部署得以被实现(JRebel本质上也是使用类似的技术手段)。
3.4.Spring Boot DevTools
Spring Boot DevTools只能应用在Spring Boot项目中,并且它不是增量热部署,而是通过Classloader迭代的方式重启项目,对大项目而言,性能上是无法接受的。准确来说Spring Boot DevTools并非一个严格意义上的热部署产品。
3.5.FastHotSwapper
目前市面上的热部署产品大部分都是国外团队研发的,缺少对国产技术框架的支持。FastHotSwapper正是为了弥补这一空缺,为广大研发同学提供一款功能强大、简单易用、支持国产框架、免费的热部署产品。
FastHotSwapper旨在提高开发效率。简而言之:修改可以立即生效,而无需在整个编码过程中重新启动应用程序。 具体来说,可以在应用程序运行时升级软件,而无需重新启动
FastHotSwapper是一款IDEA热部署插件。其核心(Agent部分)是基于HotSwapAgent做了二次开发,对spring、mybatis、tomcat、cglib等主流技术框架进行了深度的优化,同时对一些主流的国产框架进行了热部署支持,例如apollo、mybatis-plus、tk-mybatis、Fastjson等。并以IDEA作为用户的操作入口,提升热部署整体的易用性。
4.FastHotSwapper安装使用
详情可以参考: plugins.jetbrains.com/plugin/2064…
1)热部署插件安装
2)安装dcevm
1、从下面列表下载jdk8对应版本的DCEVM补丁。补丁要jdk的版本要一一对应,否则会导致jdk崩溃。
FastHotSwapper - IntelliJ IDEs Plugin | Marketplace
2、执行安装命令 mac操作系统或者linux操作系统直接打开terminal运行下面命令
cd dcevm所在目录
sudo java -jar dcevm-light-java8u192.jar
windows操作系统,首先以管理员身份打开cmd,然后执行下面命令,尽可能不在C盘执行命令
cd dcevm所在目录
java -jar dcevm-light-java8u192.jar
命令执行完成之后便可以弹出下图所示的可视化操作界面。
需要在jdk和jre上同时安装补丁,点击右下角按钮:Install DCEVM as altjvm,然后关闭界面即可。
3)运行java -XXaltjvm=dcevm -version验证安装结果,出现 "Dynamic Code Evolution"字符串则表示安装成功
DCEVM要求应用的垃圾收集器必须为SerialGC(java8默认收集器),安装该补丁后会导致非SerialGC的应用无法启动
4)关闭IDEA的热部署能力,Build,Execution,Deployment > Debug > HotSwap Reload classes after compilation选择Never。
IDEA自带的热部署只能够支持方法体的变更,无法做到spring、mybatis等框架的动态重载,所以这里禁用IDEA自带的热部署功能。
5)热部署启动
debug启动目标应用程序,目前只支持以debug启动的应用程序。
web容器目前只支持tomcat和jetty,以其他容器部署的应用则不支持热部署。
如出现以下关键信息,代表agent已生效,服务启动成功后,即可体验热部署了
6)热部署操作
当完成编码之后,可以在运行中选项卡中打开热部署面板,校验变更文件列表(如果缺少文件,可以打开该文件使用"ctrl+s"保存一下),然后点击OK按钮便可开始热部署。
同样可以使用默认的快捷键(ctrl+alt+9)来一键开始热部署
7)热部署完成
小结:总的来说非常好用,支持XML文件中的sql热部署,但是目前发现不支持2023.3的idea 中的新版ui,如果不使用新版UI应没有问题
参考:
https://juejin.cn/post/7178798474702356540