目录

目录

1.什么是热部署

1.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)是指在应用程序运行过程中,对部分代码或资源进行修改后,无需停止整个应用程序就可以立即生效的一种技术。热部署通常用于开发和测试环境,可以节省时间和提高效率,让开发人员可以更快地验证代码修改的效果。在生产环境中,热部署也可以用于修复一些轻微的问题或更新应用程序的部分功能,避免整个应用程序停机时间过长导致的影响。

1.1.热启动与热部署的区别

热启动是指在已经运行的项目上,再次启动(比如说,做了修改代码),少加载了一些东西,从而启动的比快,节省开发时间。
热部署会启动自动加载修改代码的部分。
而idea 本身不支持热部署,需要在idea中安装插件

2.为什么需要热部署

我们研发同学在日常开发调试阶段经常会遇到下面一些情况:

  1. spring bean中的属性遗漏@Resource或者@Autowired注解
  2. mybatis sql配置文件中的sql编写错误
  3. 实体类中增加(修改或者删除)属性导致Fastjson、Jackson无法正常序列化和反序列化
  4. 方法签名需要增加一个参数或者需要增加一个CheckedException的申明
  5. 类中增加静态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

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