Springboot Devtools教程
好吧,使用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 |
从自动重新加载中排除资源
默认情况下,自动重新加载适用于以下路径:
/META-INF/maven
/META-INF/resources
/resources
/static
/public
/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.enabled = false |
使用触发器文件
每次更改文件时都可能需要自动重启,有时可能会因频繁重启而缩短开发时间。要解决此问题,您可以使用触发器文件。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 |