1. Spring boot 热部署配置
在开发过程中,当修改了某些代码后需要本地验证时,需要重启本地服务进行验证,启动这个项目,如果项目庞大的话需要比较长的时间,spring开发团队为我们带来了一个插件:spring-boot-devtools,很好的解决了本地验证缓慢的问题。
- 添加spring-boot-devtools热部署依赖启动器
在spring boot项目进行热部署测试之前,需要先在项目的pom.xml文件中添加 spring-boot-devtools热部署依赖启动器:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
由于使用的是IDEA开发工具,添加热部署依赖后可能没有任何效果,接下来还需要针对IDEA开发工具进行热部署相关功能配置
- IDEA工具热部署设置
选择IDEA工具界面的【Intelli J IDEA】---> 【Preferences】选项,打开Compiler面板设置页面
选择Build下的Compiler选项,在右侧勾选“Build project automatically”选项将项目设置为自动编译,单击【Apply】 --->【OK】按钮保存设置
在项目任意页面中使用组合快捷键“command+Shift+option+/” 打开Maintenance选项框,选中并打开Registry页面:
列表中找到“compiler.automake.allow.when.app.running”,将该选项后的value值勾选,用于指定IDEA工具在程序运行过程中自动编译,最后单击【Close】按钮完成设置
- 热部署效果测试
Controller代码
@RestController
@RequestMapping(produces = "application/json; charset=utf-8")
public class DemoController {
@RequestMapping("/demo")
public String demo() {
return "hello springboot";
}
@RequestMapping("/demo2")
public String demo2(String name,String hobby) {
System.out.println("name: " + name + " hobby: " + hobby);
return "开始卷起来。";
}
}
重启SpringBoot后台服务,打开浏览器器访问http://localhost:8080/demo 页面输出 “hello springboot”
为了测试配置的热部署是否有效,接下来,在不关闭当前项目的情况下,将DemoController类中的请求处理方法demo()的返回值修改成“ 热部署返回测试 ” 并保存,查看控制台信息会发现项目能够自动构建和编译,说明项目热部署生效。
可以看到浏览器输出了“ 热部署返回测试 ”,说明项目热部署配置成功
1.1. 热部署原理分析
热部署原理其实很好说明,就是我们在编辑器上启动项目,然后改动相关的代码,编辑器自动触发编译替换掉历史的 “.class” 文件后,项目检测到有文件变更后会重启Spring-Boot项目。
官方文档的触发描述:
可以看到,我们引入了插件后,插件会监控我们的classpath的资源变化,当classpath有变化后,会触发重启
这里提到了,该插件重启快速的原因:这里对类加载采用了两种类加载器,对于第三方jar包采用base-classloader来加载,对于开发人员自己开发的代码则使用restartClassLodader来进行加载,这使得比停掉服务重启要快的多,因为使用插件只是重启开发人编写的部分代码。
1.2. 排除资源
某些资源再更改后不一定要触发重新启动。例如,Thymeleaf模版可以就地编辑。默认情况下,改变资源/META-INF/maven,/META-INF/resources,/resources,/static,/public,或/templates不触发重新启动,但会触发现场重装。如果要自定义这些排除项,则可以使用该 spring.devtools.restart.exclude属性。例如,仅排除/static,/public 可以设置以下属性:
spring.devtools.restart.exclude=static/**,public/**