前言

后端开发的同学想必每天都在重复经历着修改代码、执行代码编译,等待……重启Tomcat服务,等待……最后测试发现还是有bug,然后上述流程再来一遍(我听不见)
能不能像前端开发的同学那样,修改代码保存文件后自动编译、重新加载应用呢?Spring Boot给了我们一个大大的Yes!
本文我们就一起来探索Spring Boot的热部署功能提升开发效率吧!

长话短说

热部署作为开发阶段的特性,由spring-boot-devtools模块提供,用于在修改类、配置文件和页面等静态资源后,自动编译Spring Boot应用和加载应用和页面静态资源,从而提高开发流程自动化程度提升开发效率。
那么第一步当然是在pom.xml中添加配置:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<option>true</option>
</dependency> <build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork> <!-- 默认值为false,必须设置为true才能启用热部署功能(具体原因请见下文) -->
</configuration>
</plugin>
</plugins>
</build>

静态资源热部署

对于HTML页面、图片、CSS样式文件这些显然不需要编译的静态资源,Spring Boot Devtools模块通过内置的livereload服务端和浏览器的LiveReload插件共同实现热部署。

  1. 服务端配置
spring:
devtools:
livereload:
enabled: true # 启用LiveReload服务端
port: 35729 # LiveReload服务端口

默认仅触发LiveReload事件的默认路径如下: /META-INF/maven,/META-INF/resources,/resources,/static,/public/templates

  1. 浏览器配置
    无论时FireFox还是Chrome都有相应的LiveReload插件,按步骤安装就可以了。

Java类资源热部署

Spring Boot Devtools模块是通过监听Java类资源变化触发应用热部署,请注意这里监听的是Java类资源而不是Java源代码文件,那么什么是Java类资源**呢?其实就是.class文件。
这样从保存Java源代码文件到Spring Boot Devtools监听到Java类资源变化之间,就有一道不可逾越的鸿沟了。我们必须通过额外手段填平:

  1. 手动方式:修改Java源代码文件后,执行mvn compile
  2. 自动方式:配置IDEA监听Java源代码文件变化,触发重新编译
    2.1. 右键点击SpringBootApplication入口类文件,并点击Create XXXX.main(),创建Application类型的Configuration;
    2.2. 勾选File/Settings/Compiler/Build Project automatically
    2.3. 按ctrl+shift+alt+/,然后选择Registry并勾选Compiler autoMake allow when app running
    2.4. 通过IDEA左上角绿色的运行按钮启动Spring Boot应用,然后修改Java源代码文件后IDEA会自动重新编译项目,从而触发Spring Boot Devtools热部署。

更多配置配置项

