-
Notifications
You must be signed in to change notification settings - Fork 40.8k
Spring Boot 1.3.0 M3 Release Notes
See instructions in the 1.3.0.M2 release notes for upgrading from 1.3.0 M2
The following application.properties
keys have been renamed to improve consistency:
-
servet.tomcat.accessLogEnabled
toserver.tomcat.accesslog.enabled
-
servet.tomcat.accessLogPattern
toserver.tomcat.accesslog.pattern
-
servet.undertow.accessLogDir
toserver.undertow.accesslog.dir
-
servet.undertow.accessLogEnabled
toserver.undertow.accesslog.enabled
-
servet.undertow.accessLogPattern
toserver.undertow.accesslog.pattern
The Spring Boot Gradle plugin will no longer apply Gradle’s application plugin by default. If you wish to make use of the application plugin you will have to apply it in your build.gradle
.
If you do not need the functionality provided by the application plugin, but were using its mainClassName
or applicationDefaultJvmArgs
properties then you will need to make some minor updates to your build.gradle
.
The main class should now be configured using the mainClass
property on the springBoot
extension, for example:
springBoot { mainClass = 'com.example.YourApplication' }
applicationDefaultJvmArgs
should now be configured in your project’s ext
block,
for example:
ext { applicationDefaultJvmArgs = [ '-Dcom.example.property=true' ] }
If you were configuring your project’s main class using the main
property of the application plugin’s run
task, you should move this configuration to the bootRun
task instead:
bootRun { main = com.example.YourApplication }
Tip
|
Check the configuration changelog for a complete overview of the changes in configuration. |
Update Tomcat, Jetty and Undertow to serialize session data when the application is stopped and load it again when the application restarts. Persistent session are opt-in; either by setting persistentSession
on the ConfigurableEmbeddedServletContainer
or by using the property server.session.persistent=true
(Persistent sessions are enabled by default with Devtools).
Devtools now allow allow additional paths that trigger a reload/restart to be configured via the spring.devtools.restart.additional-paths
property. When a change occurs in one of those paths a restart or reload will be triggered, depending on the full restart exclude patterns configured via the existing spring.devtools.restart.exclude
property.
Devtools also enables the server.session.persistent
flag so that you keep your session information when the application is reloaded.
The CLI will now use the repositories configured in Maven’s settings.xml
during dependency resolution. For a repository to be used, the profile in which it is declared must be active.
Auto-configuration for Embedded MongoDB has been added. A dependency on de.flapdoodle.embed:de.flapdoodle.embed.mongo
is all that’s necessary to get started.
Configuration, such as the version of Mongo to use, can be controlled via application.properties
. Please see the
documentation for further information.
Auto-configuration for H2’s web console has been added.
When you are using Spring Boot’s developer tools, adding a dependency on com.h2database:h2
to your web application is all that is necessary to get started. Please see the documentation for further information.
The console and file logging patterns can now be specified as regular properties (that is logging.pattern.console
and logging.pattern.file
respectively).
Tomcat access logs have better customizations: the directory and file prefix/suffix can now be customized via configuration.
If you are using logback or log4j2, we now include information about the location from which each class in a stack trace was loaded (this can be customized via logging.exception-conversion-word
). We also changed the default logback configuration so that it logs the root cause first.
Finally, we have improved Log4J 2’s default output to be similar to the output produced by Logback.
The auto-configuration report has now an additional section called "Unconditional classes". It lists any auto-configuration classes that do not have any class-level conditions, i.e. the class will be always be part of the application’s configuration.
It is now possible to also exclude auto-configuration classes via the spring.autoconfigure.excludes
property. Similarly, a new @ImportAutoConfiguration
annotation can be used by tests that wish to selectively import certain auto-configuration classes.
If you are using @ConfigurationProperties
on beans, you no longer need to add @EnableConfigurationProperties
to your configuration as Spring Boot autoconfigures it now. As before you can ask Spring to create a bean for your @ConfigurationProperties
class using the value attribute of @EnableConfigurationProperties
or with a regular @Bean
definition.
Both JMS and Rabbit endpoints can be easily disabled via configuration. The default container factory that is created if none exists can also be customized via configuration. Check the new properties for spring.jms
and spring.rabbitmq
for more details.
The META-INF/spring-configuration-metadata.json
file format has been updated to support a new deprecation
attribute per property element that defines the reason for the deprecation and a replacement key, if any. Such information can be provided by adding @DeprecatedConfigurationProperty
on the getter of the property.
We’ve also improved the detection of default value: if a property is initialized via a method call having a single argument, we consider said argument to be the default value (i.e. Charset.forName("UTF-8")
would detect UTF-8
as the default value).
A new spring-boot-configuration-metadata
module is now available for any tool developers wishing to use the configuration meta-data in their own tools and apps: it offers an API to read the meta-data and build a repository out of it.