Springboot Devtools教程

如果您已经处理过最新的UI开发框架,例如Node,angular,gulp等,那么只要某些代码发生变化,您就必须了解在浏览器中自动重新加载UI。它非常实用,可以节省大量时间。

好吧,使用spring-boot-devtools依赖提供的功能可以在Springboot应用程序中使用相同的功能。让我们了解如何启用这些功能并使用它们。

启用Dev Tools Module

在Springboot程序中启用dev tools非常容易。只需spring-boot-devtools在构建文件中添加依赖项即可。

Maven

pom.xml

1
2
3
4
5
6
7
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <optional>true</optional>
    </dependency>
</dependencies>

Gradle

build.gradle

1
2
3
dependencies {
    compile("org.springframework.boot:spring-boot-devtools")
}

静态资源缓存

为了提高性能,开发工具缓存静态内容/模板文件,以便更快地为浏览器/客户端提供服务。这是生产中非常好的特性,每毫秒的性能改进都很重要。但是在开发环境中,它可能是一个问题并导致过时的缓存问题,您可能无法立即在浏览器中看到您的更改。开发工具模块通过设置少量属性来提供此功能。

默认情况下,此功能已禁用。您可以通过设置属性使其在生产环境中使用。有许多此类UI模板库支持此功能。例如thymeleaf, freemarker, groovy, mustache等。

application.properties

1
2
3
4
5
6
7
8
#spring.freemarker.cache = true //set true in production environment
spring.freemarker.cache = false //set false in development environment; It is false by default.
 
//Other such properties
 
spring.thymeleaf.cache = false
spring.mustache.cache = false
spring.groovy.template.cache = false

//Other such properties

spring.thymeleaf.cache = false
spring.mustache.cache = false
spring.groovy.template.cache = false

自动刷新VS自动重启

自动刷新(或自动加载)是指在浏览器上重新加载UI以查看静态内容更改。自动重启是指重新加载服务器端代码和配置,然后重新启动服务器。

静态资源自动加载

spring-boot-devtools模块包括一个嵌入式LiveReload服务器,可用于在更改资源时触发浏览器刷新。前提条件是您的浏览器应该支持它的扩展。您可以在此链接中找到此类浏​​览器扩展名。

默认情况下,启用实时重新加载。如果由于某种原因希望禁用此功能,请将spring.devtools.livereload.enabled属性设置为false

application.properties

1
spring.devtools.livereload.enabled  = false #Set false to disable live reload

从自动重新加载中排除资源

默认情况下,自动重新加载适用于以下路径:

  1. /META-INF/maven
  2. /META-INF/resources
  3. /resources
  4. /static
  5. /public
  6. /templates

如果要在浏览器中为少数这些路径中的文件禁用自动重新加载,请使用spring.devtools.restart.exclude属性。例如

1
spring.devtools.restart.exclude=static/**,public/**

查看/排除其他路径

或许很少有文件在classpath中,但您仍然可能希望查看这些附加文件/路径以重新加载应用程序。为此,请使用该spring.devtools.restart.additional-paths属性。

1
spring.devtools.restart.additional-paths=script/**

类似地,如果要保留这些默认值并添加其他排除项,请改用该spring.devtools.restart.additional-exclude属性。

1
spring.devtools.restart.additional-exclude=styles/**

服务端自动重启

自动重启意味着在服务器端重新加载java类和配置。在动态重新部署服务器端更改之后,服务器重新启动并加载修改后的代码和配置。

启用/禁用自动配置更改的日志记录

默认情况下,每次应用程序重新启动时,都会记录一个显示条件评估增量的报告。该报告显示了在进行更改(例如添加或删除Bean以及设置配置属性)时应用程序自动配置的更改。

要禁用报告的日志记录,请设置以下属性:

1
spring.devtools.restart.log-condition-evaluation-delta = false

禁用重启

要在非静态代码更改时禁用服务器重新启动,请使用该属性spring.devtools.restart.enabled

1
spring.devtools.restart.enabledfalse

使用触发器文件

每次更改文件时都可能需要自动重启,有时可能会因频繁重启而缩短开发时间。要解决此问题,您可以使用触发器文件。Spring启动将继续监视该文件,一旦它检测到该文件中的任何修改,它将重新启动服务器并重新加载以前的所有更改。

使用spring.devtools.restart.trigger-file属性及应用程序的触发器文件。它可以是任何外部或内部文件。

1
spring.devtools.restart.trigger-file = c:/workspace/restart-trigger.txt

全局settings文件

为您的所有springboot项目或模块设置所有您喜欢的配置选项可能会成为重复的工作。您可以使用全局设置文件将其最小化。然后,单个项目/模块将从全局文件继承所有自定义设置,如果需要,它们可以覆盖每个项目的任何特定设置。

要创建全局文件,请转到系统的用户主目录并创建一个名为的文件.spring-boot-devtools.properties。(请注意,文件名以点开头)。不使用此全局属性文件来配置全局可用选项。

.springboot,devtools.properties

1
spring.devtools.restart.trigger-file = c:/workspace/restart-trigger.txt

 

发表评论

登录后才能评论
关注我们