spring:
devtools:
restart:
enabled: true # 启用热部署
exclude: main/static/** # 除默认路径外,添加文件变化不触发热部署的路径列表,多个路径之间通过逗号分隔。
additional: assets/** # 添加文件变化会触发热部署的路径列表,多个路径之间通过逗号分隔。
additional-exclude: assets/public/** # 设置additional属性指定的路径下某些路径的文件变化,不触发热部署,多个路径之间通过逗号分隔。

默认不触发热部署的路径有:/META-INF/maven,/META-INF/resources,/resources,/static,/public/templates

除了通过yml文件配置是否启用热部署功能外,还可以通过环境变量设置。在SpringBootApplication入口方法中加入

System.setProperty("spring.devtools.restart.enabled", "false");
SpringApplication.run(MyApp.class, args);

疑难解答

  1. 在IDEA中修改文件后报 Maven Resource Compiler: Maven project configuration required for module 'lkm-api' isn't available. Compilation of Maven projects is supported only if build is started from an IDE.
    答:请使用IDEA那个绿色的运行按钮启动Spring Boot应用。
  2. 在IDEA中修改文件后没有反应
    答:请稍等数秒自然会触发重新编译和热部署的。

为什么是热部署而不是热替换呢?

开发过React或Vue的同学对热替换应该不陌生吧,可以粗线条地理解为将应用以比文件更细粒度的模块或函数来组织,当源代码发生变化时仅仅替换发生变化的模块或函数以及依赖它们的模块或函数,通过最小化变更达到快速更新应用状态。
而Spring Boot Devtools并没有做成像React和Vue的开发工具那么细粒度的更新,而是采取通过基类加载器重启类加载器两个类加载器来实现热部署:

  1. 基类加载器,用于加载第三方依赖等开发阶段不经常发生变化的Java类资源。
  2. 重启类加载器,用于加载当前项目的Java类资源。若当前项目的Java类资源发生变化时,正在运行的重启类加载器会被丢弃,并另外创建一个重启类加载器并加载最新的Java类资源。

为什么pom.xml文件中的spring-boot-maven-plugin要设置为独立JVM进程运行呢(<fork>true</fork>)?

默认情况下<fork>false</fork>表示Maven采用运行自身的JVM虚拟机运行插件,而通过<fork>true</fork>则告知Maven启动一个新的JVM虚拟机进程运行插件。
那么为什么要耗费资源启动新JVM虚拟机执行插件呢?直接运行不香吗?

场景1——使用不同的JDK运行插件

执行mvn -v会显示当前Maven运行的JDK版本信息,假设为JDK1.8且编码方式为UTF-8。
由于Maven 3.8.1必须运行在JDK1.8以上,而项目只能在JDK1.6上编译运行,因此需要通过如下方式执行插件:

<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<fork>true</fork>
<!-- 指定JDK家目录,默认为环境变量PATH中的路径 -->
<executable>/path/to/jdk1.6</executable>
<compilerVersion>1.3</compilerVersion>
</configuration>
</plugin>

场景2——采用不同的JVM配置运行插件

<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<fork>true</fork>
<meminitial>128m</meminitial>
<maxmem>1024m</maxmem>
<compilerArgs>
<arg>-XX:MaxPermSize=256m</arg>
</compilerArgs>
</configuration>
</plugin>

场景3——插件需要特定的JVM配置来运行

像spring-boot-maven-plugin那样在启用spring-boot-devtools模块时需要特定JVM配置来运行,并且运行途中还会对重启类加载器惨下杀手的,自然也要创建新的JVM虚拟机进程来运行才可以了。

总结

Spring Boot不单单通过约定由于配置的原则简化了过去Spring MVC那些繁琐的配置文件,还提供各种显著提升开发效率的自动化工具,而spring-boot-devtools就是其中一个。
倘若你所在的团队还没用上Spring Boot那么是不是就无法享受这份便捷呢?我想JRebel IDEA插件应该是你需要的:)

转载请注明来自:https://www.cnblogs.com/fsjohnhuang/p/14136491.html —— 肥仔John

SpringBoot魔法堂:应用热部署实践与原理浅析的更多相关文章

  1. springboot之DevTools热部署的简单原理解析

    IDEA新建springboot选择DevTools springboot-devtools模块能够实现热部署,添加类.添加方法,修改配置文件,修改页面等,都能实现热部署. 原理就是重启项目,但比手动 ...

  2. SpringBoot项目构建、测试、热部署、配置原理、执行流程

    SpringBoot项目构建.测试.热部署.配置原理.执行流程 一.项目构建 二.测试和热部署 三.配置原理 四.执行流程

  3. SpringBoot开发 - 什么是热部署和热加载?devtool的原理是什么?

    在SpringBoot开发调试中,如果我每行代码的修改都需要重启启动再调试,可能比较费时间:SpringBoot团队针对此问题提供了spring-boot-devtools(简称devtools)插件 ...

  4. SpringBoot+gradle+idea实现热部署和热加载

    前言 因为之前使用myeclipes的同学就知道,在使用myeclipes的时候,java文件或者jsp文件写完之后会被直接热加载到部署的容器中,从而在开发的时候,不同经常去重启项目,从而达到了增加开 ...

  5. SpringBoot笔记十七:热部署

    目录 什么是热部署 Devtools热部署 什么是热部署 热部署,就是在应用正在运行的时候升级软件,却不需要重新启动应用. 举个例子,王者荣耀的更新有时候就是热部署,热更新,就是他提示你更新,更新40 ...

  6. idea开启springboot的devtools自动热部署功能

    1.先在pom文件中添加下面代码段 <!-- 热部署 --> <dependency> <groupId>org.springframework.boot</ ...

  7. springboot在eclipse实现热部署

    eclipse使用spring-tool-suite插件创建springboot项目,项目创建完成后. 选中项目,右键 Spring Tools  --> Add Boot Devtools 点 ...

  8. Idea集成SpringBoot实现两种热部署方式(亲测有效)

    即将介绍的两种热部署方式: 1.SpringLoaded 2.DevTools 区别: SpringLoader:SpringLoader 在部署项目时使用的是热部署的方式. DevTools:Dev ...

  9. springboot集成mybatis(逆向工程),热部署以及整合Swagger2

    本文是作者原创,版权归作者所有.若要转载,请注明出处. springboot集成mybatis和mybatis-generator插件 1.新建Springboot项目(略) 2.导入相关依赖 < ...

随机推荐

  1. Annotation注解初识

    注解本质上就是一个接口,该接口默认继承Annotation接口 元注解 元注解的作用就是描述其他注解.Java1.5定义了4个标准的meta-annotation类型,它们被用来提供对其它 annot ...

  2. Windows上Jenkins插件下载慢解决方法

    替换文件内容 Jenkins/updates/default.json 替换 updates.jenkins-ci.org/download 为 mirrors.tuna.tsinghua.edu.c ...

  3. python-网络安全编程第五天(爬虫模块BeautifulSoup)

    前言 昨晚学的有点晚 睡得很晚了,今天早上10点多起来吃完饭看了会电视剧就瞌睡了一直睡到12.50多起来洗漱给我弟去开家长会 开到快4点多才回家.耽搁了不少学习时间,现在就把今天所学的内容总结下吧. ...

  4. 【appium】appium自动化入门之环境搭建(上)

     第 1 章 环境搭建 1.1 android-sdk 环境 前言 appium可以说是做app 适用最广泛的一个自动化框架,它的主要优势是支持android和ios ,另外脚本语言也是支持 java ...

  5. 厉害啊!第一次见到把Shiro运行流程写的这么清楚的,建议收藏起来慢慢看

    前言 shiro是apache的一个开源框架,是一个权限管理的框架,实现 用户认证.用户授权. spring中有spring security (原名Acegi),是一个权限框架,它和spring依赖 ...

  6. 带你体验Folx的智能化下载功能

    BT下载器,也就是种子下载器,其优点是下载的人越多,下载的速度就越快,可以更快速地下载热门资源.这是因为,每个下载种子的用户,在下载的同时,也会上传资源,从而加速其他用户的下载速度. Folx软件,作 ...

  7. MindManager主题标记功能怎么使用

    我们在使用MindManager制作思维导图的过程中,经常需要对主题的类别,优先程度等进行整理,毫无疑问,这是一项繁琐却又不得不做的工作.今天小编为大家带来了MindManager主题整理的一些小技巧 ...

  8. 追踪聚光特效怎么实现,有Vegas就够了

    舞台聚光灯大家一定都不陌生,在电视上某些颁奖活动里,主持人的进场一定伴随着舞台灯光的聚光效果.随着主持人的移动,灯光也随之移动.这里的舞台灯光就起到了一个追踪聚光的效果. Vegas Pro 16 增 ...

  9. python中操作excel数据 封装成一个类

    本文用python中openpyxl库,封装成excel数据的读写方法 from openpyxl import load_workbook from openpyxl.worksheet.works ...

  10. IdentityServer4系列 | 快速搭建简易项目

    一 .前言 从上一篇关于 常见术语说明中,主要是对IdentityServer4的说明,以及其中涉及常见的术语的表述说明,包括对身份认证服务器.用户.客户端.资源以及各个令牌等进行对比区别说明. 而在 ...