一、什么是热部署
热部署,就是在应用正在运行的时候升级软件(增加业务/修改bug),却不需要重新启动应用。
大家都知道在项目开发过程中,常常会改动页面数据或者修改数据结构,为了显示改动效果,往往需要重启应用查看改变效果,其实就是重新编译生成了新的Class文件,这个文件里记录着和代码等对应的各种信息,然后Class文件将被虚拟机的ClassLoader
加载。
而热部署正是利用了这个特点,它监听到如果有Class 文件改动了,就会创建一个新的 ClaassLoader进行加载该文件,经过一系列的过程,最终将结果呈现在我们眼前,Spring Boot通过配置DevTools工具
来达到热部署效果。
在原理上是使用了两个ClassLoader,一个ClassLoader加载那些不会改变的类(第三方Jar包),另一-个
ClassLoader加载会更改的类,称为restart ClassLoader
,这样在有代码更改的时候,原来的restart ClassLoader被丢弃,重新创建一一个 restart ClassLoader,由于需要加载的类相比较少,所以实现了较快的重启时间。
二、热部署环境配置与测试
1.配置devtools环境
(1)在springboot项目中添加devtools依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<version>2.7.0</version>
</dependency>
(2)同时在plugin中添加devtools生效标志:
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.7.0</version>
<configuration>
<fork>true</fork>
</configuration>
</plugin>
devtools可以实现页面热部署( 即页面修改后会立即生效,这个可以直接在application.properties文件中配置spring.thymeleaf.cache=false
来实现) , 实现类文件热部署(类文件修改后不会立即生题), 实现对属性 文件的热部署。
即devtools会监听classpath下的文件变动,并且会立即重启应用(发生在保存时机
),注意:因为其采用的虚拟机机制,该项重启是很快的。配置了后在修改java文件后也就支持了热启动,不过这种方式是属于项目重启. (速度比较快的项目重启), 会清空session中的值,也就是如果有用户登陆的话,项目重启后需要重新登陆。
默认情况下,/META-INF/maven, /META-INF/resources, /resources, /static, /templates, /public
这些文件夹下的文件修改不会使应用重启,但是会重新加载( devtools内嵌了- -个LiveReload server,当资源发生改变时,浏览器刷新)
2.全局配置文件配置
在application.yml文件中配置spring.devtools.restart.enabled
,如下:
#开启热部署
devtools:
restart:
enabled: true
###设置重启的目录
additional-paths: src/main/java
###解决项目自动重新编译后接口报404的问题
poll-interval: 3000
quiet-period: 1000
3.idea设置
当我们修改了Java类后,IDEA 默认是不自动编译的,而spring boot devtools又是监测classpath下的文件发生变化才会重启应用,所以需要设置IDEA的自动编译。
(1)自动编译配置
将箭头所指的地方打钩,让项目自动编译。
(2)2021版本的idea在这里设置允许自动修改选项
4.测试
在项目运行的时候修改代码,我们可以发现并没有重启按钮,但是项目自动重新构建了,这说明热部署已经成功了。(截图没放上来)。
我们还可以手动构建,通过按键ctrl+F9
可以手动热部署。