以 Java 8 为基准
Spring Boot 2.0 要求 Java 版本必须 8 以上, Java 6 和 7 不再支持。
内嵌容器包结构调整
为了支持 reactive 使用场景,内嵌的容器包结构被重构了的幅度有点大。
EmbeddedServletContainer 被重命名为 WebServer,并且
org.springframework.boot.context.embedded 包被重定向到了
org.springframework.boot.web.embedded 包下。举个例子,如果你要使用
TomcatEmbeddedServletContainerFactory 回调接口来自定义内嵌 Tomcat 容器,
你现在应该使用 TomcatServletWebServerFactory。
Servlet-specific 的 server properties 调整
大量的 Servlet 专属的 server.* properties
被移到了 server.servlet
下:
由此可以看出一些端倪,那就是 server 不再是只有 servlet 了,还有其他的要加入。
Actuator 默认映射
Actuator 的端点(endpoint)现在默认映射到 /application,
比如,/info 端点现在就是在 /application/info。但你可以使用 management.context-path 来覆盖此默认值。
@ConditionalOnBean
@ConditionalOnBean 现在的判断条件由 OR 变为了 AND。
Remote CRaSH shell
1.5 的时候此远程工具被标为 deprecated,2.0 的时候将会把这个支持彻底 remove 掉,以及基于此功能的项目也会被删除掉。
Spring Loaded 不再支持
由于 Spring Loaded 项目已被移到了 attic 了,所以不再支持 Spring Loaded 了。现在建议你去使用 Devtools。Spring Loaded 不再支持了。
Hazelcast 自动配置不再支持
不能再自动配置 HazelcastInstance 进行缓存。 因此,spring.cache.hazelcast.config 属性不再可用。
默认 connection pool 变了
默认的连接池已经由 Tomcat 切换到了 HikariCP。如果你过去使用 spring.datasource.type 在基于 Tomcat 的应用程序中强制使用 Hikari,现在你可以删除这个覆盖了。同样的,如果想要使用 Tomcat 的连接池,只需要简单的加入以下配置就可以了:
spring.datasource.type=org.apache.tomcat.jdbc.pool.DataSource
Servlet Filters
针对一个 Filter 默认的 dispatcher 类型现在为 DipatcherType.REQUEST,这样就保证了 Spring Boot 和 Servlet 默认的配置统一了。
Spring Security
Spring Security 的 filter 现在可以自动配置如下类型了: ASYNC, ERROR, and REQUEST 。这样就让 Spring Boot 中的配置和 Spring Security 默认配置保持一致了。
Spring Session
Spring Session 的 filter 现在支持自动配置如下 dispatcher 类型 ASYNC, ERROR, and REQUEST 。同样是为了让 Spring Boot 的配置与 Spring Session 的默认配置保持一致。值得注意的是从 Spring Session 2.0
起, Mongo 和 GemFire 将不再被支持。
Jetty
要求 Jetty 最低版本为 9.4。
Tomcat
要求 Tomcat 最低版本为 8.5。
Hibernate
要求 Hibernate 最低版本为 5.2。
Gradle
要求 Gradle 最低版本为 3.4。
SendGrid
SendGrid 最低支持版本是 3.2。为了支持这次升级,username 和 password 已经被干掉了。因为 API key 现在是唯一支持的认证方式。
Starter 的传递依赖的改变
以前有几个 Spring Boot starter 是依靠 Spring MVC 和 spring-boot-starter-web 传递的。
为了对 Spring WebFlux 的支持,
spring-boot-starter-mustache 和 spring-boot-starter-thymeleaf 不再依赖 spring-boot-starter-web。
现在你要自己选择并添加 spring-boot-starter-web 或 spring-boot-starter-webflux 作为依赖。
记住:web 和 webflux 是平行的关系。我们之前的文章中提到过 spring webflux。你可以移步查看:Spring 5 新增全新的 reactive web 框架
:webflux。
Solr 健康指标
针对 Solr 的健康检查信息不再是 solrStatus 这个属性了。现在是 status property,是一个标准状态属性,对应于一个的整型值。
默认代理策略
Spring Boot 现在默认是使用 CGLIB 代理,同时包含 AOP 支持。如果你需要基于代理(proxy-based)的代理策略,你需要把 spring.aop.proxy-target-class 设置为 false。
基于 CLI 的测试
从 Spring Boot 的 CLI 中删除了测试支持,现在建议你使用 Maven 或 Gradle 构建应用程序,去使用它们提供的丰富的测试支持吧。
@ConfigurationProperties
@ConfigurationProperties 里的 ignoreNestedProperties 属性已被删除。
Multipart 配置改变
为了更好的反映 Servlet 的特性, spring.http.multipart. 属性已经被命名为 spring.servlet.multipart
。
ps:其实就是因为 webflux 来了,只能把 servlet 和 webflux 区分开来。
Mustache 模板默认文件扩展名
过去 Mustache 模板的默认的文件扩展名是.html。现在.mustache 成了官方指定的扩展名,而且很多的 IDE 插件已经支持了此后缀。你可以通过 spring.mustache.suffix 来覆盖现在的默认的支持。
Spring Framework 5.0
Spring Boot 2.0 是建立在 Spring Framework 5.0 之上的(最低要求)。Spring 5 最大的亮点就是 reactive。
松绑定改善
松绑定已经得到改善。这里简单的举个例子:
简单的属性在删除特殊字符然后转成小写后进行绑定。比如:
下面的属性最终都会被映射为 spring.jpa.databaseplatform=mysql:
spring.jpa.database-platform=mysql
spring.jpa.databasePlatform=mysql
spring.JPA.database_platform=mysql
有关详细信息,我们可以查阅:https://github.com/spring-projects/spring-boot/wiki/Relaxed-Binding-2.0
WebFlux 和 WebFlux.fn 支持
Spring Boot 2.0 提供了一个新的 starter ,用来支持 Reactive Spring web frameworks。该 starter 为 spring-boot-starter-webflux
。其中 Reactor Netty 是默认的 web 引擎(spring-boot-starter-reactor-netty)。
Reactive 数据库支持
Spring Boot 2.0 对一下的数据库提供了自动配置( auto-configuration )的 reactive 的支持:
* MongoDB (spring-boot-starter-data-mongodb-reactive)
* Redis (spring-boot-starter-data-redis-reactive)
* Cassandra (spring-boot-starter-data-cassandra-reactive)
@DataMongoTest 测试注解也是支持 reactive 的。
@WebFluxTest 支持
Reactive controller 现在可以使用 @WebFluxTest 来测试。它提供的功能和 @WebMvcTest 类似。而且 WebTestClient 可以直接使用,已经被自动配置(auto-configured)了。
支持使用 @SpringBootTest 自动配置 WebTestClient
当你使用 @SpringBootTest with an actual server
(that is, either DEFINEDPORT or RANDOMPORT), a WebTestClient is available the same way TestRestTemplate is.
使用 @SpringBootTest 进行 WebTestClient 自动配置
将 @SpringBootTest 用于实际服务器(即 DEFINEDPORT 或 RANDOMPORT)时,
WebTestClient 的可用方式与 TestRestTemplate 相同。
Gradle 插件
Spring Boot 的 Gradle 插件已在很大程度上被重写,以实现一些重大的改进。有关这方面的就不细讲了,感兴趣的同学可以去一探究竟。
/loggers 端点 POST 的状态码改变
针对 /loggers 端点上 POST 操作的状态码已又 200 改为 204。
Elasticsearch
Elasticsearch 已升级到 5.4。 与 Elastic 公司宣布不再支持嵌入式 Elasticsearch 的情况一样,NodeClient 的自动配置已被删除。就是这么的节奏一致。现在你可以通过使用 `spring.data.elasticsearch.cluster-nodes 自动配置 TransportClient,具体 value 可以是一个或多个要连接的节点的地址。
Quartz Scheduler
Spring Boot 2 针对 Quartz 调度器提供了支持。你可以加入 spring-boot-starter-quartz starter 来启用。而且支持基于内存和基于 jdbc 两种存储。
Spring Data Web 配置
Spring Boot 公开了一个新的 spring.data.web 配置名称空间,可以轻松配置分页和排序。
Json starter
一个全新的 spring-boot-starter-json starter 聚合了很多常用的 json 工具,可以支持对 json 的读写。
它不仅仅提供了 jackson-databind 而且当你使用 java8 时候,
还提供了有用的模块:
jackson-datatype-jdk8, jackson-datatype-jsr310 和 jackson-module-parameter-names。
之前使用 jackson-databind 的地方就可以使用这个新的 starter 了。
Thymeleaf starter
Thymeleaf starter 现在包含了 thymeleaf-extras-java8time,开箱即用。
InfluxDB
如果 InfluxDB java client 和 the spring.influx.url 被设置, 一个 InfluxDB client 现在就会被自动配置。而且现在支持认证。
JdbcTemplate
Spring Boot 自动配置(auto-configuration)的 JdbcTemplate 现在可以通过 spring.jdbc.template 命名空间进行定制。 此外,自动配置(auto-configuration)的 NamedParameterJdbcTemplate 在底层就是 JdbcTemplate。
jOOQ
Spring Boot 现在可以根据 DataSource 自动检测出 jOOQ 方言(类似于 JPA 方言)。
此外,还引入了 @JooqTest 用于只有 jOOQ 才能 hold 的测试场景。
@DataRedisTest
新加了一个测试的时候针对 redis 的新注解。
强大的 Mongo 客户端自定义
现在可以通过 MongoClientSettingsBuilderCustomizer 这个 bean 来高度定制化 Spring Boot 的 Mongo 客户端。
Cassandra
spring.data.cassandra 现在支持池化(pooling)。
Kafka listener 支持批量消费
现在支持一次性批量消费多个 ConsumerRecord,你可以创建一批的监听器(listener),这样设置:
spring.kafka.listener.type=batch
Web filters 初始化
Web filters 现在在所有支持的容器中都会被立刻初始化。也就是 eagerly,急加载。
Auto-configuration 报告
现在不满足条件(unconditional)的 class 也会被包含进来,在自动配置(auto-configuration)的 Actuator 端点的 response 中一并返回。
重置 logger 操作
现在 Loggers 端点(endpoint) 支持 reset 日志级别到默认设置。
Maven 插件属性
插件的配置属性现在的暴露方式有所改变,现在所有的都是以 spring-boot 为前缀,这是为了避免和其他插件冲突而导致错误。
比如,以下命令行可以启用 profile foo:
mvn spring-boot:run -Dspring-boot.run.profiles=foo
Devtools 远程调试
已经从 Devtools 中删除了通过 HTTP 进行远程调试的支持。(#9489)
Jetty
为了和 Tomcat 和 Undertow 看齐,现在对 Jetty 的所有的 http method 的请去都进行压缩,而不是之前那样只对 GET request 进行压缩(#8184)。
Reactive server 自定义
当配置一个 reactive web server 时,针对 Jetty,Tomcat,Undertow 的定制化器现在会被调用 (#9572)。
Jolokia
Jolokia 不再是一个 endpoint。并且默认是禁用的,这已和其他的 web 端点保持了一直。它的配置已转移到了 management.jolokia。如果想启用 Jolokia, 向你的配置加入 management.jolokia.enabled=true
就可以了。
数据库迁移
Liquibase 和 Flyway 配置的 key 已被转移到了 spring 的命名空间下:(比如: spring.liquibase and spring.flyway )。
Auto-configuration 排序
@AutoConfigureOrder 默认值由 Ordered.LOWEST_PRECEDENCE 变为 0。 (#10142)
Auto-configuration 测试工具
一个新的 ApplicationContextRunner 测试工具让我们测试自动配置变得容易。 未来将会把所有的测试套件都迁移到这个模型上。
Java 9 支持
基本支持了 Java 9。之所以是“基本”,是因为还没得到用户的验证。
Jedis 变为了 Lettuce
Redis 客户端驱动现在由 Jedis 变为了 Lettuce。使用 Jedis 的同学们,大概知道方向了吧。
但仍然支持 Jedis,那么 exclude 掉 io.lettuce:lettuce-core,然后添加 redis.clients:jedis 就是了。
OAuth 2.0 支持
Spring Security OAuth 项目中的功能将会迁移到 Spring Security 中。将会 OAuth 2.0。
Mockito 1.x
Mockito 1.x 不再支持 @MockBean 和 @SpyBean。
如果你不使用 spring-boot-starter-test 来管理依赖关系,则应升级到 Mockito 2.x。
JSON-B 支持
除了 Jackson 和 Gson,现在还支持了 JSON-B 。JSON 测试支持也已更新为新的 JsonbTester 类。
Session Endpoint
Spring Session 用现在可以通过 /application/sessions Actuator Endpoint 进行查找和删除 session。
ConfigurationProperties 验证
如果你希望 @ConfigurationProperties 对象上开启验证,那么只需要添加 @Validated 就可以了。
Spring Mobile
针对 Spring Mobile 的自动配置和依赖不再支持,已被删除。
Spring WebFlux 支持错误约定
Spring Boot 现在让 WebFlux 的错误约定和 MVC 保持一致就像使用 MVC 一样:默认视图和 JSON 响应错误,自定义错误视图等等。
TLS 配置 和 HTTP/2 支持
你现在可以为你的 WebFlux 应用配置 SSL,使用 server.ssl.* 配置属性。
Tomcat, Jetty, Undertow 和 Reactor Netty 都支持。
你现在也可以为你的 MVC 或 WebFlux 应用配置 HTTP/2:
使用 server.http2.enabled。
@KafkaListener支持使用@SendTo
使用了自动配置工厂的 Kafka listener 现在支持 @SendTo。
Kotlin 扩展
Spring Boot 2.0 发布了 Kotlin runApplication 扩展:
package com.example.demo
import org.springframework.boot.autoconfigure.SpringBootApplication
import org.springframework.boot.runApplication
@SpringBootApplication
class DemoApplication
fun main(args: Array) {
runApplication(*args)
}
Job command line runner 顺序
CommandLineRunner 现在执行批处理 job 的启动 order 是 0。
支持自动配置的模板化欢迎页
Spring Boot 2.0 现在支持静态和模板化两种欢迎页类型。它会首先去配置好的静态内容的目录下查找 index.html 文件,如果没找到,然后就去查找 index 模板。 只要找到了一个就会被用作欢迎页。
Context path 会在启动时被打印
在 Spring Boot 之前的版本中,对 context path 貌似并没有那么的重视一样。现在当我们使用内嵌容器的时候, context path 会被打印在 HTTP 端口的旁边,像这样:
Tomcat started on port(s): 8080 (http) with context path ‘/foo’
测试优化,自动扫描 Converter 和 GenericConverter
Converter 和 GenericConverter beans 现在可以被 @WebMvcTest 和 @WebFluxTest 自动扫描到了。
Health vs. Status
status endpoint
已经被删除了,现在改成了 health
。这个 health 端点既可以展示 status 也可以有更多的细节。 health 端点现在默认
是被暴露的(只展示 status)。如果你希望展示更多的细节信息,可以通过修改属性 management.endpoints.health.show-details
来实现:
management.endpoints.health.show-details=true