一、构建系统
依赖管理
每一个SpringBoot版本都提供了一个它所支持的依赖项列表。实际上,你不需要为构建配置中的任何依赖项提供版本,因为SpringBoot为你管理这些依赖项。当你升级SpringBoot本身时,这些依赖项也会以一致的方式升级。
如果需要的话,你仍然可以指定一个版本并覆盖SpringBoot的建议。
每个SpringBoot版本都与Spring框架的一个基本版本相关联。强烈建议你不要指定其版本
Maven
要使用SpringBoot Maven插件,请在pom.xml文件中加上:
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <!-- ... --> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>2.3.3.RELEASE</version> </plugin> </plugins> </build> </project>
如果你使用milestone或snapshot版本,还需要添加适当的pluginRepository元素,如果下表所示:
<pluginRepositories> <pluginRepository> <id>spring-snapshots</id> <url>https://repo.spring.io/snapshot</url> </pluginRepository> <pluginRepository> <id>spring-milestones</id> <url>https://repo.spring.io/milestone</url> </pluginRepository> </pluginRepositories>
使用插件
Maven用户可以从spring-boot-starter-parent父项目继承以获得合理的默认值。父项目提供以下功能:
- Java 1.8作为默认编译器级别。
- UTF-8编码。
- 从 spring-boot-dependencies POM继承的依赖项管理部分,用于管理公共依赖项的版本。这个依赖项可以让你忽略<version> 标签。
继承父POM
<!-- Inherit defaults from Spring Boot --> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.3.RELEASE</version> </parent>
你应该只需要为此依赖项指定SpringBoot版本号。如果导入其他启动器,则可以安全地省略版本号。
不继承使用Parent POM
你可能有理由不从spring-boot-starter-parent父POM继承。你可能需要使用自己的公司标准父级,或者你可能更愿意显式声明所有的Maven配置。
如果你不想使用spring-boot-starter-parent父级,你仍然可以通过使用导入范围的依赖项来保留依赖项管理(而不是插件管理)的好处,如下所示:
<dependencyManagement> <dependencies> <dependency> <!-- Import dependency management from Spring Boot --> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>2.3.3.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
前面的示例设置不允许你使用属性覆盖各个依赖项,如上所述。要获得相同的结果,你需要在项目的dependencyManagement部分添加条目,然后再添加springboot dependency条目。例如,要使用不同版本的SLF4J库和Spring数据发布系列,可以将以下元素添加到pom.xml文件:
<dependencyManagement> <dependencies> <!-- Override SLF4J provided by Spring Boot --> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.30</version> </dependency> <!-- Override Spring Data release train provided by Spring Boot --> <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-releasetrain</artifactId> <version>Moore-SR6</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>2.3.3.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
打包可执行文件
该插件可以创建包含应用程序所有依赖项的可执行文件(jar文件和war文件),然后可以使用java-jar运行。
<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>2.3.3.RELEASE</version> <executions> <execution> <goals> <goal>repackage</goal> </goals> </execution> </executions> </plugin> </plugins> </build>
如果你使用的是spring-boot-starter-parent,那么这样的执行已经预先配置了一个重新打包的执行ID,以便只添加插件定义。
上面的例子重新打包了在Maven生命周期的包阶段构建的jar或war归档,包括在项目中定义的任何提供的依赖项。如果需要排除其中一些依赖项,可以使用排除选项
默认情况下,Devtools被自动排除(你可以使用excludeDevtools属性控制它)。为了使其与war打包一起工作,springboot devtools依赖项必须设置为可选的或具有所提供的范围。
这个插件重写你的清单,特别是它管理主类和启动类条目。如果默认值不起作用,你必须在springboot插件中配置值,而不是在jar插件中。清单中的主类由Spring Boot插件的layout属性控制,如下例所示:
<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>2.3.3.RELEASE</version> <configuration> <mainClass>${start.class}</mainClass> <layout>ZIP</layout> </configuration> <executions> <execution> <goals> <goal>repackage</goal> </goals> </execution> </executions> </plugin> </plugins> </build>
layout属性默认为归档类型(jar或war)确定的值。以下布局可用:
- JAR:常规的可执行JAR layout
- WAR:可执行的WAR layout。提供的依赖项放在WEB-INF/lib中,以避免在将war部署到servlet容器中时发生任何冲突。
- ZIP:类似于使用PropertiesLauncher的JAR布局。
- NONE:捆绑所有依赖项和项目资源。不绑定引导加载程序。
分层JAR
重新打包的jar分别在BOOT-INF/classes和BOOT-INF/lib中包含应用程序的类和依赖项。对于需要从jar的内容构建docker映像的情况,能够进一步分离这些目录以便将它们写入不同的层是很有用的。
分层jar使用与常规重新打包的jar相同的布局,但包含描述每个层的附加元数据文件。要使用此功能,必须启用分层功能:
<project> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>2.3.3.RELEASE</version> <configuration> <layers> <enabled>true</enabled> </layers> </configuration> </plugin> </plugins> </build> </project>
默认情况下,将定义以下分层:
dependencies:对于其版本不包含快照的任何依赖项。
spring-boot-loader:jar loader classes
snapshot-dependencies:快照依赖项
application:classes and resources
自定义分层布局
根据应用程序的不同,你可能需要调整层的创建方式并添加新层。这可以使用单独的配置文件来完成,该文件应按如下所示进行注册:
<project> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>2.3.3.RELEASE</version> <configuration> <layers> <enabled>true</enabled> <configuration>${project.basedir}/src/layers.xml</configuration> </layers> </configuration> </plugin> </plugins> </build> </project>
配置文件描述了如何将jar分成层,以及这些层的顺序。以下示例显示如何显式定义上述默认顺序:
<layers xmlns="http://www.springframework.org/schema/boot/layers" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/boot/layers https://www.springframework.org/schema/boot/layers/layers-2.3.xsd"> <application> <into layer="spring-boot-loader"> <include>org/springframework/boot/loader/**</include> </into> <into layer="application" /> </application> <dependencies> <into layer="snapshot-dependencies"> <include>*:*:*SNAPSHOT</include> </into> <into layer="dependencies" /> </dependencies> <layerOrder> <layer>dependencies</layer> <layer>spring-boot-loader</layer> <layer>snapshot-dependencies</layer> <layer>application</layer> </layerOrder> </layers>
layers XML格式分为三个部分定义:
- <application>:应用程序类和资源应该如何分层。
- <dependencies>:依赖关系应该如何分层。
- <layerOrder>:层的写入顺序。
嵌套的<into>块在<application>和<dependencies>部分中用于声明层的内容。块按定义的顺序从上到下计算。任何未被较早块所声明的内容仍然可用于后续的块。
<into>块使用嵌套的<include>和<exclude>元素声明内容。<application>部分对include/exclude表达式使用Ant样式的补丁匹配。<dependencies>部分使用group:artifact[:version] 形式
如果未定义<include>,则考虑所有内容(不是由先前的块声明的)。
如果未定义<排除>,则不应用排除。
看看上面的<dependencies>示例,我们可以看到第一个<into>将声明快照依赖关系层的所有快照依赖项。随后的<into>将为依赖关系层声明任何剩余的内容(在本例中,不是快照的任何依赖项)。
<application>块有相似的规则。声明第一个org/springframework/boot/loader/**。然后为应用层声明所有剩余的类和资源。
定义<into>块的顺序通常与写入层的顺序不同。因此,必须始终包含<layerrorder>元素,并且必须覆盖<into>块引用的所有层。
启动器Starters
启动器是一组方便的依赖关系描述符,可以包含在应用程序中。你可以获得所需的所有Spring和相关技术的一站式服务,而不必搜索示例代码和复制粘贴大量依赖描述符。例如,如果你想开始使用Spring和JPA进行数据库访问,请在项目中包含spring-boot-starter-data-jpa依赖项。
启动器包含许多依赖项,你需要这些依赖项来快速启动和运行一个一致的、受支持的托管可传递依赖项集。
所有正式的启动器都遵循类似的命名模式;spring-boot-starter-*,其中*是一种特殊类型的应用程序。此命名结构用于在需要查找启动器时提供帮助。许多ide中的Maven集成允许你按名称搜索依赖项。例如,在安装了适当的Eclipse或STS插件后,你可以在POM编辑器中按ctrl空格键并键入“spring-boot-starter-*”以获得完整的列表。
第三方启动器不应该从spring-boot开始,因为它是为正式的spring-boot构件保留的。相反,第三方启动程序通常以项目名称开头。例如,名为thirdpartyproject的第三方starter项目通常被命名为thirdpartyproject-spring-boot-starter。
以下启动由group:org.springframework.boot提供:
- spring-boot-starter:核心启动器,核心启动程序,包括自动配置支持、日志记录和YAML。
- spring-boot-starter-activemq:使用Apache ActiveMQ的JMS
- spring-boot-starter-amqp:使用Spring AMQP 和 Rabbit MQ
- spring-boot-starter-aop:Spring AOP 和 AspectJ的切面编程
- spring-boot-starter-artemis:使用Apache Artemis的JMS
- spring-boot-starter-batch:使用Spring Batch
- spring-boot-starter-cache:使用Spring框架的缓存支持
- spring-boot-starter-data-cassandra:使用Cassandra分布式数据库和Spring Data Cassandra
- spring-boot-starter-data-cassandra-reactive:使用Cassandra分布式数据库和Spring Data Cassandra Reactive
- spring-boot-starter-data-couchbase:使用Couchbase面向文档数据库和 Spring Data Couchbase
- spring-boot-starter-data-couchbase-reactive:使用Couchbase面向文档数据库和 Spring Data Couchbase Reactive
- spring-boot-starter-data-elasticsearch:使用Elasticsearch和Spring Data Elasticsearch
- spring-boot-starter-data-jdbc:使用Spring Data JDBC
- spring-boot-starter-data-jpa:使用Spring Data JPA
- spring-boot-starter-data-ldap:使用Spring Data LDAP
- spring-boot-starter-data-mongodb:使用MongoDB面向文档数据库和Spring Data MongoDB
- spring-boot-starter-data-mongodb-reactive:使用MongoDB面向文档数据库和Spring Data MongoDB Reactive
- spring-boot-starter-data-neo4j:使用Neo4j 和Spring Data Neo4j
- spring-boot-starter-data-r2dbc:使用Spring Data R2DBC
- spring-boot-starter-data-redis:利用Spring Data Redis和Lettuce使用Redis内存数据库
- spring-boot-starter-data-redis-reactive:利用Spring Data Redis Reactive和Lettuce使用Redis内存数据库
- spring-boot-starter-data-rest:Spring Data REST暴露Spring Data repositories
- spring-boot-starter-data-solr:利用Spring Data Solr使用Apache Solr
- spring-boot-starter-freemarker:使用FreeMarker 构建MVC应用
- spring-boot-starter-groovy-templates:使用 Groovy Templates构建MVC应用
- spring-boot-starter-hateoas:使用Spring MVC 和 Spring HATEOAS构建基于超媒体的RESTful web应用程序
- spring-boot-starter-integration:使用 Spring Integration
- spring-boot-starter-jdbc:JDBC与HikariCP连接池一起使用
- spring-boot-starter-jersey:使用JAX-RS和Jersey构建RESTful web应用程序,spring-boot-starter-web的替代方案
- spring-boot-starter-jooq:使用jOOQ访问SQL数据库,spring-boot-starter-data-jpa 和 spring-boot-starter-jdbc的替代品
- spring-boot-starter-json:读写JSON
- spring-boot-starter-jta-atomikos:使用Atomics启动JTA事务
- spring-boot-starter-jta-bitronix:使用Bitronix启动JTA事务。自2.3.0起已弃用
- spring-boot-starter-mail:Java Mail和Spring框架的电子邮件发送支持
- spring-boot-starter-mustache:使用Mustache 构建Web 应用
- spring-boot-starter-oauth2-client:使用Spring Security的OAuth2/OpenID连接客户端
- spring-boot-starter-oauth2-resource-server:使用Spring Security的OAuth2资源服务器
- spring-boot-starter-quartz:使用Quartz任务调度
- spring-boot-starter-rsocket:构建RSocket客户端和服务端
- spring-boot-starter-security:使用Spring Security
- spring-boot-starter-test:用于测试带有JUnit、Hamcrest和Mockito库的Spring Boot应用程序
- spring-boot-starter-thymeleaf:使用Thymeleaf 构建MVC web应用
- spring-boot-starter-validation:在Hibernate验证器中使用javabean验证
- spring-boot-starter-web:使用Spring Mvc构建web,包括RESTful应用程序。使用Tomcat作为默认的嵌入式容器
- spring-boot-starter-web-services:使用Spring Web Services
- spring-boot-starter-webflux:使用Spring框架的Reactive Web 构建WebFlux应用程序
- spring-boot-starter-websocket:使用Spring框架的WebSocket 构建WebSocket 应用
以下启动器可以用于生产:
- spring-boot-starter-actuator:使用springboot的执行器,它提供了可用于生产的特性来帮助你监视和管理应用程
最后,springboot还包括以下启动器,如果你想排除或交换特定的技术方面,可以使用这些启动器:
- spring-boot-starter-jetty:使用Jetty作为嵌入式servlet容器。spring-boot-starter-tomcat的替代品
- spring-boot-starter-log4j2:使用Log4j2,spring-boot-starter-logging的替代品
- spring-boot-starter-logging:使用Logback进行日志记录。默认日志启动器。
- spring-boot-starter-reactor-netty:使用Reactor Netty作为嵌入式的HTTP服务器的启动器。
- spring-boot-starter-tomcat:使用Tomcat作为嵌入式servlet容器。使用的默认servlet容器starter
- spring-boot-starter-undertow:使用Undertow作为嵌入式servlet容器,spring-boot-starter-tomcat的替代品
二、构建代码结构
springboot不需要任何特定的代码布局来工作。但是,有一些最佳实践可以帮助你。
使用“default”包
当一个类不包含包声明时,它被认为在“default package”中。通常不鼓励使用“default package”,应避免使用。对于使用@ComponentScan、@ConfigurationPropertiesScan、@EntityScan或@SpringBootApplication注释的springboot应用程序来说,这可能会导致特定的问题,因为每个jar中的每个类都会被读取。
我们建议你遵循Java推荐的包命名约定,并使用反向域名(例如,com.example.project).
定位主应用程序类
我们通常建议你将主应用程序类放在根包中的其他类之上。@SpringBootApplication注释通常放在主类上,它隐式地为某些项定义了一个基本的“搜索包”。例如,如果你正在编写一个JPA应用程序,@SpringBootApplication注释类的包用于搜索@Entity项。使用根包还允许组件扫描仅应用于你的项目。
如果你不想使用@SpringBootApplication,那么它导入的@EnableAutoConfiguration和@ComponentScan注释定义了这种行为,因此你也可以使用它们。
下面的列表显示了一个典型布局:
com +- example +- myapplication +- Application.java | +- customer | +- Customer.java | +- CustomerController.java | +- CustomerService.java | +- CustomerRepository.java | +- order +- Order.java +- OrderController.java +- OrderService.java +- OrderRepository.java
Application.java 声明main方法和基本@SpringBootApplication,如下所示:
package com.example.myapplication; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }
三、 Configuration 类
SpringBoot支持基于Java的配置。尽管可以将SpringApplication与XML一起使用,但我们通常建议你的主要源代码是单个@Configuration类。通常,定义main方法的类是一个直接@Configuration的一个很好的候选类。
网上已经发布了许多使用XML配置的Spring配置示例。如果可能,请始终尝试使用等效的基于Java的配置,查找Enable*注解是一个很好的起点。
导入其他配置类
你不需要将所有的@Configuration放入一个类中。@Import注释可用于导入其他配置类。或者,可以使用@ComponentScan自动获取所有Spring组件,包括@Configuration类。
导入XML配置
如果你绝对必须使用基于XML的配置,我们建议你还是从@configuration类开始。然后可以使用@ImportResource注释来加载XML配置文件。
四、自动配置
springboot的自动配置会尝试根据你添加的jar依赖项自动配置Spring应用程序。例如,如果HSQLDB在类路径上,并且你没有手动配置任何数据库连接bean,那么springboot会自动配置内存中的数据库。
你需要通过在@configuration类中添加@EnableAutoConfiguration或@SpringBootApplication注释来选择自动配置。
你应该只添加一个@SpringBootApplication或@EnableAutoConfiguration注释。我们通常建议你只将其中一个添加到主@Configuration类中。
逐渐取代自动配置
自动配置是非侵害的。在任何时候,你都可以开始定义自己的配置来替换自动配置的特定部分。例如,如果你添加自己的DataSource bean,默认的嵌入式数据库支持就会退出。
如果你需要找出当前正在应用的自动配置以及原因,请使用--debug开关启动应用程序。这样做将启用所选核心记录器的调试日志,并将条件报告记录到控制台。
禁用特定的自动配置类
如果发现不需要的特定自动配置类正在被应用,可以使用@SpringBootApplication的exclude属性禁用它们,如下例所示:
import org.springframework.boot.autoconfigure.*; import org.springframework.boot.autoconfigure.jdbc.*; @SpringBootApplication(exclude={DataSourceAutoConfiguration.class}) public class MyApplication { }
如果类不在类路径上,则可以使用注释的excludeName属性并指定完全限定名。如果你喜欢使用@EnableAutoConfiguration而不是@SpringBootApplication,那么还可以使用excludeName。最后,还可以使用spring.autoconfigure.exclude属性。
即使自动配置类是公共的,该类唯一被认为是公共API的方面是可以用于禁用自动配置的类的名称。这些类的实际内容(如嵌套的配置类或bean方法)仅供内部使用,我们不建议直接使用。
五、Spring Beans和依赖注入
你可以自由使用任何标准Spring框架技术来定义bean及其注入的依赖项。我们经常发现,使用@ComponentScan(查找bean)和使用@Autowired(执行构造函数注入)效果很好。
如果按照上面的建议构造代码(将应用程序类定位在根包中),则可以添加不带任何参数的@ComponentScan。所有应用程序组件(@Component、@Service、@Repository、@Controller等)都自动注册为Spring Bean。
下面的示例显示了一个@Service Bean,它使用构造函数注入来获得所需的RiskAssessor Bean:
package com.example.service; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class DatabaseAccountService implements AccountService { private final RiskAssessor riskAssessor; @Autowired public DatabaseAccountService(RiskAssessor riskAssessor) { this.riskAssessor = riskAssessor; } // ... }
如果一个bean有一个构造函数,可以省略@Autowired,如下例所示:
@Service public class DatabaseAccountService implements AccountService { private final RiskAssessor riskAssessor; public DatabaseAccountService(RiskAssessor riskAssessor) { this.riskAssessor = riskAssessor; } // ... }
请注意,使用构造函数注入如何使riskAssessor字段标记为final,这表明它不能随后更改。
六、使用@SpringBootApplication注解
许多springboot开发人员喜欢他们的应用程序使用自动配置、组件扫描,并且能够在他们的“应用程序类”上定义额外的配置。一个@SpringBootApplication注释可用于启用这三个功能,即:
- @EnableAutoConfiguration:启用springboot的自动配置机制
- @ComponentScan:在应用程序所在的包上启用@Component scan
- @Configuration:允许在上下文中注册额外的bean或导入额外的配置类
package com.example.myapplication; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication // same as @Configuration @EnableAutoConfiguration @ComponentScan public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }
@SpringBootApplication还提供别名来定制@EnableAutoConfiguration和@ComponentScan的属性。
这些功能都不是必需的,你可以选择用它启用的任何功能来替换这个单一的注释。例如,你可能不希望在应用程序中使用组件扫描或配置属性扫描:
package com.example.myapplication; import org.springframework.boot.SpringApplication; import org.springframework.context.annotation.ComponentScan import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Import; @Configuration(proxyBeanMethods = false) @EnableAutoConfiguration @Import({ MyConfig.class, MyAnotherConfig.class }) public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }在这个例子中,Application和任何其他springboot应用程序一样,除了@Component注释的类和@ConfigurationProperties注释的类都不会被自动检测,并且用户定义的bean是显式导入的(@Import)
七、运行你的Application
IDE上运行
作为打包应用程序运行
如果使用Spring Boot Maven或Gradle插件创建可执行jar,则可以使用java-jar运行应用程序,如下例所示:
$ java -jar target/myapplication-0.0.1-SNAPSHOT.jar
还可以在启用远程调试支持的情况下运行打包应用程序。这样可以将调试器附加到打包的应用程序,如下例所示:
$ java -Xdebug -Xrunjdwp:server=y,transport=dt_socket,address=8000,suspend=n
-jar target/myapplication-0.0.1-SNAPSHOT.jar
使用Maven Plugin
springboot maven插件包含一个运行目标,可以用来快速编译和运行应用程序。应用程序以分解的形式运行,就像在IDE中一样。以下示例显示了运行Spring Boot应用程序的典型Maven命令:
$ mvn spring-boot:run
你可能还需要使用MAVEN_OPTS操作系统环境变量,如下例所示:
$ export MAVEN_OPTS=-Xmx1024m
热部署
由于springboot应用程序是普通的Java应用程序,JVM热交换应该是开箱即用的。JVM热交换在某种程度上受限于它可以替换的字节码。对于更完整的解决方案,可以使用JRebel。
spring-boot-devtools模块还支持快速应用程序重启。
八、开发者工具
springboot包括一组附加的工具,可以使应用程序开发体验更愉快一些。spring-boot-devtools模块可以包含在任何项目中,以提供额外的开发时特性。要包含devtools支持,请将模块依赖项添加到您的构建中,
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional> </dependency> </dependencies>
运行完全打包的应用程序时,开发人员工具将自动禁用。如果您的应用程序是从java-jar启动的,或者是从一个特殊的类加载器启动的,那么它就被认为是一个“生产应用程序”。如果这不适用于您(即,如果您从容器运行应用程序),请考虑排除devtools或设置-Dspring.devtools.restart.enabled=false的系统属性。
在Maven中将依赖项标记为可选,可以防止devtools被传递地应用到使用您的项目的其他模块。
默认情况下,重新打包的存档不包含devtools。如果您想使用某个远程devtools特性,则需要包含它。使用Maven插件时,将excludeDevtools属性设置为false。
属性默认值
springboot支持的一些库使用缓存来提高性能。例如,模板引擎缓存已编译的模板,以避免重复解析模板文件。另外,springmvc可以在提供静态资源时向响应添加HTTP缓存头。
虽然缓存在生产中非常有益,但在开发过程中它可能会适得其反,使您无法看到刚刚在应用程序中所做的更改。因此,spring-boot-devtools默认情况下禁用缓存选项。
缓存选项通常由application.properties文件。例如,Thymeleaf提供spring.thymeleaf.cache属性。spring-boot-devtools模块不需要手动设置这些属性,而是自动应用合理的开发时配置。
因为在开发springmvc和springwebflux应用程序时需要更多关于web请求的信息,开发人员工具将为web日志记录组启用调试日志记录。这将为您提供有关传入请求、哪个处理程序正在处理它、响应结果等的信息。如果您希望记录所有请求详细信息(包括潜在的敏感信息),可以打开 spring.mvc.log-request-details或spring.codec.log-request-details配置属性。
如果不希望应用属性默认值,可以在application.properties设置spring.devtools.add为false。
有关devtools应用的属性的完整列表,请参阅DevToolsPropertyDefaultsPostProcessor。
自动重启
当类路径上的文件发生变化时,使用springboot devtools的应用程序会自动重新启动。在IDE中工作时,这可能是一个有用的特性,因为它为代码更改提供了一个非常快速的反馈循环。默认情况下,类路径上指向某个目录的任何条目都会被监视以进行更改。请注意,某些资源(如静态资产和视图模板)不需要重新启动应用程序。
DevTools依赖于应用程序上下文的关闭钩子在重新启动期间关闭它。如果您禁用了关闭挂钩,它将无法正常工作(SpringApplication.setRegisterShutdownHook(错误))。
当决定类路径上的某个条目在更改时是否应该触发重新启动时,DevTools会自动忽略名为spring-boot、spring-boot-devtools、spring-boot-autoconfigure、spring-boot-actuator和spring-boot-starter的项目。
DevTools需要定制ApplicationContext使用的ResourceLoader。如果您的应用程序已经提供了一个,它将被包装。不支持直接重写ApplicationContext上的getResource方法。
打包应用程序上生产
可执行jar可用于生产部署。由于它们是自包含的,因此也非常适合基于云的部署。
可以考虑使用spring-boot-actuator进行应用程序的运行监控等。