Spring Boot Reference 2.3.X
Spring Boot Reference 2.3.X
Phillip Webb, Dave Syer, Josh Long, Stéphane Nicoll, Rob Winch, Andy
Wilkinson, Marcel Overdijk, Christian Dupuis, Sébastien Deleuze, Michael
Simons, Vedran Pavić, Jay Bryant, Madhura Bhave, Eddú Meléndez, Scott
Frederick
Table of Contents
1. Legal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
3. Getting Started . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
Maven Installation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
Gradle Installation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
Manual Installation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
MacPorts Installation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Command-line Completion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
4.1.2. Maven . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
4.1.3. Gradle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
4.1.4. Ant . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
4.1.5. Starters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
4.4. Auto-configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
Excluding Resources . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
Disabling Restart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
Known Limitations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
4.8.3. LiveReload . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
Remote Update. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
5.1. SpringApplication. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
Liveness State. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
Readiness State . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
Loading YAML . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
YAML Shortcomings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
Constructor binding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
Third-party Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
Relaxed Binding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
Properties Conversion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
@ConfigurationProperties Validation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
5.3. Profiles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
5.3.1. Adding Active Profiles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
Color-coded Output. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
Profile-specific Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
Environment Properties . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
5.5. Internationalization. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
5.6. JSON . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
5.6.1. Jackson. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90
5.6.2. Gson . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90
5.6.3. JSON-B . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90
HttpMessageConverters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92
MessageCodesResolver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93
Static Content . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93
Welcome Page . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
Custom Favicon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
ConfigurableWebBindingInitializer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
Template Engines . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
Error Handling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
Client . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
MongoTemplate. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 138
Neo4jSession . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141
Generic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152
Hazelcast . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 153
Infinispan . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 153
Couchbase. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 154
Redis. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 154
Caffeine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 155
Simple . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156
None . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156
ConfigFileApplicationContextInitializer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 210
TestPropertyValues. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 210
OutputCapture . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 210
TestRestTemplate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 211
Naming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 220
runApplication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 224
Extensions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 224
Examples. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 226
AppOptics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257
Atlas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257
Datadog . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257
Dynatrace . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257
Elastic. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257
Ganglia. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 258
Graphite . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 258
Humio . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 258
Influx . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 259
JMX . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 259
KairosDB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 259
Prometheus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 260
SignalFx. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 261
Simple . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 261
Stackdriver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 261
StatsD . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 261
Wavefront. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 262
Summary. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 281
Examples. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 301
Examples. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 302
10.13.1. Change the HTTP Port or Address of the Actuator Endpoints . . . . . . . . . . . . . . . . . . . . . . 355
10.16.8. Remote Debug a Spring Boot Application Started with Maven. . . . . . . . . . . . . . . . . . . . . 365
10.16.9. Build an Executable Archive from Ant without Using spring-boot-antlib . . . . . . . . . . . 365
11.B.3. Generating Your Own Metadata by Using the Annotation Processor . . . . . . . . . . . . . . . . 473
1
Chapter 1. Legal
Copyright © 2012-2021
Copies of this document may be made for your own use and for distribution to others, provided
that you do not charge any fee for such copies and further provided that each copy contains this
Copyright Notice, whether distributed in print or electronically.
2
Chapter 2. Spring Boot Documentation
This section provides a brief overview of Spring Boot reference documentation. It serves as a map
for the rest of the document.
• Multi-page HTML
• Try the How-to documents. They provide solutions to the most common questions.
• Learn the Spring basics. Spring Boot builds on many other Spring projects. Check the spring.io
web-site for a wealth of reference documentation. If you are starting out with Spring, try one of
the guides.
All of Spring Boot is open source, including the documentation. If you find
problems with the docs or if you want to improve them, please get involved.
Upgrading instructions are always the first item in the release notes. If you are more than one
release behind, please make sure that you also review the release notes of the versions that you
jumped.
You should always ensure that you are running a supported version of Spring Boot.
3
• From scratch: Overview | Requirements | Installation
4
Auto-configuration Annotations | Executable Jars | Dependency Versions
5
Chapter 3. Getting Started
If you are getting started with Spring Boot, or “Spring” in general, start by reading this section. It
answers the basic “what?”, “how?” and “why?” questions. It includes an introduction to Spring
Boot, along with installation instructions. We then walk you through building your first Spring Boot
application, discussing some core principles as we go.
You can use Spring Boot to create Java applications that can be started by using java -jar or more
traditional war deployments. We also provide a command line tool that runs “spring scripts”.
• Provide a radically faster and widely accessible getting-started experience for all Spring
development.
• Be opinionated out of the box but get out of the way quickly as requirements start to diverge
from the defaults.
• Provide a range of non-functional features that are common to large classes of projects (such as
embedded servers, security, metrics, health checks, and externalized configuration).
Maven 3.5+
6
Name Servlet Version
You can also deploy Spring Boot applications to any Servlet 3.1+ compatible container.
$ java -version
If you are new to Java development or if you want to experiment with Spring Boot, you might want
to try the Spring Boot CLI (Command Line Interface) first. Otherwise, read on for “classic”
installation instructions.
You can use Spring Boot in the same way as any standard Java library. To do so, include the
appropriate spring-boot-*.jar files on your classpath. Spring Boot does not require any special
tools integration, so you can use any IDE or text editor. Also, there is nothing special about a Spring
Boot application, so you can run and debug a Spring Boot application as you would any other Java
program.
Although you could copy Spring Boot jars, we generally recommend that you use a build tool that
supports dependency management (such as Maven or Gradle).
Maven Installation
Spring Boot is compatible with Apache Maven 3.3 or above. If you do not already have Maven
installed, you can follow the instructions at maven.apache.org.
Spring Boot dependencies use the org.springframework.boot groupId. Typically, your Maven POM file
inherits from the spring-boot-starter-parent project and declares dependencies to one or more
“Starters”. Spring Boot also provides an optional Maven plugin to create executable jars.
More details on getting started with Spring Boot and Maven can be found in the Getting Started
section of the Maven plugin’s reference guide.
7
Gradle Installation
Spring Boot is compatible with Gradle 6 (6.3 or later). Gradle 5.6.x is also supported but this support
is deprecated and will be removed in a future release. If you do not already have Gradle installed,
you can follow the instructions at gradle.org.
Spring Boot dependencies can be declared by using the org.springframework.boot group. Typically,
your project declares dependencies to one or more “Starters”. Spring Boot provides a useful Gradle
plugin that can be used to simplify dependency declarations and to create executable jars.
Gradle Wrapper
The Gradle Wrapper provides a nice way of “obtaining” Gradle when you need to build a
project. It is a small script and library that you commit alongside your code to bootstrap the
build process. See docs.gradle.org/current/userguide/gradle_wrapper.html for details.
More details on getting started with Spring Boot and Gradle can be found in the Getting Started
section of the Gradle plugin’s reference guide.
The Spring Boot CLI (Command Line Interface) is a command line tool that you can use to quickly
prototype with Spring. It lets you run Groovy scripts, which means that you have a familiar Java-
like syntax without so much boilerplate code.
You do not need to use the CLI to work with Spring Boot, but it is definitely the quickest way to get a
Spring application off the ground.
Manual Installation
You can download the Spring CLI distribution from the Spring software repository:
• spring-boot-cli-2.3.12.RELEASE-bin.zip
• spring-boot-cli-2.3.12.RELEASE-bin.tar.gz
Once downloaded, follow the INSTALL.txt instructions from the unpacked archive. In summary,
there is a spring script (spring.bat for Windows) in a bin/ directory in the .zip file. Alternatively,
you can use java -jar with the .jar file (the script helps you to be sure that the classpath is set
correctly).
SDKMAN! (The Software Development Kit Manager) can be used for managing multiple versions of
various binary SDKs, including Groovy and the Spring Boot CLI. Get SDKMAN! from sdkman.io and
install Spring Boot by using the following commands:
8
$ sdk install springboot
$ spring --version
Spring Boot v2.3.12.RELEASE
If you develop features for the CLI and want access to the version you built, use the following
commands:
The preceding instructions install a local instance of spring called the dev instance. It points at your
target build location, so every time you rebuild Spring Boot, spring is up-to-date.
$ sdk ls springboot
================================================================================
Available Springboot Versions
================================================================================
> + dev
* 2.3.12.RELEASE
================================================================================
+ - local version
* - installed
> - currently in use
================================================================================
If you are on a Mac and use Homebrew, you can install the Spring Boot CLI by using the following
commands:
If you do not see the formula, your installation of brew might be out-of-date. In
that case, run brew update and try again.
9
MacPorts Installation
If you are on a Mac and use MacPorts, you can install the Spring Boot CLI by using the following
command:
Command-line Completion
The Spring Boot CLI includes scripts that provide command completion for the BASH and zsh shells.
You can source the script (also named spring) in any shell or put it in your personal or system-wide
bash completion initialization. On a Debian system, the system-wide scripts are in /shell-
completion/bash and all scripts in that directory are executed when a new shell starts. For example,
to run the script manually if you have installed by using SDKMAN!, use the following commands:
$ . ~/.sdkman/candidates/springboot/current/shell-completion/bash/spring
$ spring <HIT TAB HERE>
grab help jar run test version
If you install the Spring Boot CLI by using Homebrew or MacPorts, the command-
line completion scripts are automatically registered with your shell.
If you are on a Windows and use Scoop, you can install the Spring Boot CLI by using the following
commands:
If you do not see the app manifest, your installation of scoop might be out-of-date.
In that case, run scoop update and try again.
You can use the following web application to test your installation. To start, create a file called
app.groovy, as follows:
10
@RestController
class ThisWillActuallyRun {
@RequestMapping("/")
String home() {
"Hello World!"
}
Open localhost:8080 in your favorite web browser. You should see the following output:
Hello World!
If you are upgrading from the 1.x release of Spring Boot, check the “migration guide” on the project
wiki that provides detailed upgrade instructions. Check also the “release notes” for a list of “new
and noteworthy” features for each release.
When upgrading to a new feature release, some properties may have been renamed or removed.
Spring Boot provides a way to analyze your application’s environment and print diagnostics at
startup, but also temporarily migrate properties at runtime for you. To enable that feature, add the
following dependency to your project:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-properties-migrator</artifactId>
<scope>runtime</scope>
</dependency>
Properties that are added late to the environment, such as when using
@PropertySource, will not be taken into account.
Once you’re done with the migration, please make sure to remove this module
from your project’s dependencies.
11
To upgrade an existing CLI installation, use the appropriate package manager command (for
example, brew upgrade). If you manually installed the CLI, follow the standard instructions,
remembering to update your PATH environment variable to remove any older references.
The spring.io web site contains many “Getting Started” guides that use Spring Boot.
If you need to solve a specific problem, check there first.
You can shortcut the steps below by going to start.spring.io and choosing the "Web"
starter from the dependencies searcher. Doing so generates a new project
structure so that you can start coding right away. Check the Spring Initializr
documentation for more details.
Before we begin, open a terminal and run the following commands to ensure that you have valid
versions of Java and Maven installed:
$ java -version
java version "1.8.0_102"
Java(TM) SE Runtime Environment (build 1.8.0_102-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.102-b14, mixed mode)
$ mvn -v
Apache Maven 3.5.4 (1edded0938998edf8bf061f1ceb3cfdeccf443fe; 2018-06-17T14:33:14-
04:00)
Maven home: /usr/local/Cellar/maven/3.3.9/libexec
Java version: 1.8.0_102, vendor: Oracle Corporation
We need to start by creating a Maven pom.xml file. The pom.xml is the recipe that is used to build your
project. Open your favorite text editor and add the following:
12
<?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>
<groupId>com.example</groupId>
<artifactId>myproject</artifactId>
<version>0.0.1-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.12.RELEASE</version>
</parent>
<description/>
<developers>
<developer/>
</developers>
<licenses>
<license/>
</licenses>
<scm>
<url/>
</scm>
<url/>
</project>
The preceding listing should give you a working build. You can test it by running mvn package (for
now, you can ignore the “jar will be empty - no content was marked for inclusion!” warning).
At this point, you could import the project into an IDE (most modern Java IDEs
include built-in support for Maven). For simplicity, we continue to use a plain text
editor for this example.
Spring Boot provides a number of “Starters” that let you add jars to your classpath. Our
applications for smoke tests use the spring-boot-starter-parent in the parent section of the POM.
The spring-boot-starter-parent is a special starter that provides useful Maven defaults. It also
provides a dependency-management section so that you can omit version tags for “blessed”
dependencies.
Other “Starters” provide dependencies that you are likely to need when developing a specific type
13
of application. Since we are developing a web application, we add a spring-boot-starter-web
dependency. Before that, we can look at what we currently have by running the following
command:
$ mvn dependency:tree
[INFO] com.example:myproject:jar:0.0.1-SNAPSHOT
The mvn dependency:tree command prints a tree representation of your project dependencies. You
can see that spring-boot-starter-parent provides no dependencies by itself. To add the necessary
dependencies, edit your pom.xml and add the spring-boot-starter-web dependency immediately
below the parent section:
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
If you run mvn dependency:tree again, you see that there are now a number of additional
dependencies, including the Tomcat web server and Spring Boot itself.
To finish our application, we need to create a single Java file. By default, Maven compiles sources
from src/main/java, so you need to create that directory structure and then add a file named
src/main/java/Example.java to contain the following code:
14
import org.springframework.boot.*;
import org.springframework.boot.autoconfigure.*;
import org.springframework.web.bind.annotation.*;
@RestController
@EnableAutoConfiguration
public class Example {
@RequestMapping("/")
String home() {
return "Hello World!";
}
Although there is not much code here, quite a lot is going on. We step through the important parts
in the next few sections.
The first annotation on our Example class is @RestController. This is known as a stereotype
annotation. It provides hints for people reading the code and for Spring that the class plays a
specific role. In this case, our class is a web @Controller, so Spring considers it when handling
incoming web requests.
The @RequestMapping annotation provides “routing” information. It tells Spring that any HTTP
request with the / path should be mapped to the home method. The @RestController annotation tells
Spring to render the resulting string directly back to the caller.
The second class-level annotation is @EnableAutoConfiguration. This annotation tells Spring Boot to
“guess” how you want to configure Spring, based on the jar dependencies that you have added.
Since spring-boot-starter-web added Tomcat and Spring MVC, the auto-configuration assumes that
you are developing a web application and sets up Spring accordingly.
15
Starters and Auto-configuration
Auto-configuration is designed to work well with “Starters”, but the two concepts are not
directly tied. You are free to pick and choose jar dependencies outside of the starters. Spring
Boot still does its best to auto-configure your application.
The final part of our application is the main method. This is a standard method that follows the Java
convention for an application entry point. Our main method delegates to Spring Boot’s
SpringApplication class by calling run. SpringApplication bootstraps our application, starting Spring,
which, in turn, starts the auto-configured Tomcat web server. We need to pass Example.class as an
argument to the run method to tell SpringApplication which is the primary Spring component. The
args array is also passed through to expose any command-line arguments.
At this point, your application should work. Since you used the spring-boot-starter-parent POM,
you have a useful run goal that you can use to start the application. Type mvn spring-boot:run from
the root project directory to start the application. You should see output similar to the following:
$ mvn spring-boot:run
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v2.3.12.RELEASE)
....... . . .
....... . . . (log output here)
....... . . .
........ Started Example in 2.222 seconds (JVM running for 6.514)
If you open a web browser to localhost:8080, you should see the following output:
Hello World!
We finish our example by creating a completely self-contained executable jar file that we could run
in production. Executable jars (sometimes called “fat jars”) are archives containing your compiled
classes along with all of the jar dependencies that your code needs to run.
16
Executable jars and Java
Java does not provide a standard way to load nested jar files (jar files that are themselves
contained within a jar). This can be problematic if you are looking to distribute a self-
contained application.
To solve this problem, many developers use “uber” jars. An uber jar packages all the classes
from all the application’s dependencies into a single archive. The problem with this approach
is that it becomes hard to see which libraries are in your application. It can also be
problematic if the same filename is used (but with different content) in multiple jars.
Spring Boot takes a different approach and lets you actually nest jars directly.
To create an executable jar, we need to add the spring-boot-maven-plugin to our pom.xml. To do so,
insert the following lines just below the dependencies section:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
Save your pom.xml and run mvn package from the command line, as follows:
17
$ mvn package
If you look in the target directory, you should see myproject-0.0.1-SNAPSHOT.jar. The file should be
around 10 MB in size. If you want to peek inside, you can use jar tvf, as follows:
You should also see a much smaller file named myproject-0.0.1-SNAPSHOT.jar.original in the target
directory. This is the original jar file that Maven created before it was repackaged by Spring Boot.
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v2.3.12.RELEASE)
....... . . .
....... . . . (log output here)
....... . . .
........ Started Example in 2.536 seconds (JVM running for 2.864)
18
your own applications. If you are a task-oriented type of developer, you might want to jump over to
spring.io and check out some of the getting started guides that solve specific “How do I do that with
Spring?” problems. We also have Spring Boot-specific “How-to” reference documentation.
Otherwise, the next logical step is to read Using Spring Boot. If you are really impatient, you could
also jump ahead and read about Spring Boot features.
19
Chapter 4. Using Spring Boot
This section goes into more detail about how you should use Spring Boot. It covers topics such as
build systems, auto-configuration, and how to run your applications. We also cover some Spring
Boot best practices. Although there is nothing particularly special about Spring Boot (it is just
another library that you can consume), there are a few recommendations that, when followed,
make your development process a little easier.
If you are starting out with Spring Boot, you should probably read the Getting Started guide before
diving into this section.
Each release of Spring Boot provides a curated list of dependencies that it supports. In practice, you
do not need to provide a version for any of these dependencies in your build configuration, as
Spring Boot manages that for you. When you upgrade Spring Boot itself, these dependencies are
upgraded as well in a consistent way.
You can still specify a version and override Spring Boot’s recommendations if you
need to do so.
The curated list contains all the Spring modules that you can use with Spring Boot as well as a
refined list of third party libraries. The list is available as a standard Bills of Materials (spring-boot-
dependencies) that can be used with both Maven and Gradle.
Each release of Spring Boot is associated with a base version of the Spring
Framework. We highly recommend that you not specify its version.
4.1.2. Maven
To learn about using Spring Boot with Maven, please refer to the documentation for Spring Boot’s
Maven plugin:
• API
4.1.3. Gradle
To learn about using Spring Boot with Gradle, please refer to the documentation for Spring Boot’s
Gradle plugin:
20
• Reference (HTML and PDF)
• API
4.1.4. Ant
It is possible to build a Spring Boot project using Apache Ant+Ivy. The spring-boot-antlib “AntLib”
module is also available to help Ant create executable jars.
To declare dependencies, a typical ivy.xml file looks something like the following example:
<ivy-module version="2.0">
<info organisation="org.springframework.boot" module="spring-boot-sample-ant" />
<configurations>
<conf name="compile" description="everything needed to compile this module" />
<conf name="runtime" extends="compile" description="everything needed to run
this module" />
</configurations>
<dependencies>
<dependency org="org.springframework.boot" name="spring-boot-starter"
rev="${spring-boot.version}" conf="compile" />
</dependencies>
</ivy-module>
21
<project
xmlns:ivy="antlib:org.apache.ivy.ant"
xmlns:spring-boot="antlib:org.springframework.boot.ant"
name="myapp" default="build">
If you do not want to use the spring-boot-antlib module, see the Build an
Executable Archive from Ant without Using spring-boot-antlib “How-to” .
4.1.5. Starters
Starters are a set of convenient dependency descriptors that you can include in your application.
You get a one-stop shop for all the Spring and related technologies that you need without having to
hunt through sample code and copy-paste loads of dependency descriptors. For example, if you
want to get started using Spring and JPA for database access, include the spring-boot-starter-data-
jpa dependency in your project.
The starters contain a lot of the dependencies that you need to get a project up and running quickly
and with a consistent, supported set of managed transitive dependencies.
22
What’s in a name
As explained in the “Creating Your Own Starter” section, third party starters should not start
with spring-boot, as it is reserved for official Spring Boot artifacts. Rather, a third-party
starter typically starts with the name of the project. For example, a third-party starter project
called thirdpartyproject would typically be named thirdpartyproject-spring-boot-starter.
The following application starters are provided by Spring Boot under the org.springframework.boot
group:
Name Description
23
Name Description
24
Name Description
In addition to the application starters, the following starters can be used to add production ready
features:
Name Description
Finally, Spring Boot also includes the following starters that can be used if you want to exclude or
swap specific technical facets:
25
Name Description
To learn how to swap technical facets, please see the how-to documentation for swapping web
server and logging system.
For a list of additional community contributed starters, see the README file in the
spring-boot-starters module on GitHub.
When a class does not include a package declaration, it is considered to be in the “default package”.
The use of the “default package” is generally discouraged and should be avoided. It can cause
particular problems for Spring Boot applications that use the @ComponentScan,
@ConfigurationPropertiesScan, @EntityScan, or @SpringBootApplication annotations, since every class
from every jar is read.
We generally recommend that you locate your main application class in a root package above other
classes. The @SpringBootApplication annotation is often placed on your main class, and it implicitly
defines a base “search package” for certain items. For example, if you are writing a JPA application,
the package of the @SpringBootApplication annotated class is used to search for @Entity items. Using
26
a root package also allows component scan to apply only on your project.
com
+- example
+- myapplication
+- Application.java
|
+- customer
| +- Customer.java
| +- CustomerController.java
| +- CustomerService.java
| +- CustomerRepository.java
|
+- order
+- Order.java
+- OrderController.java
+- OrderService.java
+- OrderRepository.java
The Application.java file would declare the main method, along with the basic
@SpringBootApplication, as follows:
package com.example.myapplication;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class Application {
27
Many Spring configuration examples have been published on the Internet that use
XML configuration. If possible, always try to use the equivalent Java-based
configuration. Searching for Enable* annotations can be a good starting point.
You need not put all your @Configuration into a single class. The @Import annotation can be used to
import additional configuration classes. Alternatively, you can use @ComponentScan to automatically
pick up all Spring components, including @Configuration classes.
If you absolutely must use XML based configuration, we recommend that you still start with a
@Configuration class. You can then use an @ImportResource annotation to load XML configuration
files.
4.4. Auto-configuration
Spring Boot auto-configuration attempts to automatically configure your Spring application based
on the jar dependencies that you have added. For example, if HSQLDB is on your classpath, and you
have not manually configured any database connection beans, then Spring Boot auto-configures an
in-memory database.
Auto-configuration is non-invasive. At any point, you can start to define your own configuration to
replace specific parts of the auto-configuration. For example, if you add your own DataSource bean,
the default embedded database support backs away.
If you need to find out what auto-configuration is currently being applied, and why, start your
application with the --debug switch. Doing so enables debug logs for a selection of core loggers and
logs a conditions report to the console.
If you find that specific auto-configuration classes that you do not want are being applied, you can
use the exclude attribute of @SpringBootApplication to disable them, as shown in the following
example:
28
import org.springframework.boot.autoconfigure.*;
import org.springframework.boot.autoconfigure.jdbc.*;
@SpringBootApplication(exclude={DataSourceAutoConfiguration.class})
public class MyApplication {
}
If the class is not on the classpath, you can use the excludeName attribute of the annotation and
specify the fully qualified name instead. If you prefer to use @EnableAutoConfiguration rather than
@SpringBootApplication, exclude and excludeName are also available. Finally, you can also control the
list of auto-configuration classes to exclude by using the spring.autoconfigure.exclude property.
You can define exclusions both at the annotation level and by using the property.
Even though auto-configuration classes are public, the only aspect of the class that
is considered public API is the name of the class which can be used for disabling
the auto-configuration. The actual contents of those classes, such as nested
configuration classes or bean methods are for internal use only and we do not
recommend using those directly.
If you structure your code as suggested above (locating your application class in a root package),
you can add @ComponentScan without any arguments. All of your application components (
@Component, @Service, @Repository, @Controller etc.) are automatically registered as Spring Beans.
The following example shows a @Service Bean that uses constructor injection to obtain a required
RiskAssessor bean:
29
package com.example.service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class DatabaseAccountService implements AccountService {
@Autowired
public DatabaseAccountService(RiskAssessor riskAssessor) {
this.riskAssessor = riskAssessor;
}
// ...
If a bean has one constructor, you can omit the @Autowired, as shown in the following example:
@Service
public class DatabaseAccountService implements AccountService {
// ...
Notice how using constructor injection lets the riskAssessor field be marked as
final, indicating that it cannot be subsequently changed.
• @ComponentScan: enable @Component scan on the package where the application is located (see the
best practices)
30
• @Configuration: allow to register extra beans in the context or import additional configuration
classes
package com.example.myapplication;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
None of these features are mandatory and you may choose to replace this single
annotation by any of the features that it enables. For instance, you may not want to
use component scan or configuration properties scan in your application:
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 {
In this example, Application is just like any other Spring Boot application except
that @Component-annotated classes and @ConfigurationProperties-annotated classes
are not detected automatically and the user-defined beans are imported explicitly
(see @Import).
31
4.7. Running Your Application
One of the biggest advantages of packaging your application as a jar and using an embedded HTTP
server is that you can run your application as you would any other. The sample applies to
debugging Spring Boot applications. You do not need any special IDE plugins or extensions.
This section only covers jar based packaging. If you choose to package your
application as a war file, you should refer to your server and IDE documentation.
You can run a Spring Boot application from your IDE as a Java application. However, you first need
to import your project. Import steps vary depending on your IDE and build system. Most IDEs can
import Maven projects directly. For example, Eclipse users can select Import… → Existing Maven
Projects from the File menu.
If you cannot directly import your project into your IDE, you may be able to generate IDE metadata
by using a build plugin. Maven includes plugins for Eclipse and IDEA. Gradle offers plugins for
various IDEs.
If you accidentally run a web application twice, you see a “Port already in use”
error. STS users can use the Relaunch button rather than the Run button to ensure
that any existing instance is closed.
If you use the Spring Boot Maven or Gradle plugins to create an executable jar, you can run your
application using java -jar, as shown in the following example:
It is also possible to run a packaged application with remote debugging support enabled. Doing so
lets you attach a debugger to your packaged application, as shown in the following example:
The Spring Boot Maven plugin includes a run goal that can be used to quickly compile and run your
application. Applications run in an exploded form, as they do in your IDE. The following example
shows a typical Maven command to run a Spring Boot application:
$ mvn spring-boot:run
32
You might also want to use the MAVEN_OPTS operating system environment variable, as shown in the
following example:
$ export MAVEN_OPTS=-Xmx1024m
The Spring Boot Gradle plugin also includes a bootRun task that can be used to run your application
in an exploded form. The bootRun task is added whenever you apply the org.springframework.boot
and java plugins and is shown in the following example:
$ gradle bootRun
You might also want to use the JAVA_OPTS operating system environment variable, as shown in the
following example:
$ export JAVA_OPTS=-Xmx1024m
Since Spring Boot applications are plain Java applications, JVM hot-swapping should work out of
the box. JVM hot swapping is somewhat limited with the bytecode that it can replace. For a more
complete solution, JRebel can be used.
The spring-boot-devtools module also includes support for quick application restarts. See the
Developer Tools section later in this chapter and the Hot swapping “How-to” for details.
Maven
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
33
Gradle
dependencies {
developmentOnly("org.springframework.boot:spring-boot-devtools")
}
Several of the libraries supported by Spring Boot use caches to improve performance. For example,
template engines cache compiled templates to avoid repeatedly parsing template files. Also, Spring
MVC can add HTTP caching headers to responses when serving static resources.
Cache options are usually configured by settings in your application.properties file. For example,
Thymeleaf offers the spring.thymeleaf.cache property. Rather than needing to set these properties
manually, the spring-boot-devtools module automatically applies sensible development-time
configuration.
Because you need more information about web requests while developing Spring MVC and Spring
WebFlux applications, developer tools will enable DEBUG logging for the web logging group. This will
give you information about the incoming request, which handler is processing it, the response
outcome, etc. If you wish to log all request details (including potentially sensitive information), you
can turn on the spring.mvc.log-request-details or spring.codec.log-request-details configuration
properties.
If you don’t want property defaults to be applied you can set spring.devtools.add-
properties to false in your application.properties.
34
For a complete list of the properties that are applied by the devtools, see
DevToolsPropertyDefaultsPostProcessor.
Applications that use spring-boot-devtools automatically restart whenever files on the classpath
change. This can be a useful feature when working in an IDE, as it gives a very fast feedback loop
for code changes. By default, any entry on the classpath that points to a directory is monitored for
changes. Note that certain resources, such as static assets and view templates, do not need to restart
the application.
Triggering a restart
As DevTools monitors classpath resources, the only way to trigger a restart is to update the
classpath. The way in which you cause the classpath to be updated depends on the IDE that
you are using:
• In Eclipse, saving a modified file causes the classpath to be updated and triggers a restart.
• In IntelliJ IDEA, building the project (Build +→+ Build Project) has the same effect.
• If using a build plugin, running mvn compile for Maven or gradle build for Gradle will
trigger a restart.
If you are restarting with Maven or Gradle using the build plugin you must leave
the forking set to enabled. If you disable forking, the isolated application
classloader used by devtools will not be created and restarts will not operate
properly.
Automatic restart works very well when used with LiveReload. See the LiveReload
section for details. If you use JRebel, automatic restarts are disabled in favor of
dynamic class reloading. Other devtools features (such as LiveReload and property
overrides) can still be used.
35
Restart vs Reload
The restart technology provided by Spring Boot works by using two classloaders. Classes that
do not change (for example, those from third-party jars) are loaded into a base classloader.
Classes that you are actively developing are loaded into a restart classloader. When the
application is restarted, the restart classloader is thrown away and a new one is created. This
approach means that application restarts are typically much faster than “cold starts”, since
the base classloader is already available and populated.
If you find that restarts are not quick enough for your applications or you encounter
classloading issues, you could consider reloading technologies such as JRebel from
ZeroTurnaround. These work by rewriting classes as they are loaded to make them more
amenable to reloading.
By default, each time your application restarts, a report showing the condition evaluation delta is
logged. The report shows the changes to your application’s auto-configuration as you make changes
such as adding or removing beans and setting configuration properties.
spring.devtools.restart.log-condition-evaluation-delta=false
Excluding Resources
Certain resources do not necessarily need to trigger a restart when they are changed. For example,
Thymeleaf templates can be edited in-place. By default, changing resources in /META-INF/maven,
/META-INF/resources, /resources, /static, /public, or /templates does not trigger a restart but does
trigger a live reload. If you want to customize these exclusions, you can use the
spring.devtools.restart.exclude property. For example, to exclude only /static and /public you
would set the following property:
spring.devtools.restart.exclude=static/**,public/**
If you want to keep those defaults and add additional exclusions, use the
spring.devtools.restart.additional-exclude property instead.
You may want your application to be restarted or reloaded when you make changes to files that are
not on the classpath. To do so, use the spring.devtools.restart.additional-paths property to
configure additional paths to watch for changes. You can use the spring.devtools.restart.exclude
property described earlier to control whether changes beneath the additional paths trigger a full
restart or a live reload.
36
Disabling Restart
If you do not want to use the restart feature, you can disable it by using the
spring.devtools.restart.enabled property. In most cases, you can set this property in your
application.properties (doing so still initializes the restart classloader, but it does not watch for file
changes).
If you need to completely disable restart support (for example, because it does not work with a
specific library), you need to set the spring.devtools.restart.enabled System property to false
before calling SpringApplication.run(…), as shown in the following example:
If you work with an IDE that continuously compiles changed files, you might prefer to trigger
restarts only at specific times. To do so, you can use a “trigger file”, which is a special file that must
be modified when you want to actually trigger a restart check.
Any update to the file will trigger a check, but restart only actually occurs if
Devtools has detected it has something to do.
To use a trigger file, set the spring.devtools.restart.trigger-file property to the name (excluding
any path) of your trigger file. The trigger file must appear somewhere on your classpath.
src
+- main
+- resources
+- .reloadtrigger
spring.devtools.restart.trigger-file=.reloadtrigger
Some IDEs have features that save you from needing to update your trigger file manually. Spring
Tools for Eclipse and IntelliJ IDEA (Ultimate Edition) both have such support. With Spring Tools, you
37
can use the “reload” button from the console view (as long as your trigger-file is named
.reloadtrigger). For IntelliJ IDEA, you can follow the instructions in their documentation.
As described earlier in the Restart vs Reload section, restart functionality is implemented by using
two classloaders. For most applications, this approach works well. However, it can sometimes cause
classloading issues.
By default, any open project in your IDE is loaded with the “restart” classloader, and any regular
.jar file is loaded with the “base” classloader. If you work on a multi-module project, and not every
module is imported into your IDE, you may need to customize things. To do so, you can create a
META-INF/spring-devtools.properties file.
The spring-devtools.properties file can contain properties prefixed with restart.exclude and
restart.include. The include elements are items that should be pulled up into the “restart”
classloader, and the exclude elements are items that should be pushed down into the “base”
classloader. The value of the property is a regex pattern that is applied to the classpath, as shown in
the following example:
restart.exclude.companycommonlibs=/mycorp-common-[\\w\\d-\.]+\.jar
restart.include.projectcommon=/mycorp-myproj-[\\w\\d-\.]+\.jar
Known Limitations
Restart functionality does not work well with objects that are deserialized by using a standard
ObjectInputStream. If you need to deserialize data, you may need to use Spring’s
ConfigurableObjectInputStream in combination with
Thread.currentThread().getContextClassLoader().
Unfortunately, several third-party libraries deserialize without considering the context classloader.
If you find such a problem, you need to request a fix with the original authors.
4.8.3. LiveReload
The spring-boot-devtools module includes an embedded LiveReload server that can be used to
trigger a browser refresh when a resource is changed. LiveReload browser extensions are freely
available for Chrome, Firefox and Safari from livereload.com.
If you do not want to start the LiveReload server when your application runs, you can set the
spring.devtools.livereload.enabled property to false.
38
You can only run one LiveReload server at a time. Before starting your application,
ensure that no other LiveReload servers are running. If you start multiple
applications from your IDE, only the first has LiveReload support.
You can configure global devtools settings by adding any of the following files to the
$HOME/.config/spring-boot directory:
1. spring-boot-devtools.properties
2. spring-boot-devtools.yaml
3. spring-boot-devtools.yml
Any properties added to these file apply to all Spring Boot applications on your machine that use
devtools. For example, to configure restart to always use a trigger file, you would add the following
property:
~/.config/spring-boot/spring-boot-devtools.properties
spring.devtools.restart.trigger-file=.reloadtrigger
FileSystemWatcher works by polling the class changes with a certain time interval, and then
waiting for a predefined quiet period to make sure there are no more changes. Since Spring Boot
relies entirely on the IDE to compile and copy files into the location from where Spring Boot can
read them, you might find that there are times when certain changes are not reflected when
devtools restarts the application. If you observe such problems constantly, try increasing the
spring.devtools.restart.poll-interval and spring.devtools.restart.quiet-period parameters to
the values that fit your development environment:
39
spring.devtools.restart.poll-interval=2s
spring.devtools.restart.quiet-period=1s
The monitored classpath directories are now polled every 2 seconds for changes, and a 1 second
quiet period is maintained to make sure there are no additional class changes.
The Spring Boot developer tools are not limited to local development. You can also use several
features when running applications remotely. Remote support is opt-in as enabling it can be a
security risk. It should only be enabled when running on a trusted network or when secured with
SSL. If neither of these options is available to you, you should not use DevTools' remote support.
You should never enable support on a production deployment.
To enable it, you need to make sure that devtools is included in the repackaged archive, as shown in
the following listing:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludeDevtools>false</excludeDevtools>
</configuration>
</plugin>
</plugins>
</build>
Then you need to set the spring.devtools.remote.secret property. Like any important password or
secret, the value should be unique and strong such that it cannot be guessed or brute-forced.
Remote devtools support is provided in two parts: a server-side endpoint that accepts connections
and a client application that you run in your IDE. The server component is automatically enabled
when the spring.devtools.remote.secret property is set. The client component must be launched
manually.
The remote client application is designed to be run from within your IDE. You need to run
org.springframework.boot.devtools.RemoteSpringApplication with the same classpath as the remote
project that you connect to. The application’s single required argument is the remote URL to which
it connects.
For example, if you are using Eclipse or STS and you have a project named my-app that you have
deployed to Cloud Foundry, you would do the following:
40
• Create a new Java Application “launch configuration”.
• Add https://myapp.cfapps.io to the Program arguments (or whatever your remote URL is).
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ ___ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | | _ \___ _ __ ___| |_ ___ \ \ \ \
\\/ ___)| |_)| | | | | || (_| []::::::[] / -_) ' \/ _ \ _/ -_) ) ) ) )
' |____| .__|_| |_|_| |_\__, | |_|_\___|_|_|_\___/\__\___|/ / / /
=========|_|==============|___/===================================/_/_/_/
:: Spring Boot Remote :: 2.3.12.RELEASE
Because the remote client is using the same classpath as the real application it can
directly read application properties. This is how the spring.devtools.remote.secret
property is read and passed to the server for authentication.
If you need to use a proxy to access the remote application, configure the
spring.devtools.remote.proxy.host
properties.
and spring.devtools.remote.proxy.port
Remote Update
The remote client monitors your application classpath for changes in the same way as the local
41
restart. Any updated resource is pushed to the remote application and (if required) triggers a
restart. This can be helpful if you iterate on a feature that uses a cloud service that you do not have
locally. Generally, remote updates and restarts are much quicker than a full rebuild and deploy
cycle.
On a slower development environment, it may happen that the quiet period is not enough, and the
changes in the classes may be split into batches. The server is restarted after the first batch of class
changes is uploaded. The next batch can’t be sent to the application, since the server is restarting.
This is typically manifested by a warning in the RemoteSpringApplication logs about failing to upload
some of the classes, and a consequent retry. But it may also lead to application code inconsistency
and failure to restart after the first batch of changes is uploaded. If you observe such problems
constantly, try increasing the spring.devtools.restart.poll-interval and
spring.devtools.restart.quiet-period parameters to the values that fit your development
environment. See the Configuring File System Watcher section for configuring these properties.
Files are only monitored when the remote client is running. If you change a file
before starting the remote client, it is not pushed to the remote server.
For additional “production ready” features, such as health, auditing, and metric REST or JMX end-
points, consider adding spring-boot-actuator. See Spring Boot Actuator: Production-ready Features
for details.
42
Chapter 5. Spring Boot Features
This section dives into the details of Spring Boot. Here you can learn about the key features that you
may want to use and customize. If you have not already done so, you might want to read the
"Getting Started" and "Using Spring Boot" sections, so that you have a good grounding of the basics.
5.1. SpringApplication
The SpringApplication class provides a convenient way to bootstrap a Spring application that is
started from a main() method. In many situations, you can delegate to the static
SpringApplication.run method, as shown in the following example:
When your application starts, you should see something similar to the following output:
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: v2.3.12.RELEASE
By default, INFO logging messages are shown, including some relevant startup details, such as the
user that launched the application. If you need a log level other than INFO, you can set it, as
described in Log Levels. The application version is determined using the implementation version
from the main application class’s package. Startup information logging can be turned off by setting
spring.main.log-startup-info to false. This will also turn off logging of the application’s active
profiles.
43
To add additional logging during startup, you can override
logStartupInfo(boolean) in a subclass of SpringApplication.
If your application fails to start, registered FailureAnalyzers get a chance to provide a dedicated
error message and a concrete action to fix the problem. For instance, if you start a web application
on port 8080 and that port is already in use, you should see something similar to the following
message:
***************************
APPLICATION FAILED TO START
***************************
Description:
Embedded servlet container failed to start. Port 8080 was already in use.
Action:
Identify and stop the process that's listening on port 8080 or configure this
application to listen on another port.
If no failure analyzers are able to handle the exception, you can still display the full conditions
report to better understand what went wrong. To do so, you need to enable the debug property or
enable DEBUG logging for
org.springframework.boot.autoconfigure.logging.ConditionEvaluationReportLoggingListener.
For instance, if you are running your application by using java -jar, you can enable the debug
property as follows:
A downside of lazy initialization is that it can delay the discovery of a problem with the application.
If a misconfigured bean is initialized lazily, a failure will no longer occur during startup and the
44
problem will only become apparent when the bean is initialized. Care must also be taken to ensure
that the JVM has sufficient memory to accommodate all of the application’s beans and not just those
that are initialized during startup. For these reasons, lazy initialization is not enabled by default
and it is recommended that fine-tuning of the JVM’s heap size is done before enabling lazy
initialization.
spring.main.lazy-initialization=true
If you want to disable lazy initialization for certain beans while using lazy
initialization for the rest of the application, you can explicitly set their lazy
attribute to false using the @Lazy(false) annotation.
The banner that is printed on start up can be changed by adding a banner.txt file to your classpath
or by setting the spring.banner.location property to the location of such a file. If the file has an
encoding other than UTF-8, you can set spring.banner.charset. In addition to a text file, you can also
add a banner.gif, banner.jpg, or banner.png image file to your classpath or set the
spring.banner.image.location property. Images are converted into an ASCII art representation and
printed above any text banner.
Inside your banner.txt file, you can use any of the following placeholders:
Variable Description
${application.version} The version number of your application, as
declared in MANIFEST.MF. For example,
Implementation-Version: 1.0 is printed as 1.0.
${application.formatted-version} The version number of your application, as
declared in MANIFEST.MF and formatted for
display (surrounded with brackets and prefixed
with v). For example (v1.0).
${spring-boot.version} The Spring Boot version that you are using. For
example 2.3.12.RELEASE.
${spring-boot.formatted-version} The Spring Boot version that you are using,
formatted for display (surrounded with brackets
and prefixed with v). For example
(v2.3.12.RELEASE).
${Ansi.NAME} (or ${AnsiColor.NAME}, Where NAME is the name of an ANSI escape code.
${AnsiBackground.NAME}, ${AnsiStyle.NAME}) See AnsiPropertySource for details.
45
Variable Description
${application.title} The title of your application, as declared in
MANIFEST.MF. For example Implementation-Title:
MyApp is printed as MyApp.
You can also use the spring.main.banner-mode property to determine if the banner has to be printed
on System.out (console), sent to the configured logger (log), or not produced at all (off).
The printed banner is registered as a singleton bean under the following name: springBootBanner.
<mainclass>.
This is why we recommend that you always use launch unpacked jars using java
org.springframework.boot.loader.JarLauncher. This will initialize the application.*
banner variables before building the classpath and launching your app.
If the SpringApplication defaults are not to your taste, you can instead create a local instance and
customize it. For example, to turn off the banner, you could write:
For a complete list of the configuration options, see the SpringApplication Javadoc.
46
5.1.5. Fluent Builder API
The SpringApplicationBuilder lets you chain together multiple method calls and includes parent and
child methods that let you create a hierarchy, as shown in the following example:
new SpringApplicationBuilder()
.sources(Parent.class)
.child(Application.class)
.bannerMode(Banner.Mode.OFF)
.run(args);
When deployed on platforms, applications can provide information about their availability to the
platform using infrastructure such as Kubernetes Probes. Spring Boot includes out-of-the box
support for the commonly used “liveness” and “readiness” availability states. If you are using
Spring Boot’s “actuator” support then these states are exposed as health endpoint groups.
In addition, you can also obtain availability states by injecting the ApplicationAvailability interface
into your own beans.
Liveness State
The “Liveness” state of an application tells whether its internal state allows it to work correctly, or
recover by itself if it’s currently failing. A broken “Liveness” state means that the application is in a
state that it cannot recover from, and the infrastructure should restart the application.
In general, the "Liveness" state should not be based on external checks, such as
Health checks. If it did, a failing external system (a database, a Web API, an
external cache) would trigger massive restarts and cascading failures across the
platform.
The internal state of Spring Boot applications is mostly represented by the Spring
ApplicationContext. If the application context has started successfully, Spring Boot assumes that the
application is in a valid state. An application is considered live as soon as the context has been
refreshed, see Spring Boot application lifecycle and related Application Events.
Readiness State
The “Readiness” state of an application tells whether the application is ready to handle traffic. A
47
failing “Readiness” state tells the platform that it should not route traffic to the application for now.
This typically happens during startup, while CommandLineRunner and ApplicationRunner components
are being processed, or at any time if the application decides that it’s too busy for additional traffic.
An application is considered ready as soon as application and command-line runners have been
called, see Spring Boot application lifecycle and related Application Events.
Application components can retrieve the current availability state at any time, by injecting the
ApplicationAvailability interface and calling methods on it. More often, applications will want to
listen to state updates or update the state of the application.
For example, we can export the "Readiness" state of the application to a file so that a Kubernetes
"exec Probe" can look at this file:
@Component
public class ReadinessStateExporter {
@EventListener
public void onStateChange(AvailabilityChangeEvent<ReadinessState> event) {
switch (event.getState()) {
case ACCEPTING_TRAFFIC:
// create file /tmp/healthy
break;
case REFUSING_TRAFFIC:
// remove file /tmp/healthy
break;
}
}
We can also update the state of the application, when the application breaks and cannot recover:
48
@Component
public class LocalCacheVerifier {
Spring Boot provides Kubernetes HTTP probes for "Liveness" and "Readiness" with Actuator Health
Endpoints. You can get more guidance about deploying Spring Boot applications on Kubernetes in
the dedicated section.
Some events are actually triggered before the ApplicationContext is created, so you
cannot register a listener on those as a @Bean. You can register them with the
SpringApplication.addListeners(…) method or the
SpringApplicationBuilder.listeners(…) method.
If you want those listeners to be registered automatically, regardless of the way the
application is created, you can add a META-INF/spring.factories file to your project
and reference your listener(s) by using the
org.springframework.context.ApplicationListener key, as shown in the following
example:
org.springframework.context.ApplicationListener=com.example.project.MyL
istener
Application events are sent in the following order, as your application runs:
1. An ApplicationStartingEvent is sent at the start of a run but before any processing, except for
49
the registration of listeners and initializers.
4. An ApplicationPreparedEvent is sent just before the refresh is started but after bean definitions
have been loaded.
5. An ApplicationStartedEvent is sent after the context has been refreshed but before any
application and command-line runners have been called.
7. An ApplicationReadyEvent is sent after any application and command-line runners have been
called.
The above list only includes SpringApplicationEvents that are tied to a SpringApplication. In
addition to these, the following events are also published after ApplicationPreparedEvent and before
ApplicationStartedEvent:
You often need not use application events, but it can be handy to know that they
exist. Internally, Spring Boot uses events to handle a variety of tasks.
Event listeners should not run potentially lengthy tasks as they execute in the
same thread by default. Consider using application and command-line runners
instead.
Application events are sent by using Spring Framework’s event publishing mechanism. Part of this
mechanism ensures that an event published to the listeners in a child context is also published to
the listeners in any ancestor contexts. As a result of this, if your application uses a hierarchy of
SpringApplication instances, a listener may receive multiple instances of the same type of
application event.
To allow your listener to distinguish between an event for its context and an event for a descendant
context, it should request that its application context is injected and then compare the injected
context with the context of the event. The context can be injected by implementing
ApplicationContextAware or, if the listener is a bean, by using @Autowired.
50
5.1.8. Web Environment
A SpringApplication attempts to create the right type of ApplicationContext on your behalf. The
algorithm used to determine a WebApplicationType is the following:
This means that if you are using Spring MVC and the new WebClient from Spring WebFlux in the
same application, Spring MVC will be used by default. You can override that easily by calling
setWebApplicationType(WebApplicationType).
It is also possible to take complete control of the ApplicationContext type that is used by calling
setApplicationContextClass(…).
If you need to access the application arguments that were passed to SpringApplication.run(…), you
can inject a org.springframework.boot.ApplicationArguments bean. The ApplicationArguments
interface provides access to both the raw String[] arguments as well as parsed option and non-
option arguments, as shown in the following example:
import org.springframework.boot.*;
import org.springframework.beans.factory.annotation.*;
import org.springframework.stereotype.*;
@Component
public class MyBean {
@Autowired
public MyBean(ApplicationArguments args) {
boolean debug = args.containsOption("debug");
List<String> files = args.getNonOptionArgs();
// if run with "--debug logfile.txt" debug=true, files=["logfile.txt"]
}
51
5.1.10. Using the ApplicationRunner or CommandLineRunner
If you need to run some specific code once the SpringApplication has started, you can implement
the ApplicationRunner or CommandLineRunner interfaces. Both interfaces work in the same way and
offer a single run method, which is called just before SpringApplication.run(…) completes.
This contract is well suited for tasks that should run after application startup but
before it starts accepting traffic.
import org.springframework.boot.*;
import org.springframework.stereotype.*;
@Component
public class MyBean implements CommandLineRunner {
If several CommandLineRunner or ApplicationRunner beans are defined that must be called in a specific
order, you can additionally implement the org.springframework.core.Ordered interface or use the
org.springframework.core.annotation.Order annotation.
Each SpringApplication registers a shutdown hook with the JVM to ensure that the
ApplicationContext closes gracefully on exit. All the standard Spring lifecycle callbacks (such as the
DisposableBean interface or the @PreDestroy annotation) can be used.
52
@SpringBootApplication
public class ExitCodeApplication {
@Bean
public ExitCodeGenerator exitCodeGenerator() {
return () -> 42;
}
Also, the ExitCodeGenerator interface may be implemented by exceptions. When such an exception
is encountered, Spring Boot returns the exit code provided by the implemented getExitCode()
method.
If you want to know on which HTTP port the application is running, get the
property with a key of local.server.port.
Spring Boot uses a very particular PropertySource order that is designed to allow sensible
overriding of values. Properties are considered in the following order:
3. properties attribute on your tests. Available on @SpringBootTest and the test annotations for
testing a particular slice of your application.
53
4. Command line arguments.
14. Application properties outside of your packaged jar (application.properties and YAML
variants).
15. Application properties packaged inside your jar (application.properties and YAML variants).
16. @PropertySource annotations on your @Configuration classes. Please note that such property
sources are not added to the Environment until the application context is being refreshed. This is
too late to configure certain properties such as logging.* and spring.main.* which are read
before refresh begins.
To provide a concrete example, suppose you develop a @Component that uses a name property, as
shown in the following example:
import org.springframework.stereotype.*;
import org.springframework.beans.factory.annotation.*;
@Component
public class MyBean {
@Value("${name}")
private String name;
// ...
On your application classpath (for example, inside your jar) you can have an
application.properties file that provides a sensible default property value for name. When running
in a new environment, an application.properties file can be provided outside of your jar that
overrides the name. For one-off testing, you can launch with a specific command line switch (for
example, java -jar app.jar --name="Spring").
54
The env and configprops endpoints can be useful in determining why a property
has a particular value. You can use these two endpoints to diagnose unexpected
property values. See the "Production ready features" section for details.
Spring Boot also supports wildcard locations when loading configuration files. By default, a
wildcard location of config/*/ outside of your jar is supported. Wildcard locations are also
supported when specifying spring.config.additional-location and spring.config.location.
Wildcard locations are particularly useful in an environment such as Kubernetes when there are
multiple sources of config properties. For example, if you have some Redis configuration and some
MySQL configuration, you might want to keep those two pieces of configuration separate, while
requiring that both those are present in an application.properties that the app can bind to. This
might result in two separate application.properties files mounted at different locations such as
/config/redis/application.properties and /config/mysql/application.properties. In such a case,
having a wildcard location of config/*/, will result in both files being processed.
A wildcard location must contain only one and end with / for search locations
that are directories or */<filename> for search locations that are files. Locations
with wildcards are sorted alphabetically based on the absolute path of the file
names.
You can also supply the JSON by using a command line argument, as shown in the
following example:
55
Although null values from the JSON will be added to the resulting property source,
the PropertySourcesPropertyResolver treats null properties as missing values. This
means that the JSON cannot override properties from lower order property
sources with a null value.
The RandomValuePropertySource is useful for injecting random values (for example, into secrets or
test cases). It can produce integers, longs, uuids, or strings, as shown in the following example:
my.secret=${random.value}
my.number=${random.int}
my.bignumber=${random.long}
my.uuid=${random.uuid}
my.number.less.than.ten=${random.int(10)}
my.number.in.range=${random.int[1024,65536]}
The random.int* syntax is OPEN value (,max) CLOSE where the OPEN,CLOSE are any character and
value,max are integers. If max is provided, then value is the minimum value and max is the maximum
value (exclusive).
By default, SpringApplication converts any command line option arguments (that is, arguments
starting with --, such as --server.port=9000) to a property and adds them to the Spring Environment.
As mentioned previously, command line properties always take precedence over other property
sources.
If you do not want command line properties to be added to the Environment, you can disable them
by using SpringApplication.setAddCommandLineProperties(false).
SpringApplication loads properties from application.properties files in the following locations and
adds them to the Spring Environment:
The list is ordered by precedence (properties defined in locations higher in the list override those
defined in lower locations).
56
If you do not like application.properties as the configuration file name, you can switch to another
file name by specifying a spring.config.name environment property. You can also refer to an explicit
location by using the spring.config.location environment property (which is a comma-separated
list of directory locations or file paths). The following example shows how to specify a different file
name:
If spring.config.location contains directories (as opposed to files), they should end in / (and, at
runtime, be appended with the names generated from spring.config.name before being loaded,
including profile-specific file names). Files specified in spring.config.location are used as-is, with
no support for profile-specific variants, and are overridden by any profile-specific properties.
Whether specified directly or contained in a directory, configuration files must include a file
extension in their name. Typical extensions that are supported out-of-the-box are .properties,
.yaml, and .yml.
Config locations are searched in reverse order. By default, the configured locations are
classpath:/,classpath:/config/,file:./,file:./config/*/,file:./config/. The resulting search
order is the following:
1. file:./config/
2. file:./config/*/
3. file:./
4. classpath:/config/
5. classpath:/
When custom config locations are configured by using spring.config.location, they replace the
default locations. For example, if spring.config.location is configured with the value
classpath:/custom-config/,file:./custom-config/, the search order becomes the following:
1. file:./custom-config/
2. classpath:custom-config/
57
the default locations. For example, if additional locations of classpath:/custom-
config/,file:./custom-config/ are configured, the search order becomes the following:
1. file:./custom-config/
2. classpath:custom-config/
3. file:./config/
4. file:./config/*/
5. file:./
6. classpath:/config/
7. classpath:/
This search ordering lets you specify default values in one configuration file and then selectively
override those values in another. You can provide default values for your application in
application.properties (or whatever other basename you choose with spring.config.name) in one of
the default locations. These default values can then be overridden at runtime with a different file
located in one of the custom locations.
If you use environment variables rather than system properties, most operating
systems disallow period-separated key names, but you can use underscores
instead (for example, SPRING_CONFIG_NAME instead of spring.config.name). See
Binding from Environment Variables for details.
Profile-specific properties are loaded from the same locations as standard application.properties,
with profile-specific files always overriding the non-specific ones, whether or not the profile-
specific files are inside or outside your packaged jar.
If several profiles are specified, a last-wins strategy applies. For example, profiles specified by the
spring.profiles.active property are added after those configured through the SpringApplication
API and therefore take precedence.
58
5.2.5. Placeholders in Properties
The values in application.properties are filtered through the existing Environment when they are
used, so you can refer back to previously defined values (for example, from System properties).
app.name=MyApp
app.description=${app.name} is a Spring Boot application
You can also use this technique to create “short” variants of existing Spring Boot
properties. See the Use ‘Short’ Command Line Arguments how-to for details.
Spring Boot does not provide any built in support for encrypting property values, however, it does
provide the hook points necessary to modify values contained in the Spring Environment. The
EnvironmentPostProcessor interface allows you to manipulate the Environment before the application
starts. See Customize the Environment or ApplicationContext Before It Starts for details.
If you’re looking for a secure way to store credentials and passwords, the Spring Cloud Vault project
provides support for storing externalized configuration in HashiCorp Vault.
YAML is a superset of JSON and, as such, is a convenient format for specifying hierarchical
configuration data. The SpringApplication class automatically supports YAML as an alternative to
properties whenever you have the SnakeYAML library on your classpath.
Loading YAML
Spring Framework provides two convenient classes that can be used to load YAML documents. The
YamlPropertiesFactoryBean loads YAML as Properties and the YamlMapFactoryBean loads YAML as a
Map.
environments:
dev:
url: https://dev.example.com
name: Developer Setup
prod:
url: https://another.example.com
name: My Cool App
59
environments.dev.url=https://dev.example.com
environments.dev.name=Developer Setup
environments.prod.url=https://another.example.com
environments.prod.name=My Cool App
YAML lists are represented as property keys with [index] dereferencers. For example, consider the
following YAML:
my:
servers:
- dev.example.com
- another.example.com
my.servers[0]=dev.example.com
my.servers[1]=another.example.com
To bind to properties like that by using Spring Boot’s Binder utilities (which is what
@ConfigurationProperties does), you need to have a property in the target bean of type
java.util.List (or Set) and you either need to provide a setter or initialize it with a mutable value.
For example, the following example binds to the properties shown previously:
@ConfigurationProperties(prefix="my")
public class Config {
The YamlPropertySourceLoader class can be used to expose YAML as a PropertySource in the Spring
Environment. Doing so lets you use the @Value annotation with placeholders syntax to access YAML
properties.
You can specify multiple profile-specific YAML documents in a single file by using a spring.profiles
key to indicate when the document applies, as shown in the following example:
60
server:
address: 192.168.1.100
---
spring:
profiles: development
server:
address: 127.0.0.1
---
spring:
profiles: production & eu-central
server:
address: 192.168.1.120
In the preceding example, if the development profile is active, the server.address property is
127.0.0.1. Similarly, if the production and eu-central profiles are active, the server.address property
is 192.168.1.120. If the development, production and eu-central profiles are not enabled, then the
value for the property is 192.168.1.100.
If none are explicitly active when the application context starts, the default profiles are activated.
So, in the following YAML, we set a value for spring.security.user.password that is available only in
the "default" profile:
server:
port: 8000
---
spring:
profiles: default
security:
user:
password: weak
Whereas, in the following example, the password is always set because it is not attached to any
profile, and it would have to be explicitly reset in all other profiles as necessary:
server:
port: 8000
spring:
security:
user:
password: weak
61
Spring profiles designated by using the spring.profiles element may optionally be negated by using
the ! character. If both negated and non-negated profiles are specified for a single document, at
least one non-negated profile must match, and no negated profiles may match.
YAML Shortcomings
YAML files cannot be loaded by using the @PropertySource annotation. So, in the case that you need
to load values that way, you need to use a properties file.
Using the multi YAML document syntax in profile-specific YAML files can lead to unexpected
behavior. For example, consider the following config in a file:
application-dev.yml
server:
port: 8000
---
spring:
profiles: "!test"
security:
user:
password: "secret"
If you run the application with the argument --spring.profiles.active=dev you might expect
security.user.password to be set to “secret”, but this is not the case.
The nested document will be filtered because the main file is named application-dev.yml. It is
already considered to be profile-specific, and nested documents will be ignored.
We recommend that you don’t mix profile-specific YAML files and multiple YAML
documents. Stick to using only one of them.
See also the differences between @Value and type-safe configuration properties.
It is possible to bind a bean declaring standard JavaBean properties as shown in the following
example:
62
package com.example;
import java.net.InetAddress;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import org.springframework.boot.context.properties.ConfigurationProperties;
@ConfigurationProperties("acme")
public class AcmeProperties {
}
}
63
The preceding POJO defines the following properties:
• acme.security.username, with a nested "security" object whose name is determined by the name
of the property. In particular, the return type is not used at all there and could have been
SecurityProperties.
• acme.security.password.
Such arrangement relies on a default empty constructor and getters and setters
are usually mandatory, since binding is through standard Java Beans property
descriptors, just like in Spring MVC. A setter may be omitted in the following cases:
• Maps, as long as they are initialized, need a getter but not necessarily a setter,
since they can be mutated by the binder.
• Collections and arrays can be accessed either through an index (typically with
YAML) or by using a single comma-separated value (properties). In the latter
case, a setter is mandatory. We recommend to always add a setter for such
types. If you initialize a collection, make sure it is not immutable (as in the
preceding example).
• If nested POJO properties are initialized (like the Security field in the preceding
example), a setter is not required. If you want the binder to create the instance
on the fly by using its default constructor, you need a setter.
Some people use Project Lombok to add getters and setters automatically. Make
sure that Lombok does not generate any particular constructor for such a type, as
it is used automatically by the container to instantiate the object.
Finally, only standard Java Bean properties are considered and binding on static
properties is not supported.
Constructor binding
The example in the previous section can be rewritten in an immutable fashion as shown in the
following example:
package com.example;
import java.net.InetAddress;
import java.util.List;
64
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.ConstructorBinding;
import org.springframework.boot.context.properties.bind.DefaultValue;
@ConstructorBinding
@ConfigurationProperties("acme")
public class AcmeProperties {
}
65
}
In this setup, the @ConstructorBinding annotation is used to indicate that constructor binding should
be used. This means that the binder will expect to find a constructor with the parameters that you
wish to have bound.
Nested members of a @ConstructorBinding class (such as Security in the example above) will also be
bound via their constructor.
Default values can be specified using @DefaultValue and the same conversion service will be applied
to coerce the String value to the target type of a missing property. By default, if no properties are
bound to Security, the AcmeProperties instance will contain a null value for security. If you wish
you return a non-null instance of Security even when no properties are bound to it, you can use an
empty @DefaultValue annotation to do so:
package com.example;
import java.net.InetAddress;
import java.util.List;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.ConstructorBinding;
import org.springframework.boot.context.properties.bind.DefaultValue;
@ConstructorBinding
@ConfigurationProperties("acme")
public class AcmeProperties {
66
If you have more than one constructor for your class you can also use
@ConstructorBinding directly on the constructor that should be bound.
Spring Boot provides infrastructure to bind @ConfigurationProperties types and register them as
beans. You can either enable configuration properties on a class-by-class basis or enable
configuration property scanning that works in a similar manner to component scanning.
Sometimes, classes annotated with @ConfigurationProperties might not be suitable for scanning, for
example, if you’re developing your own auto-configuration or you want to enable them
conditionally. In these cases, specify the list of types to process using the
@EnableConfigurationProperties annotation. This can be done on any @Configuration class, as shown
in the following example:
@Configuration(proxyBeanMethods = false)
@EnableConfigurationProperties(AcmeProperties.class)
public class MyConfiguration {
}
@SpringBootApplication
@ConfigurationPropertiesScan({ "com.example.app", "org.acme.another" })
public class MyApplication {
}
67
We recommend that @ConfigurationProperties only deal with the environment and, in particular,
does not inject other beans from the context. For corner cases, setter injection can be used or any of
the *Aware interfaces provided by the framework (such as EnvironmentAware if you need access to the
Environment). If you still want to inject other beans using the constructor, the configuration
properties bean must be annotated with @Component and use JavaBean-based property binding.
This style of configuration works particularly well with the SpringApplication external YAML
configuration, as shown in the following example:
# application.yml
acme:
remote-address: 192.168.1.1
security:
username: admin
roles:
- USER
- ADMIN
To work with @ConfigurationProperties beans, you can inject them in the same way as any other
bean, as shown in the following example:
@Service
public class MyService {
@Autowired
public MyService(AcmeProperties properties) {
this.properties = properties;
}
//...
@PostConstruct
public void openConnection() {
Server server = new Server(this.properties.getRemoteAddress());
// ...
}
68
Using @ConfigurationProperties also lets you generate metadata files that can be
used by IDEs to offer auto-completion for your own keys. See the appendix for
details.
Third-party Configuration
As well as using @ConfigurationProperties to annotate a class, you can also use it on public @Bean
methods. Doing so can be particularly useful when you want to bind properties to third-party
components that are outside of your control.
To configure a bean from the Environment properties, add @ConfigurationProperties to its bean
registration, as shown in the following example:
@ConfigurationProperties(prefix = "another")
@Bean
public AnotherComponent anotherComponent() {
...
}
Any JavaBean property defined with the another prefix is mapped onto that AnotherComponent bean
in manner similar to the preceding AcmeProperties example.
Relaxed Binding
Spring Boot uses some relaxed rules for binding Environment properties to @ConfigurationProperties
beans, so there does not need to be an exact match between the Environment property name and the
bean property name. Common examples where this is useful include dash-separated environment
properties (for example, context-path binds to contextPath), and capitalized environment properties
(for example, PORT binds to port).
@ConfigurationProperties(prefix="acme.my-project.person")
public class OwnerProperties {
With the preceding code, the following properties names can all be used:
69
Table 5. relaxed binding
Property Note
acme.my- Kebab case, which is recommended for use in .properties and .yml files.
project.person.fir
st-name
acme.myProject.per Standard camel case syntax.
son.firstName
acme.my_project.pe Underscore notation, which is an alternative format for use in .properties and
rson.first_name .yml files.
ACME_MYPROJECT_PER Upper case format, which is recommended when using system environment
SON_FIRSTNAME variables.
The prefix value for the annotation must be in kebab case (lowercase and
separated by -, such as acme.my-project.person).
Properties Files Camel case, kebab case, or underscore Standard list syntax using [ ] or
notation comma-separated values
YAML Files Camel case, kebab case, or underscore Standard YAML list syntax or comma-
notation separated values
System properties Camel case, kebab case, or underscore Standard list syntax using [ ] or
notation comma-separated values
Binding Maps
When binding to Map properties you may need to use a special bracket notation so that the original
key value is preserved. If the key is not surrounded by [], any characters that are not alpha-
numeric, - or . are removed.
acme:
map:
"[/key1]": "value1"
"[/key2]": "value2"
"/key3": "value3"
70
For YAML files, the brackets need to be surrounded by quotes for the keys to be
parsed properly.
The properties above will bind to a Map with /key1, /key2 and key3 as the keys in the map. The slash
has been removed from key3 because it wasn’t surrounded by square brackets.
You may also occasionally need to use the bracket notation if your key contains a . and you are
binding to non-scalar value. For example, binding a.b=c to Map<String, Object> will return a Map
with the entry {"a"={"b"="c"}} where as [a.b]=c will return a Map with the entry {"a.b"="c"}.
Most operating systems impose strict rules around the names that can be used for environment
variables. For example, Linux shell variables can contain only letters (a to z or A to Z), numbers (0 to
9) or the underscore character (_). By convention, Unix shell variables will also have their names in
UPPERCASE.
Spring Boot’s relaxed binding rules are, as much as possible, designed to be compatible with these
naming restrictions.
To convert a property name in the canonical-form to an environment variable name you can follow
these rules:
• Convert to uppercase.
Environment variables can also be used when binding to object lists. To bind to a List, the element
number should be surrounded with underscores in the variable name.
For example, the configuration property my.acme[0].other would use an environment variable
named MY_ACME_0_OTHER.
When lists are configured in more than one place, overriding works by replacing the entire list.
For example, assume a MyPojo object with name and description attributes that are null by default.
The following example exposes a list of MyPojo objects from AcmeProperties:
71
@ConfigurationProperties("acme")
public class AcmeProperties {
acme:
list:
- name: my name
description: my description
---
spring:
profiles: dev
acme:
list:
- name: my another name
If the dev profile is not active, AcmeProperties.list contains one MyPojo entry, as previously defined.
If the dev profile is enabled, however, the list still contains only one entry (with a name of my
another name and a description of null). This configuration does not add a second MyPojo instance to
the list, and it does not merge the items.
When a List is specified in multiple profiles, the one with the highest priority (and only that one) is
used. Consider the following example:
acme:
list:
- name: my name
description: my description
- name: another name
description: another description
---
spring:
profiles: dev
acme:
list:
- name: my another name
In the preceding example, if the dev profile is active, AcmeProperties.list contains one MyPojo entry
(with a name of my another name and a description of null). For YAML, both comma-separated lists
72
and YAML lists can be used for completely overriding the contents of the list.
For Map properties, you can bind with property values drawn from multiple sources. However, for
the same property in multiple sources, the one with the highest priority is used. The following
example exposes a Map<String, MyPojo> from AcmeProperties:
@ConfigurationProperties("acme")
public class AcmeProperties {
acme:
map:
key1:
name: my name 1
description: my description 1
---
spring:
profiles: dev
acme:
map:
key1:
name: dev name 1
key2:
name: dev name 2
description: dev description 2
If the dev profile is not active, AcmeProperties.map contains one entry with key key1 (with a name of
my name 1 and a description of my description 1). If the dev profile is enabled, however, map contains
two entries with keys key1 (with a name of dev name 1 and a description of my description 1) and
key2 (with a name of dev name 2 and a description of dev description 2).
The preceding merging rules apply to properties from all property sources and not
just YAML files.
Properties Conversion
Spring Boot attempts to coerce the external application properties to the right type when it binds to
the @ConfigurationProperties beans. If you need custom type conversion, you can provide a
ConversionService bean (with a bean named conversionService) or custom property editors (through
73
a CustomEditorConfigurer bean) or custom Converters (with bean definitions annotated as
@ConfigurationPropertiesBinding).
As this bean is requested very early during the application lifecycle, make sure to
limit the dependencies that your ConversionService is using. Typically, any
dependency that you require may not be fully initialized at creation time. You may
want to rename your custom ConversionService if it is not required for
configuration keys coercion and only rely on custom converters qualified with
@ConfigurationPropertiesBinding.
Converting durations
Spring Boot has dedicated support for expressing durations. If you expose a java.time.Duration
property, the following formats in application properties are available:
• A regular long representation (using milliseconds as the default unit unless a @DurationUnit has
been specified)
• A more readable format where the value and the unit are coupled (e.g. 10s means 10 seconds)
@ConfigurationProperties("app.system")
public class AppSystemProperties {
@DurationUnit(ChronoUnit.SECONDS)
private Duration sessionTimeout = Duration.ofSeconds(30);
74
To specify a session timeout of 30 seconds, 30, PT30S and 30s are all equivalent. A read timeout of
500ms can be specified in any of the following form: 500, PT0.5S and 500ms.
You can also use any of the supported units. These are:
• ns for nanoseconds
• us for microseconds
• ms for milliseconds
• s for seconds
• m for minutes
• h for hours
• d for days
The default unit is milliseconds and can be overridden using @DurationUnit as illustrated in the
sample above. Note that @DurationUnit is only supported with JavaBean-style property binding
using getters and setters. It is not supported with constructor binding.
If you are upgrading a Long property, make sure to define the unit (using
@DurationUnit) if it isn’t milliseconds. Doing so gives a transparent upgrade path
while supporting a much richer format.
Converting periods
In addition to durations, Spring Boot can also work with java.time.Period type. The following
formats can be used in application properties:
• An regular int representation (using days as the default unit unless a @PeriodUnit has been
specified)
• A simpler format where the value and the unit pairs are coupled (e.g. 1y3d means 1 year and 3
days)
• y for years
• m for months
• w for weeks
• d for days
Spring Framework has a DataSize value type that expresses a size in bytes. If you expose a DataSize
75
property, the following formats in application properties are available:
• A regular long representation (using bytes as the default unit unless a @DataSizeUnit has been
specified)
• A more readable format where the value and the unit are coupled (e.g. 10MB means 10
megabytes)
@ConfigurationProperties("app.io")
public class AppIoProperties {
@DataSizeUnit(DataUnit.MEGABYTES)
private DataSize bufferSize = DataSize.ofMegabytes(2);
To specify a buffer size of 10 megabytes, 10 and 10MB are equivalent. A size threshold of 256 bytes
can be specified as 256 or 256B.
You can also use any of the supported units. These are:
• B for bytes
• KB for kilobytes
• MB for megabytes
• GB for gigabytes
• TB for terabytes
The default unit is bytes and can be overridden using @DataSizeUnit as illustrated in the sample
above.
76
If you are upgrading a Long property, make sure to define the unit (using
@DataSizeUnit) if it isn’t bytes. Doing so gives a transparent upgrade path while
supporting a much richer format.
@ConfigurationProperties Validation
Spring Boot attempts to validate @ConfigurationProperties classes whenever they are annotated
with Spring’s @Validated annotation. You can use JSR-303 javax.validation constraint annotations
directly on your configuration class. To do so, ensure that a compliant JSR-303 implementation is on
your classpath and then add constraint annotations to your fields, as shown in the following
example:
@ConfigurationProperties(prefix="acme")
@Validated
public class AcmeProperties {
@NotNull
private InetAddress remoteAddress;
You can also trigger validation by annotating the @Bean method that creates the
configuration properties with @Validated.
To ensure that validation is always triggered for nested properties, even when no properties are
found, the associated field must be annotated with @Valid. The following example builds on the
preceding AcmeProperties example:
77
@ConfigurationProperties(prefix="acme")
@Validated
public class AcmeProperties {
@NotNull
private InetAddress remoteAddress;
@Valid
private final Security security = new Security();
@NotEmpty
public String username;
}
You can also add a custom Spring Validator by creating a bean definition called
configurationPropertiesValidator. The @Bean method should be declared static. The configuration
properties validator is created very early in the application’s lifecycle, and declaring the @Bean
method as static lets the bean be created without having to instantiate the @Configuration class.
Doing so avoids any problems that may be caused by early instantiation.
The @Value annotation is a core container feature, and it does not provide the same features as type-
safe configuration properties. The following table summarizes the features that are supported by
@ConfigurationProperties and @Value:
78
If you do want to use @Value, we recommend that you refer to property names
using their canonical form (kebab-case using only lowercase letters). This will
allow Spring Boot to use the same logic as it does when relaxed binding
@ConfigurationProperties. For example, @Value("{demo.item-price}") will pick up
demo.item-price and demo.itemPrice forms from the application.properties file, as
well as DEMO_ITEMPRICE from the system environment. If you used
@Value("{demo.itemPrice}") instead, demo.item-price and DEMO_ITEMPRICE would not
be considered.
If you define a set of configuration keys for your own components, we recommend you group them
in a POJO annotated with @ConfigurationProperties. Doing so will provide you with structured,
type-safe object that you can inject into your own beans.
SpEL expressions from application property files are not processed at time of parsing these files and
populating the environment. However, it is possible to write a SpEL expression in @Value. If the
value of a property from an application property file is a SpEL expression, it will be evaluated when
consumed via @Value.
5.3. Profiles
Spring Profiles provide a way to segregate parts of your application configuration and make it be
available only in certain environments. Any @Component, @Configuration or @ConfigurationProperties
can be marked with @Profile to limit when it is loaded, as shown in the following example:
@Configuration(proxyBeanMethods = false)
@Profile("production")
public class ProductionConfiguration {
// ...
You can use a spring.profiles.active Environment property to specify which profiles are active. You
can specify the property in any of the ways described earlier in this chapter. For example, you
could include it in your application.properties, as shown in the following example:
spring.profiles.active=dev,hsqldb
You could also specify it on the command line by using the following switch:
79
--spring.profiles.active=dev,hsqldb.
If no profile is active, a default profile is enabled. The name of the default profile is default and it
can be tuned using the spring.profiles.default Environment property, as shown in the following
example:
spring.profiles.default=none
The spring.profiles.active property follows the same ordering rules as other properties: The
highest PropertySource wins. This means that you can specify active profiles in
application.properties and then replace them by using the command line switch.
Sometimes, it is useful to have profile-specific properties that add to the active profiles rather than
replace them. The spring.profiles.include property can be used to unconditionally add active
profiles. The SpringApplication entry point also has a Java API for setting additional profiles (that is,
on top of those activated by the spring.profiles.active property). See the setAdditionalProfiles()
method in SpringApplication.
For example, when an application with the following properties is run by using the switch,
--spring.profiles.active=prod, the proddb and prodmq profiles are also activated:
---
my.property: fromyamlfile
---
spring.profiles: prod
spring.profiles.include:
- proddb
- prodmq
80
5.4. Logging
Spring Boot uses Commons Logging for all internal logging but leaves the underlying log
implementation open. Default configurations are provided for Java Util Logging, Log4J2, and
Logback. In each case, loggers are pre-configured to use console output with optional file output
also available.
By default, if you use the “Starters”, Logback is used for logging. Appropriate Logback routing is
also included to ensure that dependent libraries that use Java Util Logging, Commons Logging,
Log4J, or SLF4J all work correctly.
There are a lot of logging frameworks available for Java. Do not worry if the above
list seems confusing. Generally, you do not need to change your logging
dependencies and the Spring Boot defaults work just fine.
The default log output from Spring Boot resembles the following example:
• Process ID.
81
• Thread name: Enclosed in square brackets (may be truncated for console output).
• Logger name: This is usually the source class name (often abbreviated).
The default log configuration echoes messages to the console as they are written. By default, ERROR
-level, WARN-level, and INFO-level messages are logged. You can also enable a “debug” mode by
starting your application with a --debug flag.
When the debug mode is enabled, a selection of core loggers (embedded container, Hibernate, and
Spring Boot) are configured to output more information. Enabling the debug mode does not
configure your application to log all messages with DEBUG level.
Alternatively, you can enable a “trace” mode by starting your application with a --trace flag (or
trace=true in your application.properties). Doing so enables trace logging for a selection of core
loggers (embedded container, Hibernate schema generation, and the whole Spring portfolio).
Color-coded Output
If your terminal supports ANSI, color output is used to aid readability. You can set
spring.output.ansi.enabled to a supported value to override the auto-detection.
Color coding is configured by using the %clr conversion word. In its simplest form, the converter
colors the output according to the log level, as shown in the following example:
%clr(%5p)
Level Color
FATAL Red
ERROR Red
WARN Yellow
INFO Green
DEBUG Green
TRACE Green
82
Alternatively, you can specify the color or style that should be used by providing it as an option to
the conversion. For example, to make the text yellow, use the following setting:
%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){yellow}
• blue
• cyan
• faint
• green
• magenta
• red
• yellow
By default, Spring Boot logs only to the console and does not write log files. If you want to write log
files in addition to the console output, you need to set a logging.file.name or logging.file.path
property (for example, in your application.properties).
The following table shows how the logging.* properties can be used together:
Specific file (none) my.log Writes to the specified log file. Names can be an exact
location or relative to the current directory.
(none) Specific /var/log Writes spring.log to the specified directory. Names can
directory be an exact location or relative to the current directory.
Log files rotate when they reach 10 MB and, as with console output, ERROR-level, WARN-level, and INFO
-level messages are logged by default. Size limits can be changed using the logging.file.max-size
property. Rotated log files of the last 7 days are kept by default unless the logging.file.max-history
property has been set. The total size of log archives can be capped using logging.file.total-size-
cap. When the total size of log archives exceeds that threshold, backups will be deleted. To force log
archive cleanup on application startup, use the logging.file.clean-history-on-start property.
83
5.4.4. Log Levels
All the supported logging systems can have the logger levels set in the Spring Environment (for
example, in application.properties) by using logging.level.<logger-name>=<level> where level is
one of TRACE, DEBUG, INFO, WARN, ERROR, FATAL, or OFF. The root logger can be configured by
using logging.level.root.
logging.level.root=warn
logging.level.org.springframework.web=debug
logging.level.org.hibernate=error
It’s also possible to set logging levels using environment variables. For example,
LOGGING_LEVEL_ORG_SPRINGFRAMEWORK_WEB=DEBUG will set org.springframework.web to DEBUG.
The above approach will only work for package level logging. Since relaxed
binding always converts environment variables to lowercase, it’s not possible to
configure logging for an individual class in this way. If you need to configure
logging for a class, you can use the SPRING_APPLICATION_JSON variable.
It’s often useful to be able to group related loggers together so that they can all be configured at the
same time. For example, you might commonly change the logging levels for all Tomcat related
loggers, but you can’t easily remember top level packages.
To help with this, Spring Boot allows you to define logging groups in your Spring Environment. For
example, here’s how you could define a “tomcat” group by adding it to your application.properties:
Once defined, you can change the level for all the loggers in the group with a single line:
logging.level.tomcat=TRACE
Spring Boot includes the following pre-defined logging groups that can be used out-of-the-box:
Name Loggers
84
5.4.6. Using a Log Shutdown Hook
In order to release logging resources it is usually a good idea to stop the logging system when your
application terminates. Unfortunately, there’s no single way to do this that will work with all
application types. If your application has complex context hierarchies or is deployed as a war file,
you’ll need to investigate the options provided directly by the underlying logging system. For
example, Logback offers context selectors which allow each Logger to be created in its own context.
For simple "single jar" applications deployed in their own JVM, you can use the logging.register-
shutdown-hook property. Setting logging.register-shutdown-hook to true will register a shutdown
hook that will trigger log system cleanup when the JVM exits.
logging.register-shutdown-hook=true
The various logging systems can be activated by including the appropriate libraries on the
classpath and can be further customized by providing a suitable configuration file in the root of the
classpath or in a location specified by the following Spring Environment property: logging.config.
You can force Spring Boot to use a particular logging system by using the
org.springframework.boot.logging.LoggingSystem system property. The value should be the fully
qualified class name of a LoggingSystem implementation. You can also disable Spring Boot’s logging
configuration entirely by using a value of none.
When possible, we recommend that you use the -spring variants for your logging
configuration (for example, logback-spring.xml rather than logback.xml). If you use
standard configuration locations, Spring cannot completely control log
initialization.
85
There are known classloading issues with Java Util Logging that cause problems
when running from an 'executable jar'. We recommend that you avoid it when
running from an 'executable jar' if at all possible.
To help with the customization, some other properties are transferred from the Spring Environment
to System properties, as described in the following table:
86
Spring Environment System Property Comments
logging.pattern.level LOG_LEVEL_PATTERN The format to use when
rendering the log level (default
%5p). (Only supported with the
default Logback setup.)
logging.pattern.rolling-file- ROLLING_FILE_NAME_PATTERN Pattern for rolled-over log file
name names (default
${LOG_FILE}.%d{yyyy-MM-
dd}.%i.gz). (Only supported
with the default Logback setup.)
PID PID The current process ID
(discovered if possible and
when not already defined as an
OS environment variable).
All the supported logging systems can consult System properties when parsing their configuration
files. See the default configurations in spring-boot.jar for examples:
• Logback
• Log4j 2
If you want to use a placeholder in a logging property, you should use Spring
Boot’s syntax and not the syntax of the underlying framework. Notably, if you use
Logback, you should use : as the delimiter between a property name and its
default value and not use :-.
You can add MDC and other ad-hoc content to log lines by overriding only the
LOG_LEVEL_PATTERN (or logging.pattern.level with Logback). For example, if you use
logging.pattern.level=user:%X{user} %5p, then the default log format contains an
MDC entry for "user", if it exists, as shown in the following example.
2019-08-30 12:30:04.031 user:someone INFO 22174 --- [ nio-8080-exec-0]
demo.Controller
Handling authenticated request
Spring Boot includes a number of extensions to Logback that can help with advanced configuration.
You can use these extensions in your logback-spring.xml configuration file.
Because the standard logback.xml configuration file is loaded too early, you cannot
use extensions in it. You need to either use logback-spring.xml or define a
logging.config property.
87
The extensions cannot be used with Logback’s configuration scanning. If you
attempt to do so, making changes to the configuration file results in an error
similar to one of the following being logged:
Profile-specific Configuration
The <springProfile> tag lets you optionally include or exclude sections of configuration based on
the active Spring profiles. Profile sections are supported anywhere within the <configuration>
element. Use the name attribute to specify which profile accepts the configuration. The
<springProfile> tag can contain a profile name (for example staging) or a profile expression. A
profile expression allows for more complicated profile logic to be expressed, for example
production & (eu-central | eu-west). Check the reference guide for more details. The following
listing shows three sample profiles:
<springProfile name="staging">
<!-- configuration to be enabled when the "staging" profile is active -->
</springProfile>
<springProfile name="!production">
<!-- configuration to be enabled when the "production" profile is not active -->
</springProfile>
Environment Properties
The <springProperty> tag lets you expose properties from the Spring Environment for use within
Logback. Doing so can be useful if you want to access values from your application.properties file
in your Logback configuration. The tag works in a similar way to Logback’s standard <property> tag.
However, rather than specifying a direct value, you specify the source of the property (from the
Environment). If you need to store the property somewhere other than in local scope, you can use
the scope attribute. If you need a fallback value (in case the property is not set in the Environment),
you can use the defaultValue attribute. The following example shows how to expose properties for
use within Logback:
88
<springProperty scope="context" name="fluentHost" source="myapp.fluentd.host"
defaultValue="localhost"/>
<appender name="FLUENT" class="ch.qos.logback.more.appenders.DataFluentAppender">
<remoteHost>${fluentHost}</remoteHost>
...
</appender>
5.5. Internationalization
Spring Boot supports localized messages so that your application can cater to users of different
language preferences. By default, Spring Boot looks for the presence of a messages resource bundle
at the root of the classpath.
The auto-configuration applies when the default properties file for the configured
resource bundle is available (i.e. messages.properties by default). If your resource
bundle contains only language-specific properties files, you are required to add
the default. If no properties file is found that matches any of the configured base
names, there will be no auto-configured MessageSource.
The basename of the resource bundle as well as several other attributes can be configured using
the spring.messages namespace, as shown in the following example:
spring.messages.basename=messages,config.i18n.messages
spring.messages.fallback-to-system-locale=false
5.6. JSON
Spring Boot provides integration with three JSON mapping libraries:
• Gson
• Jackson
• JSON-B
89
5.6.1. Jackson
5.6.2. Gson
Auto-configuration for Gson is provided. When Gson is on the classpath a Gson bean is automatically
configured. Several spring.gson.* configuration properties are provided for customizing the
configuration. To take more control, one or more GsonBuilderCustomizer beans can be used.
5.6.3. JSON-B
Auto-configuration for JSON-B is provided. When the JSON-B API and an implementation are on the
classpath a Jsonb bean will be automatically configured. The preferred JSON-B implementation is
Apache Johnzon for which dependency management is provided.
If you have not yet developed a Spring Boot web application, you can follow the "Hello World!"
example in the Getting started section.
The Spring Web MVC framework (often referred to as “Spring MVC”) is a rich “model view
controller” web framework. Spring MVC lets you create special @Controller or @RestController
beans to handle incoming HTTP requests. Methods in your controller are mapped to HTTP by using
@RequestMapping annotations.
The following code shows a typical @RestController that serves JSON data:
90
@RestController
@RequestMapping(value="/users")
public class MyRestController {
@RequestMapping(value="/{user}", method=RequestMethod.GET)
public User getUser(@PathVariable Long user) {
// ...
}
@RequestMapping(value="/{user}/customers", method=RequestMethod.GET)
List<Customer> getUserCustomers(@PathVariable Long user) {
// ...
}
@RequestMapping(value="/{user}", method=RequestMethod.DELETE)
public User deleteUser(@PathVariable Long user) {
// ...
}
Spring MVC is part of the core Spring Framework, and detailed information is available in the
reference documentation. There are also several guides that cover Spring MVC available at
spring.io/guides.
Spring Boot provides auto-configuration for Spring MVC that works well with most applications.
• Support for serving static resources, including support for WebJars (covered later in this
document)).
If you want to keep those Spring Boot MVC customizations and make more MVC customizations
(interceptors, formatters, view controllers, and other features), you can add your own
@Configuration class of type WebMvcConfigurer but without @EnableWebMvc.
91
RequestMappingHandlerAdapter, or ExceptionHandlerExceptionResolver, and still keep the Spring Boot
MVC customizations, you can declare a bean of type WebMvcRegistrations and use it to provide
custom instances of those components.
If you want to take complete control of Spring MVC, you can add your own @Configuration
annotated with @EnableWebMvc, or alternatively add your own @Configuration-annotated
DelegatingWebMvcConfiguration as described in the Javadoc of @EnableWebMvc.
Spring MVC uses a different ConversionService to the one used to convert values
from your application.properties or application.yaml file. The means that Period,
Duration and DataSize converters are not available and that @DurationUnit and
@DataSizeUnit annotations will be ignored.
If you want to customize the ConversionService used by Spring MVC, you can
provide a WebMvcConfigurer bean with an addFormatters method. From this method
you can register any converter that you like, or you can delegate to the static
methods available on ApplicationConversionService.
HttpMessageConverters
Spring MVC uses the HttpMessageConverter interface to convert HTTP requests and responses.
Sensible defaults are included out of the box. For example, objects can be automatically converted
to JSON (by using the Jackson library) or XML (by using the Jackson XML extension, if available, or
by using JAXB if the Jackson XML extension is not available). By default, strings are encoded in UTF-
8.
If you need to add or customize converters, you can use Spring Boot’s HttpMessageConverters class,
as shown in the following listing:
import org.springframework.boot.autoconfigure.http.HttpMessageConverters;
import org.springframework.context.annotation.*;
import org.springframework.http.converter.*;
@Configuration(proxyBeanMethods = false)
public class MyConfiguration {
@Bean
public HttpMessageConverters customConverters() {
HttpMessageConverter<?> additional = ...
HttpMessageConverter<?> another = ...
return new HttpMessageConverters(additional, another);
}
Any HttpMessageConverter bean that is present in the context is added to the list of converters. You
can also override default converters in the same way.
92
Custom JSON Serializers and Deserializers
If you use Jackson to serialize and deserialize JSON data, you might want to write your own
JsonSerializer and JsonDeserializer classes. Custom serializers are usually registered with Jackson
through a module, but Spring Boot provides an alternative @JsonComponent annotation that makes it
easier to directly register Spring Beans.
import java.io.*;
import com.fasterxml.jackson.core.*;
import com.fasterxml.jackson.databind.*;
import org.springframework.boot.jackson.*;
@JsonComponent
public class Example {
All @JsonComponent beans in the ApplicationContext are automatically registered with Jackson.
Because @JsonComponent is meta-annotated with @Component, the usual component-scanning rules
apply.
Spring Boot also provides JsonObjectSerializer and JsonObjectDeserializer base classes that
provide useful alternatives to the standard Jackson versions when serializing objects. See
JsonObjectSerializer and JsonObjectDeserializer in the Javadoc for details.
MessageCodesResolver
Spring MVC has a strategy for generating error codes for rendering error messages from binding
errors: MessageCodesResolver. If you set the spring.mvc.message-codes-resolver-format property
PREFIX_ERROR_CODE or POSTFIX_ERROR_CODE, Spring Boot creates one for you (see the enumeration in
DefaultMessageCodesResolver.Format).
Static Content
By default, Spring Boot serves static content from a directory called /static (or /public or
/resources or /META-INF/resources) in the classpath or from the root of the ServletContext. It uses
the ResourceHttpRequestHandler from Spring MVC so that you can modify that behavior by adding
93
your own WebMvcConfigurer and overriding the addResourceHandlers method.
In a stand-alone web application, the default servlet from the container is also enabled and acts as
a fallback, serving content from the root of the ServletContext if Spring decides not to handle it.
Most of the time, this does not happen (unless you modify the default MVC configuration), because
Spring can always handle requests through the DispatcherServlet.
By default, resources are mapped on /**, but you can tune that with the spring.mvc.static-path-
pattern property. For instance, relocating all resources to /resources/** can be achieved as follows:
spring.mvc.static-path-pattern=/resources/**
You can also customize the static resource locations by using the spring.resources.static-locations
property (replacing the default values with a list of directory locations). The root Servlet context
path, "/", is automatically added as a location as well.
In addition to the “standard” static resource locations mentioned earlier, a special case is made for
Webjars content. Any resources with a path in /webjars/** are served from jar files if they are
packaged in the Webjars format.
Spring Boot also supports the advanced resource handling features provided by Spring MVC,
allowing use cases such as cache-busting static resources or using version agnostic URLs for
Webjars.
To use version agnostic URLs for Webjars, add the webjars-locator-core dependency. Then declare
your Webjar. Using jQuery as an example, adding "/webjars/jquery/jquery.min.js" results in
"/webjars/jquery/x.y.z/jquery.min.js" where x.y.z is the Webjar version.
To use cache busting, the following configuration configures a cache busting solution for all static
resources, effectively adding a content hash, such as <link href="/css/spring-
2a2d595e6ed9a0b24f027f2b63b134d6.css"/>, in URLs:
spring.resources.chain.strategy.content.enabled=true
spring.resources.chain.strategy.content.paths=/**
94
Links to resources are rewritten in templates at runtime, thanks to a
ResourceUrlEncodingFilter that is auto-configured for Thymeleaf and FreeMarker.
You should manually declare this filter when using JSPs. Other template engines
are currently not automatically supported but can be with custom template
macros/helpers and the use of the ResourceUrlProvider.
When loading resources dynamically with, for example, a JavaScript module loader, renaming files
is not an option. That is why other strategies are also supported and can be combined. A "fixed"
strategy adds a static version string in the URL without changing the file name, as shown in the
following example:
spring.resources.chain.strategy.content.enabled=true
spring.resources.chain.strategy.content.paths=/**
spring.resources.chain.strategy.fixed.enabled=true
spring.resources.chain.strategy.fixed.paths=/js/lib/
spring.resources.chain.strategy.fixed.version=v12
With this configuration, JavaScript modules located under "/js/lib/" use a fixed versioning
strategy ("/v12/js/lib/mymodule.js"), while other resources still use the content one (<link
href="/css/spring-2a2d595e6ed9a0b24f027f2b63b134d6.css"/>).
This feature has been thoroughly described in a dedicated blog post and in Spring
Framework’s reference documentation.
Welcome Page
Spring Boot supports both static and templated welcome pages. It first looks for an index.html file in
the configured static content locations. If one is not found, it then looks for an index template. If
either is found, it is automatically used as the welcome page of the application.
Custom Favicon
As with other static resources, Spring Boot looks for a favicon.ico in the configured static content
locations. If such a file is present, it is automatically used as the favicon of the application.
Spring MVC can map incoming HTTP requests to handlers by looking at the request path and
matching it to the mappings defined in your application (for example, @GetMapping annotations on
Controller methods).
Spring Boot chooses to disable suffix pattern matching by default, which means that requests like
"GET /projects/spring-boot.json" won’t be matched to @GetMapping("/projects/spring-boot")
mappings. This is considered as a best practice for Spring MVC applications. This feature was
mainly useful in the past for HTTP clients which did not send proper "Accept" request headers; we
needed to make sure to send the correct Content Type to the client. Nowadays, Content Negotiation
95
is much more reliable.
There are other ways to deal with HTTP clients that don’t consistently send proper "Accept" request
headers. Instead of using suffix matching, we can use a query parameter to ensure that requests
like "GET /projects/spring-boot?format=json" will be mapped to @GetMapping("/projects/spring-
boot"):
spring.mvc.contentnegotiation.favor-parameter=true
Suffix pattern matching is deprecated and will be removed in a future release. If you understand
the caveats and would still like your application to use suffix pattern matching, the following
configuration is required:
spring.mvc.contentnegotiation.favor-path-extension=true
spring.mvc.pathmatch.use-suffix-pattern=true
Alternatively, rather than open all suffix patterns, it’s more secure to only support registered suffix
patterns:
spring.mvc.contentnegotiation.favor-path-extension=true
spring.mvc.pathmatch.use-registered-suffix-pattern=true
ConfigurableWebBindingInitializer
Spring MVC uses a WebBindingInitializer to initialize a WebDataBinder for a particular request. If you
create your own ConfigurableWebBindingInitializer @Bean, Spring Boot automatically configures
Spring MVC to use it.
Template Engines
As well as REST web services, you can also use Spring MVC to serve dynamic HTML content. Spring
MVC supports a variety of templating technologies, including Thymeleaf, FreeMarker, and JSPs.
Also, many other templating engines include their own Spring MVC integrations.
Spring Boot includes auto-configuration support for the following templating engines:
• FreeMarker
• Groovy
96
• Thymeleaf
• Mustache
If possible, JSPs should be avoided. There are several known limitations when
using them with embedded servlet containers.
When you use one of these templating engines with the default configuration, your templates are
picked up automatically from src/main/resources/templates.
Depending on how you run your application, your IDE may order the classpath
differently. Running your application in the IDE from its main method results in a
different ordering than when you run your application by using Maven or Gradle
or from its packaged jar. This can cause Spring Boot to fail to find the expected
template. If you have this problem, you can reorder the classpath in the IDE to
place the module’s classes and resources first.
Error Handling
By default, Spring Boot provides an /error mapping that handles all errors in a sensible way, and it
is registered as a “global” error page in the servlet container. For machine clients, it produces a
JSON response with details of the error, the HTTP status, and the exception message. For browser
clients, there is a “whitelabel” error view that renders the same data in HTML format (to customize
it, add a View that resolves to error).
There are a number of server.error properties that can be set if you want to customize the default
error handling behavior. See the “Server Properties” section of the Appendix.
To replace the default behavior completely, you can implement ErrorController and register a bean
definition of that type or add a bean of type ErrorAttributes to use the existing mechanism but
replace the contents.
You can also define a class annotated with @ControllerAdvice to customize the JSON document to
return for a particular controller and/or exception type, as shown in the following example:
97
@ControllerAdvice(basePackageClasses = AcmeController.class)
public class AcmeControllerAdvice extends ResponseEntityExceptionHandler {
@ExceptionHandler(YourException.class)
@ResponseBody
ResponseEntity<?> handleControllerException(HttpServletRequest request, Throwable
ex) {
HttpStatus status = getStatus(request);
return new ResponseEntity<>(new CustomErrorType(status.value(),
ex.getMessage()), status);
}
In the preceding example, if YourException is thrown by a controller defined in the same package as
AcmeController, a JSON representation of the CustomErrorType POJO is used instead of the
ErrorAttributes representation.
If you want to display a custom HTML error page for a given status code, you can add a file to an
/error directory. Error pages can either be static HTML (that is, added under any of the static
resource directories) or be built by using templates. The name of the file should be the exact status
code or a series mask.
For example, to map 404 to a static HTML file, your directory structure would be as follows:
src/
+- main/
+- java/
| + <source code>
+- resources/
+- public/
+- error/
| +- 404.html
+- <other public assets>
To map all 5xx errors by using a FreeMarker template, your directory structure would be as follows:
98
src/
+- main/
+- java/
| + <source code>
+- resources/
+- templates/
+- error/
| +- 5xx.ftlh
+- <other templates>
For more complex mappings, you can also add beans that implement the ErrorViewResolver
interface, as shown in the following example:
@Override
public ModelAndView resolveErrorView(HttpServletRequest request,
HttpStatus status, Map<String, Object> model) {
// Use the request or status to optionally return a ModelAndView
return ...
}
You can also use regular Spring MVC features such as @ExceptionHandler methods and
@ControllerAdvice. The ErrorController then picks up any unhandled exceptions.
For applications that do not use Spring MVC, you can use the ErrorPageRegistrar interface to
directly register ErrorPages. This abstraction works directly with the underlying embedded servlet
container and works even if you do not have a Spring MVC DispatcherServlet.
99
@Bean
public ErrorPageRegistrar errorPageRegistrar(){
return new MyErrorPageRegistrar();
}
// ...
@Override
public void registerErrorPages(ErrorPageRegistry registry) {
registry.addErrorPages(new ErrorPage(HttpStatus.BAD_REQUEST, "/400"));
}
If you register an ErrorPage with a path that ends up being handled by a Filter (as
is common with some non-Spring web frameworks, like Jersey and Wicket), then
the Filter has to be explicitly registered as an ERROR dispatcher, as shown in the
following example:
@Bean
public FilterRegistrationBean myFilter() {
FilterRegistrationBean registration = new FilterRegistrationBean();
registration.setFilter(new MyFilter());
...
registration.setDispatcherTypes(EnumSet.allOf(DispatcherType.class));
return registration;
}
Note that the default FilterRegistrationBean does not include the ERROR dispatcher type.
When deployed to a servlet container, Spring Boot uses its error page filter to forward a request
with an error status to the appropriate error page. This is necessary as the Servlet specification
does not provide an API for registering error pages. Depending on the container that you are
deploying your war file to and the technologies that your application uses, some additional
configuration may be required.
The error page filter can only forward the request to the correct error page if the response has not
already been committed. By default, WebSphere Application Server 8.0 and later commits the
response upon successful completion of a servlet’s service method. You should disable this behavior
by setting com.ibm.ws.webcontainer.invokeFlushAfterService to false.
If you are using Spring Security and want to access the principal in an error page, you must
configure Spring Security’s filter to be invoked on error dispatches. To do so, set the
100
spring.security.filter.dispatcher-types property to async, error, forward, request.
Spring HATEOAS
If you develop a RESTful API that makes use of hypermedia, Spring Boot provides auto-
configuration for Spring HATEOAS that works well with most applications. The auto-configuration
replaces the need to use @EnableHypermediaSupport and registers a number of beans to ease building
hypermedia-based applications, including a LinkDiscoverers (for client side support) and an
ObjectMapper configured to correctly marshal responses into the desired representation. The
ObjectMapper is customized by setting the various spring.jackson.* properties or, if one exists, by a
Jackson2ObjectMapperBuilder bean.
You can take control of Spring HATEOAS’s configuration by using @EnableHypermediaSupport. Note
that doing so disables the ObjectMapper customization described earlier.
CORS Support
Cross-origin resource sharing (CORS) is a W3C specification implemented by most browsers that
lets you specify in a flexible way what kind of cross-domain requests are authorized., instead of
using some less secure and less powerful approaches such as IFRAME or JSONP.
As of version 4.2, Spring MVC supports CORS. Using controller method CORS configuration with
@CrossOrigin annotations in your Spring Boot application does not require any specific
configuration. Global CORS configuration can be defined by registering a WebMvcConfigurer bean
with a customized addCorsMappings(CorsRegistry) method, as shown in the following example:
@Configuration(proxyBeanMethods = false)
public class MyConfiguration {
@Bean
public WebMvcConfigurer corsConfigurer() {
return new WebMvcConfigurer() {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/api/**");
}
};
}
}
Spring WebFlux is the new reactive web framework introduced in Spring Framework 5.0. Unlike
Spring MVC, it does not require the Servlet API, is fully asynchronous and non-blocking, and
implements the Reactive Streams specification through the Reactor project.
Spring WebFlux comes in two flavors: functional and annotation-based. The annotation-based one
is quite close to the Spring MVC model, as shown in the following example:
101
@RestController
@RequestMapping("/users")
public class MyRestController {
@GetMapping("/{user}")
public Mono<User> getUser(@PathVariable Long user) {
// ...
}
@GetMapping("/{user}/customers")
public Flux<Customer> getUserCustomers(@PathVariable Long user) {
// ...
}
@DeleteMapping("/{user}")
public Mono<User> deleteUser(@PathVariable Long user) {
// ...
}
“WebFlux.fn”, the functional variant, separates the routing configuration from the actual handling
of the requests, as shown in the following example:
102
@Configuration(proxyBeanMethods = false)
public class RoutingConfiguration {
@Bean
public RouterFunction<ServerResponse> monoRouterFunction(UserHandler userHandler)
{
return route(GET("/{user}").and(accept(APPLICATION_JSON)),
userHandler::getUser)
.andRoute(GET("/{user}/customers").and(accept(APPLICATION_JSON)),
userHandler::getUserCustomers)
.andRoute(DELETE("/{user}").and(accept(APPLICATION_JSON)),
userHandler::deleteUser);
}
@Component
public class UserHandler {
WebFlux is part of the Spring Framework and detailed information is available in its reference
documentation.
You can define as many RouterFunction beans as you like to modularize the
definition of the router. Beans can be ordered if you need to apply a precedence.
103
Spring WebFlux Auto-configuration
Spring Boot provides auto-configuration for Spring WebFlux that works well with most
applications.
• Support for serving static resources, including support for WebJars (described later in this
document).
If you want to keep Spring Boot WebFlux features and you want to add additional WebFlux
configuration, you can add your own @Configuration class of type WebFluxConfigurer but without
@EnableWebFlux.
If you want to take complete control of Spring WebFlux, you can add your own @Configuration
annotated with @EnableWebFlux.
Spring WebFlux uses the HttpMessageReader and HttpMessageWriter interfaces to convert HTTP
requests and responses. They are configured with CodecConfigurer to have sensible defaults by
looking at the libraries available in your classpath.
Spring Boot provides dedicated configuration properties for codecs, spring.codec.*. It also applies
further customization by using CodecCustomizer instances. For example, spring.jackson.*
configuration keys are applied to the Jackson codec.
If you need to add or customize codecs, you can create a custom CodecCustomizer component, as
shown in the following example:
import org.springframework.boot.web.codec.CodecCustomizer;
@Configuration(proxyBeanMethods = false)
public class MyConfiguration {
@Bean
public CodecCustomizer myCodecCustomizer() {
return codecConfigurer -> {
// ...
};
}
You can also leverage Boot’s custom JSON serializers and deserializers.
104
Static Content
By default, Spring Boot serves static content from a directory called /static (or /public or
/resources or /META-INF/resources) in the classpath. It uses the ResourceWebHandler from Spring
WebFlux so that you can modify that behavior by adding your own WebFluxConfigurer and
overriding the addResourceHandlers method.
By default, resources are mapped on /**, but you can tune that by setting the
spring.webflux.static-path-pattern property. For instance, relocating all resources to /resources/**
can be achieved as follows:
spring.webflux.static-path-pattern=/resources/**
You can also customize the static resource locations by using spring.resources.static-locations.
Doing so replaces the default values with a list of directory locations. If you do so, the default
welcome page detection switches to your custom locations. So, if there is an index.html in any of
your locations on startup, it is the home page of the application.
In addition to the “standard” static resource locations listed earlier, a special case is made for
Webjars content. Any resources with a path in /webjars/** are served from jar files if they are
packaged in the Webjars format.
Spring WebFlux applications do not strictly depend on the Servlet API, so they
cannot be deployed as war files and do not use the src/main/webapp directory.
Welcome Page
Spring Boot supports both static and templated welcome pages. It first looks for an index.html file in
the configured static content locations. If one is not found, it then looks for an index template. If
either is found, it is automatically used as the welcome page of the application.
Template Engines
As well as REST web services, you can also use Spring WebFlux to serve dynamic HTML content.
Spring WebFlux supports a variety of templating technologies, including Thymeleaf, FreeMarker,
and Mustache.
Spring Boot includes auto-configuration support for the following templating engines:
• FreeMarker
• Thymeleaf
• Mustache
When you use one of these templating engines with the default configuration, your templates are
picked up automatically from src/main/resources/templates.
105
Error Handling
Spring Boot provides a WebExceptionHandler that handles all errors in a sensible way. Its position in
the processing order is immediately before the handlers provided by WebFlux, which are
considered last. For machine clients, it produces a JSON response with details of the error, the HTTP
status, and the exception message. For browser clients, there is a “whitelabel” error handler that
renders the same data in HTML format. You can also provide your own HTML templates to display
errors (see the next section).
The first step to customizing this feature often involves using the existing mechanism but replacing
or augmenting the error contents. For that, you can add a bean of type ErrorAttributes.
To change the error handling behavior, you can implement ErrorWebExceptionHandler and register a
bean definition of that type. Because a WebExceptionHandler is quite low-level, Spring Boot also
provides a convenient AbstractErrorWebExceptionHandler to let you handle errors in a WebFlux
functional way, as shown in the following example:
@Override
protected RouterFunction<ServerResponse> getRoutingFunction(ErrorAttributes
errorAttributes) {
return RouterFunctions
.route(aPredicate, aHandler)
.andRoute(anotherPredicate, anotherHandler);
}
For a more complete picture, you can also subclass DefaultErrorWebExceptionHandler directly and
override specific methods.
If you want to display a custom HTML error page for a given status code, you can add a file to an
/error directory. Error pages can either be static HTML (that is, added under any of the static
resource directories) or built with templates. The name of the file should be the exact status code or
a series mask.
For example, to map 404 to a static HTML file, your directory structure would be as follows:
106
src/
+- main/
+- java/
| + <source code>
+- resources/
+- public/
+- error/
| +- 404.html
+- <other public assets>
To map all 5xx errors by using a Mustache template, your directory structure would be as follows:
src/
+- main/
+- java/
| + <source code>
+- resources/
+- templates/
+- error/
| +- 5xx.mustache
+- <other templates>
Web Filters
Spring WebFlux provides a WebFilter interface that can be implemented to filter HTTP request-
response exchanges. WebFilter beans found in the application context will be automatically used to
filter each exchange.
Where the order of the filters is important they can implement Ordered or be annotated with @Order.
Spring Boot auto-configuration may configure web filters for you. When it does so, the orders
shown in the following table will be used:
HttpTraceWebFilter Ordered.LOWEST_PRECEDENCE - 10
If you prefer the JAX-RS programming model for REST endpoints, you can use one of the available
implementations instead of Spring MVC. Jersey and Apache CXF work quite well out of the box. CXF
requires you to register its Servlet or Filter as a @Bean in your application context. Jersey has some
native Spring support, so we also provide auto-configuration support for it in Spring Boot, together
with a starter.
To get started with Jersey, include the spring-boot-starter-jersey as a dependency and then you
107
need one @Bean of type ResourceConfig in which you register all the endpoints, as shown in the
following example:
@Component
public class JerseyConfig extends ResourceConfig {
public JerseyConfig() {
register(Endpoint.class);
}
Jersey’s support for scanning executable archives is rather limited. For example, it
cannot scan for endpoints in a package found in a fully executable jar file or in
WEB-INF/classes when running an executable war file. To avoid this limitation, the
packages method should not be used, and endpoints should be registered
individually by using the register method, as shown in the preceding example.
For more advanced customizations, you can also register an arbitrary number of beans that
implement ResourceConfigCustomizer.
All the registered endpoints should be @Components with HTTP resource annotations (@GET and
others), as shown in the following example:
@Component
@Path("/hello")
public class Endpoint {
@GET
public String message() {
return "Hello";
}
Since the Endpoint is a Spring @Component, its lifecycle is managed by Spring and you can use the
@Autowired annotation to inject dependencies and use the @Value annotation to inject external
configuration. By default, the Jersey servlet is registered and mapped to /*. You can change the
mapping by adding @ApplicationPath to your ResourceConfig.
108
parameters by using spring.jersey.init.* to specify a map of properties.
Spring Boot includes support for embedded Tomcat, Jetty, and Undertow servers. Most developers
use the appropriate “Starter” to obtain a fully configured instance. By default, the embedded server
listens for HTTP requests on port 8080.
When using an embedded servlet container, you can register servlets, filters, and all the listeners
(such as HttpSessionListener) from the Servlet spec, either by using Spring beans or by scanning for
Servlet components.
Any Servlet, Filter, or servlet *Listener instance that is a Spring bean is registered with the
embedded container. This can be particularly convenient if you want to refer to a value from your
application.properties during configuration.
By default, if the context contains only a single Servlet, it is mapped to /. In the case of multiple
servlet beans, the bean name is used as a path prefix. Filters map to /*.
If convention-based mapping is not flexible enough, you can use the ServletRegistrationBean,
FilterRegistrationBean, and ServletListenerRegistrationBean classes for complete control.
It is usually safe to leave Filter beans unordered. If a specific order is required, you should annotate
the Filter with @Order or make it implement Ordered. You cannot configure the order of a Filter by
annotating its bean method with @Order. If you cannot change the Filter class to add @Order or
implement Ordered, you must define a FilterRegistrationBean for the Filter and set the registration
bean’s order using the setOrder(int) method. Avoid configuring a Filter that reads the request body
at Ordered.HIGHEST_PRECEDENCE, since it might go against the character encoding configuration of
your application. If a Servlet filter wraps the request, it should be configured with an order that is
less than or equal to OrderedFilter.REQUEST_WRAPPER_FILTER_MAX_ORDER.
To see the order of every Filter in your application, enable debug level logging for
the web logging group (logging.level.web=debug). Details of the registered filters,
including their order and URL patterns, will then be logged at startup.
Take care when registering Filter beans since they are initialized very early in the
application lifectyle. If you need to register a Filter that interacts with other
beans, consider using a DelegatingFilterProxyRegistrationBean instead.
109
Boot applications.
If you need to perform servlet context initialization in a Spring Boot application, you should
register a bean that implements the
org.springframework.boot.web.servlet.ServletContextInitializer interface. The single onStartup
method provides access to the ServletContext and, if necessary, can easily be used as an adapter to
an existing WebApplicationInitializer.
When using an embedded container, automatic registration of classes annotated with @WebServlet,
@WebFilter, and @WebListener can be enabled by using @ServletComponentScan.
The ServletWebServerApplicationContext
Under the hood, Spring Boot uses a different type of ApplicationContext for embedded servlet
container support. The ServletWebServerApplicationContext is a special type of
WebApplicationContext that bootstraps itself by searching for a single ServletWebServerFactory bean.
Usually a TomcatServletWebServerFactory, JettyServletWebServerFactory, or
UndertowServletWebServerFactory has been auto-configured.
Common servlet container settings can be configured by using Spring Environment properties.
Usually, you would define the properties in your application.properties file.
• Network settings: Listen port for incoming HTTP requests (server.port), interface address to
bind to server.address, and so on.
• SSL
• HTTP compression
Spring Boot tries as much as possible to expose common settings, but this is not always possible. For
those cases, dedicated namespaces offer server-specific customizations (see server.tomcat and
server.undertow). For instance, access logs can be configured with specific features of the embedded
110
servlet container.
Programmatic Customization
If you need to programmatically configure your embedded servlet container, you can register a
Spring bean that implements the WebServerFactoryCustomizer interface. WebServerFactoryCustomizer
provides access to the ConfigurableServletWebServerFactory, which includes numerous
customization setter methods. The following example shows programmatically setting the port:
import org.springframework.boot.web.server.WebServerFactoryCustomizer;
import
org.springframework.boot.web.servlet.server.ConfigurableServletWebServerFactory;
import org.springframework.stereotype.Component;
@Component
public class CustomizationBean implements
WebServerFactoryCustomizer<ConfigurableServletWebServerFactory> {
@Override
public void customize(ConfigurableServletWebServerFactory server) {
server.setPort(9000);
}
@Component
public class TomcatServerCustomizerExample implements
WebServerFactoryCustomizer<TomcatServletWebServerFactory> {
@Override
public void customize(TomcatServletWebServerFactory server) {
server.addConnectorCustomizers(
(tomcatConnector) ->
tomcatConnector.setAsyncTimeout(Duration.ofSeconds(20).toMillis()));
}
111
Customizing ConfigurableServletWebServerFactory Directly
For more advanced use cases that require you to extend from ServletWebServerFactory, you can
expose a bean of such type yourself.
Setters are provided for many configuration options. Several protected method “hooks” are also
provided should you need to do something more exotic. See the source code documentation for
details.
Auto-configured customizers are still applied on your custom factory, so use that
option carefully.
JSP Limitations
When running a Spring Boot application that uses an embedded servlet container (and is packaged
as an executable archive), there are some limitations in the JSP support.
• With Jetty and Tomcat, it should work if you use war packaging. An executable war will work
when launched with java -jar, and will also be deployable to any standard container. JSPs are
not supported when using an executable jar.
• Creating a custom error.jsp page does not override the default view for error handling. Custom
error pages should be used instead.
Spring Boot includes support for the following embedded reactive web servers: Reactor Netty,
Tomcat, Jetty, and Undertow. Most developers use the appropriate “Starter” to obtain a fully
configured instance. By default, the embedded server listens for HTTP requests on port 8080.
When auto-configuring a Reactor Netty or Jetty server, Spring Boot will create specific beans that
will provide HTTP resources to the server instance: ReactorResourceFactory or JettyResourceFactory.
By default, those resources will be also shared with the Reactor Netty and Jetty clients for optimal
performances, given:
• the client instance is built using the WebClient.Builder bean auto-configured by Spring Boot
Developers can override the resource configuration for Jetty and Reactor Netty by providing a
custom ReactorResourceFactory or JettyResourceFactory bean - this will be applied to both clients
and servers.
You can learn more about the resource configuration on the client side in the WebClient Runtime
section.
112
5.8. Graceful shutdown
Graceful shutdown is supported with all four embedded web servers (Jetty, Reactor Netty, Tomcat,
and Undertow) and with both reactive and Servlet-based web applications. It occurs as part of
closing the application context and is performed in the earliest phase of stopping SmartLifecycle
beans. This stop processing uses a timeout which provides a grace period during which existing
requests will be allowed to complete but no new requests will be permitted. The exact way in which
new requests are not permitted varies depending on the web server that is being used. Jetty,
Reactor Netty, and Tomcat will stop accepting requests at the network layer. Undertow will accept
requests but respond immediately with a service unavailable (503) response.
To enable graceful shutdown, configure the server.shutdown property, as shown in the following
example:
server.shutdown=graceful
spring.lifecycle.timeout-per-shutdown-phase=20s
Using graceful shutdown with your IDE may not work properly if it does not send
a proper SIGTERM signal. Refer to the documentation of your IDE for more details.
5.9. RSocket
RSocket is a binary protocol for use on byte stream transports. It enables symmetric interaction
models via async message passing over a single connection.
The spring-messaging module of the Spring Framework provides support for RSocket requesters
and responders, both on the client and on the server side. See the RSocket section of the Spring
Framework reference for more details, including an overview of the RSocket protocol.
Spring Boot auto-configures an RSocketStrategies bean that provides all the required infrastructure
for encoding and decoding RSocket payloads. By default, the auto-configuration will try to configure
the following (in order):
The spring-boot-starter-rsocket starter provides both dependencies. Check out the Jackson support
113
section to know more about customization possibilities.
Developers can customize the RSocketStrategies component by creating beans that implement the
RSocketStrategiesCustomizer interface. Note that their @Order is important, as it determines the
order of codecs.
Spring Boot provides RSocket server auto-configuration. The required dependencies are provided
by the spring-boot-starter-rsocket.
Spring Boot allows exposing RSocket over WebSocket from a WebFlux server, or standing up an
independent RSocket server. This depends on the type of application and its configuration.
For WebFlux application (i.e. of type WebApplicationType.REACTIVE), the RSocket server will be
plugged into the Web Server only if the following properties match:
Plugging RSocket into a web server is only supported with Reactor Netty, as
RSocket itself is built with that library.
Spring Boot will auto-configure the Spring Messaging infrastructure for RSocket.
This means that Spring Boot will create a RSocketMessageHandler bean that will handle RSocket
requests to your application.
Once the RSocket channel is established between server and client, any party can send or receive
requests to the other.
As a server, you can get injected with an RSocketRequester instance on any handler method of an
RSocket @Controller. As a client, you need to configure and establish an RSocket connection first.
Spring Boot auto-configures an RSocketRequester.Builder for such cases with the expected codecs.
114
The RSocketRequester.Builder instance is a prototype bean, meaning each injection point will
provide you with a new instance . This is done on purpose since this builder is stateful and you
shouldn’t create requesters with different setups using the same instance.
@Service
public class MyService {
5.10. Security
If Spring Security is on the classpath, then web applications are secured by default. Spring Boot
relies on Spring Security’s content-negotiation strategy to determine whether to use httpBasic or
formLogin. To add method-level security to a web application, you can also add
@EnableGlobalMethodSecurity with your desired settings. Additional information can be found in the
Spring Security Reference Guide.
The default UserDetailsService has a single user. The user name is user, and the password is
random and is printed at INFO level when the application starts, as shown in the following
example:
You can change the username and password by providing a spring.security.user.name and
spring.security.user.password.
115
with in-memory store and a single user with a generated password (see SecurityProperties.User
for the properties of the user).
• Form-based login or HTTP Basic security (depending on the Accept header in the request) for the
entire application (including actuator endpoints if actuator is on the classpath).
To also switch off the UserDetailsService configuration, you can add a bean of type
UserDetailsService, AuthenticationProvider, or AuthenticationManager.
Similar to Spring MVC applications, you can secure your WebFlux applications by adding the
spring-boot-starter-security dependency. The default security configuration is implemented in
ReactiveSecurityAutoConfiguration and UserDetailsServiceAutoConfiguration.
ReactiveSecurityAutoConfiguration imports WebFluxSecurityConfiguration for web security and
UserDetailsServiceAutoConfiguration configures authentication, which is also relevant in non-web
applications. To switch off the default web application security configuration completely, you can
add a bean of type WebFilterChainProxy (doing so does not disable the UserDetailsService
configuration or Actuator’s security).
To also switch off the UserDetailsService configuration, you can add a bean of type
ReactiveUserDetailsService or ReactiveAuthenticationManager.
Access rules and the use of multiple Spring Security components such as OAuth 2 Client and
Resource Server can be configured by adding a custom SecurityWebFilterChain bean. Spring Boot
provides convenience methods that can be used to override access rules for actuator endpoints and
static resources. EndpointRequest can be used to create a ServerWebExchangeMatcher that is based on
the management.endpoints.web.base-path property.
116
locations.
For example, you can customize your security configuration by adding something like:
@Bean
public SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) {
return http
.authorizeExchange()
.matchers(PathRequest.toStaticResources().atCommonLocations()).permitAll()
.pathMatchers("/foo", "/bar")
.authenticated().and()
.formLogin().and()
.build();
}
5.10.3. OAuth2
Client
If you have spring-security-oauth2-client on your classpath, you can take advantage of some auto-
configuration to set up an OAuth2/Open ID Connect clients. This configuration makes use of the
properties under OAuth2ClientProperties. The same properties are applicable to both servlet and
reactive applications.
You can register multiple OAuth2 clients and providers under the spring.security.oauth2.client
prefix, as shown in the following example:
117
spring.security.oauth2.client.registration.my-client-1.client-id=abcd
spring.security.oauth2.client.registration.my-client-1.client-secret=password
spring.security.oauth2.client.registration.my-client-1.client-name=Client for user
scope
spring.security.oauth2.client.registration.my-client-1.provider=my-oauth-provider
spring.security.oauth2.client.registration.my-client-1.scope=user
spring.security.oauth2.client.registration.my-client-1.redirect-uri=https://my-
redirect-uri.com
spring.security.oauth2.client.registration.my-client-1.client-authentication-
method=basic
spring.security.oauth2.client.registration.my-client-1.authorization-grant-
type=authorization_code
spring.security.oauth2.client.registration.my-client-2.client-id=abcd
spring.security.oauth2.client.registration.my-client-2.client-secret=password
spring.security.oauth2.client.registration.my-client-2.client-name=Client for email
scope
spring.security.oauth2.client.registration.my-client-2.provider=my-oauth-provider
spring.security.oauth2.client.registration.my-client-2.scope=email
spring.security.oauth2.client.registration.my-client-2.redirect-uri=https://my-
redirect-uri.com
spring.security.oauth2.client.registration.my-client-2.client-authentication-
method=basic
spring.security.oauth2.client.registration.my-client-2.authorization-grant-
type=authorization_code
spring.security.oauth2.client.provider.my-oauth-provider.authorization-uri=https://my-
auth-server/oauth/authorize
spring.security.oauth2.client.provider.my-oauth-provider.token-uri=https://my-auth-
server/oauth/token
spring.security.oauth2.client.provider.my-oauth-provider.user-info-uri=https://my-
auth-server/userinfo
spring.security.oauth2.client.provider.my-oauth-provider.user-info-authentication-
method=header
spring.security.oauth2.client.provider.my-oauth-provider.jwk-set-uri=https://my-auth-
server/token_keys
spring.security.oauth2.client.provider.my-oauth-provider.user-name-attribute=name
For OpenID Connect providers that support OpenID Connect discovery, the configuration can be
further simplified. The provider needs to be configured with an issuer-uri which is the URI that the
it asserts as its Issuer Identifier. For example, if the issuer-uri provided is "https://example.com",
then an OpenID Provider Configuration Request will be made to "https://example.com/.well-
known/openid-configuration". The result is expected to be an OpenID Provider Configuration
Response. The following example shows how an OpenID Connect Provider can be configured with
the issuer-uri:
spring.security.oauth2.client.provider.oidc-provider.issuer-uri=https://dev-
123456.oktapreview.com/oauth2/default/
118
By default, Spring Security’s OAuth2LoginAuthenticationFilter only processes URLs matching
/login/oauth2/code/*. If you want to customize the redirect-uri to use a different pattern, you need
to provide configuration to process that custom pattern. For example, for servlet applications, you
can add your own WebSecurityConfigurerAdapter that resembles the following:
@Override
protected void configure(HttpSecurity http) throws Exception {
http
.authorizeRequests()
.anyRequest().authenticated()
.and()
.oauth2Login()
.redirectionEndpoint()
.baseUri("/custom-callback");
}
}
For common OAuth2 and OpenID providers, including Google, Github, Facebook, and Okta, we
provide a set of provider defaults (google, github, facebook, and okta, respectively).
If you do not need to customize these providers, you can set the provider attribute to the one for
which you need to infer defaults. Also, if the key for the client registration matches a default
supported provider, Spring Boot infers that as well.
In other words, the two configurations in the following example use the Google provider:
spring.security.oauth2.client.registration.my-client.client-id=abcd
spring.security.oauth2.client.registration.my-client.client-secret=password
spring.security.oauth2.client.registration.my-client.provider=google
spring.security.oauth2.client.registration.google.client-id=abcd
spring.security.oauth2.client.registration.google.client-secret=password
Resource Server
119
specified, as shown in the following examples:
spring.security.oauth2.resourceserver.jwt.jwk-set-
uri=https://example.com/oauth2/default/v1/keys
spring.security.oauth2.resourceserver.jwt.issuer-uri=https://dev-
123456.oktapreview.com/oauth2/default/
If the authorization server does not support a JWK Set URI, you can configure the
resource server with the Public Key used for verifying the signature of the JWT.
This can be done using the spring.security.oauth2.resourceserver.jwt.public-key-
location property, where the value needs to point to a file containing the public
key in the PEM-encoded x509 format.
The same properties are applicable for both servlet and reactive applications.
Alternatively, you can define your own JwtDecoder bean for servlet applications or a
ReactiveJwtDecoder for reactive applications.
In cases where opaque tokens are used instead of JWTs, you can configure the following properties
to validate tokens via introspection:
spring.security.oauth2.resourceserver.opaquetoken.introspection-
uri=https://example.com/check-token
spring.security.oauth2.resourceserver.opaquetoken.client-id=my-client-id
spring.security.oauth2.resourceserver.opaquetoken.client-secret=my-client-secret
Again, the same properties are applicable for both servlet and reactive applications.
Alternatively, you can define your own OpaqueTokenIntrospector bean for servlet applications or a
ReactiveOpaqueTokenIntrospector for reactive applications.
Authorization Server
Currently, Spring Security does not provide support for implementing an OAuth 2.0 Authorization
Server. However, this functionality is available from the Spring Security OAuth project, which will
eventually be superseded by Spring Security completely. Until then, you can use the spring-
security-oauth2-autoconfigure module to easily set up an OAuth 2.0 authorization server; see its
documentation for instructions.
Relying Party
120
properties under Saml2RelyingPartyProperties.
A relying party registration represents a paired configuration between an Identity Provider, IDP,
and a Service Provider, SP. You can register multiple relying parties under the
spring.security.saml2.relyingparty prefix, as shown in the following example:
spring.security.saml2.relyingparty.registration.my-relying-
party1.signing.credentials[0].private-key-location=path-to-private-key
spring.security.saml2.relyingparty.registration.my-relying-
party1.signing.credentials[0].certificate-location=path-to-certificate
spring.security.saml2.relyingparty.registration.my-relying-
party1.identityprovider.verification.credentials[0].certificate-location=path-to-
verification-cert
spring.security.saml2.relyingparty.registration.my-relying-
party1.identityprovider.entity-id=remote-idp-entity-id1
spring.security.saml2.relyingparty.registration.my-relying-
party1.identityprovider.sso-url=https://remoteidp1.sso.url
spring.security.saml2.relyingparty.registration.my-relying-
party2.signing.credentials[0].private-key-location=path-to-private-key
spring.security.saml2.relyingparty.registration.my-relying-
party2.signing.credentials[0].certificate-location=path-to-certificate
spring.security.saml2.relyingparty.registration.my-relying-
party2.identityprovider.verification.credentials[0].certificate-location=path-to-
other-verification-cert
spring.security.saml2.relyingparty.registration.my-relying-
party2.identityprovider.entity-id=remote-idp-entity-id2
spring.security.saml2.relyingparty.registration.my-relying-
party2.identityprovider.sso-url=https://remoteidp2.sso.url
For security purposes, all actuators other than /health and /info are disabled by default. The
management.endpoints.web.exposure.include property can be used to enable the actuators.
Since Spring Boot relies on Spring Security’s defaults, CSRF protection is turned on by default. This
means that the actuator endpoints that require a POST (shutdown and loggers endpoints), PUT or
DELETE will get a 403 forbidden error when the default security configuration is in use.
121
We recommend disabling CSRF protection completely only if you are creating a
service that is used by non-browser clients.
Additional information about CSRF protection can be found in the Spring Security Reference Guide.
See the “How-to” section for more advanced examples, typically to take full control
over the configuration of the DataSource.
Spring Boot can auto-configure embedded H2, HSQL, and Derby databases. You need not provide
any connection URLs. You need only include a build dependency to the embedded database that
you want to use.
If you are using this feature in your tests, you may notice that the same database is
reused by your whole test suite regardless of the number of application contexts
that you use. If you want to make sure that each context has a separate embedded
database, you should set spring.datasource.generate-unique-name to true.
122
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.hsqldb</groupId>
<artifactId>hsqldb</artifactId>
<scope>runtime</scope>
</dependency>
If, for whatever reason, you do configure the connection URL for an embedded
database, take care to ensure that the database’s automatic shutdown is disabled.
If you use H2, you should use DB_CLOSE_ON_EXIT=FALSE to do so. If you use HSQLDB,
you should ensure that shutdown=true is not used. Disabling the database’s
automatic shutdown lets Spring Boot control when the database is closed, thereby
ensuring that it happens once access to the database is no longer needed.
Production database connections can also be auto-configured by using a pooling DataSource. Spring
Boot uses the following algorithm for choosing a specific implementation:
1. We prefer HikariCP for its performance and concurrency. If HikariCP is available, we always
choose it.
3. If neither HikariCP nor the Tomcat pooling datasource are available and if Commons DBCP2 is
available, we use it.
You can bypass that algorithm completely and specify the connection pool to use
by setting the spring.datasource.type property. This is especially important if you
run your application in a Tomcat container, as tomcat-jdbc is provided by default.
Additional connection pools can always be configured manually. If you define your
own DataSource bean, auto-configuration does not occur.
123
spring.datasource.url=jdbc:mysql://localhost/test
spring.datasource.username=dbuser
spring.datasource.password=dbpass
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
You should at least specify the URL by setting the spring.datasource.url property.
Otherwise, Spring Boot tries to auto-configure an embedded database.
You often do not need to specify the driver-class-name, since Spring Boot can
deduce it for most databases from the url.
See DataSourceProperties for more of the supported options. These are the standard options that
work regardless of the actual implementation. It is also possible to fine-tune implementation-
specific settings by using their respective prefix (spring.datasource.hikari.*,
spring.datasource.tomcat.*, and spring.datasource.dbcp2.*). Refer to the documentation of the
connection pool implementation you are using for more details.
For instance, if you use the Tomcat connection pool, you could customize many additional settings,
as shown in the following example:
# Maximum number of active connections that can be allocated from this pool at the
same time.
spring.datasource.tomcat.max-active=50
If you deploy your Spring Boot application to an Application Server, you might want to configure
and manage your DataSource by using your Application Server’s built-in features and access it by
using JNDI.
124
spring.datasource.jndi-name=java:jboss/datasources/customers
Spring’s JdbcTemplate and NamedParameterJdbcTemplate classes are auto-configured, and you can
@Autowire them directly into your own beans, as shown in the following example:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component;
@Component
public class MyBean {
@Autowired
public MyBean(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
// ...
You can customize some properties of the template by using the spring.jdbc.template.* properties,
as shown in the following example:
spring.jdbc.template.max-rows=500
The Java Persistence API is a standard technology that lets you “map” objects to relational
databases. The spring-boot-starter-data-jpa POM provides a quick way to get started. It provides
the following key dependencies:
125
We do not go into too many details of JPA or Spring Data here. You can follow the
“Accessing Data with JPA” guide from spring.io and read the Spring Data JPA and
Hibernate reference documentation.
Entity Classes
Traditionally, JPA “Entity” classes are specified in a persistence.xml file. With Spring Boot, this file is
not necessary and “Entity Scanning” is used instead. By default, all packages below your main
configuration class (the one annotated with @EnableAutoConfiguration or @SpringBootApplication)
are searched.
Any classes annotated with @Entity, @Embeddable, or @MappedSuperclass are considered. A typical
entity class resembles the following example:
126
package com.example.myapp.domain;
import java.io.Serializable;
import javax.persistence.*;
@Entity
public class City implements Serializable {
@Id
@GeneratedValue
private Long id;
@Column(nullable = false)
private String name;
@Column(nullable = false)
private String state;
protected City() {
// no-args constructor required by JPA spec
// this one is protected since it shouldn't be used directly
}
// ... etc
You can customize entity scanning locations by using the @EntityScan annotation.
See the “Separate @Entity Definitions from Spring Configuration” how-to.
Spring Data JPA repositories are interfaces that you can define to access data. JPA queries are
created automatically from your method names. For example, a CityRepository interface might
127
declare a findAllByState(String state) method to find all the cities in a given state.
For more complex queries, you can annotate your method with Spring Data’s Query annotation.
Spring Data repositories usually extend from the Repository or CrudRepository interfaces. If you use
auto-configuration, repositories are searched from the package containing your main configuration
class (the one annotated with @EnableAutoConfiguration or @SpringBootApplication) down.
The following example shows a typical Spring Data repository interface definition:
package com.example.myapp.domain;
import org.springframework.data.domain.*;
import org.springframework.data.repository.*;
Spring Data JPA repositories support three different modes of bootstrapping: default, deferred, and
lazy. To enable deferred or lazy bootstrapping, set the spring.data.jpa.repositories.bootstrap-mode
property to deferred or lazy respectively. When using deferred or lazy bootstrapping, the auto-
configured EntityManagerFactoryBuilder will use the context’s AsyncTaskExecutor, if any, as the
bootstrap executor. If more than one exists, the one named applicationTaskExecutor will be used.
When using deferred or lazy bootstraping, make sure to defer any access to the JPA
infrastructure after the application context bootstrap phase. You can use
SmartInitializingSingleton to invoke any initialization that requires the JPA
infrastructure. For JPA components (such as converters) that are created as Spring
beans, use ObjectProvider to delay the resolution of dependencies, if any.
We have barely scratched the surface of Spring Data JPA. For complete details, see
the Spring Data JPA reference documentation.
By default, JPA databases are automatically created only if you use an embedded database (H2,
HSQL, or Derby). You can explicitly configure JPA settings by using spring.jpa.* properties. For
example, to create and drop tables you can add the following line to your application.properties:
spring.jpa.hibernate.ddl-auto=create-drop
128
Hibernate’s own internal property name for this (if you happen to remember it
better) is hibernate.hbm2ddl.auto. You can set it, along with other Hibernate native
properties, by using spring.jpa.properties.* (the prefix is stripped before adding
them to the entity manager). The following line shows an example of setting JPA
properties for Hibernate:
spring.jpa.properties.hibernate.globally_quoted_identifiers=true
The line in the preceding example passes a value of true for the
hibernate.globally_quoted_identifiers property to the Hibernate entity manager.
By default, the DDL execution (or validation) is deferred until the ApplicationContext has started.
There is also a spring.jpa.generate-ddl flag, but it is not used if Hibernate auto-configuration is
active, because the ddl-auto settings are more fine-grained.
Spring Data includes repository support for JDBC and will automatically generate SQL for the
methods on CrudRepository. For more advanced queries, a @Query annotation is provided.
Spring Boot will auto-configure Spring Data’s JDBC repositories when the necessary dependencies
are on the classpath. They can be added to your project with a single dependency on spring-boot-
starter-data-jdbc. If necessary, you can take control of Spring Data JDBC’s configuration by adding
the @EnableJdbcRepositories annotation or a JdbcConfiguration subclass to your application.
For complete details of Spring Data JDBC, please refer to the reference
documentation.
The H2 database provides a browser-based console that Spring Boot can auto-configure for you. The
console is auto-configured when the following conditions are met:
129
If you are not using Spring Boot’s developer tools but would still like to make use
of H2’s console, you can configure the spring.h2.console.enabled property with a
value of true.
The H2 console is only intended for use during development, so you should take
care to ensure that spring.h2.console.enabled is not set to true in production.
By default, the console is available at /h2-console. You can customize the console’s path by using the
spring.h2.console.path property.
jOOQ Object Oriented Querying (jOOQ) is a popular product from Data Geekery which generates
Java code from your database and lets you build type-safe SQL queries through its fluent API. Both
the commercial and open source editions can be used with Spring Boot.
Code Generation
In order to use jOOQ type-safe queries, you need to generate Java classes from your database
schema. You can follow the instructions in the jOOQ user manual. If you use the jooq-codegen-maven
plugin and you also use the spring-boot-starter-parent “parent POM”, you can safely omit the
plugin’s <version> tag. You can also use Spring Boot-defined version variables (such as h2.version)
to declare the plugin’s database dependency. The following listing shows an example:
130
<plugin>
<groupId>org.jooq</groupId>
<artifactId>jooq-codegen-maven</artifactId>
<executions>
...
</executions>
<dependencies>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>${h2.version}</version>
</dependency>
</dependencies>
<configuration>
<jdbc>
<driver>org.h2.Driver</driver>
<url>jdbc:h2:~/yourdatabase</url>
</jdbc>
<generator>
...
</generator>
</configuration>
</plugin>
Using DSLContext
The fluent API offered by jOOQ is initiated through the org.jooq.DSLContext interface. Spring Boot
auto-configures a DSLContext as a Spring Bean and connects it to your application DataSource. To use
the DSLContext, you can @Autowire it, as shown in the following example:
@Component
public class JooqExample implements CommandLineRunner {
@Autowired
public JooqExample(DSLContext dslContext) {
this.create = dslContext;
}
The jOOQ manual tends to use a variable named create to hold the DSLContext.
You can then use the DSLContext to construct your queries, as shown in the following example:
131
public List<GregorianCalendar> authorsBornAfter1980() {
return this.create.selectFrom(AUTHOR)
.where(AUTHOR.DATE_OF_BIRTH.greaterThan(new GregorianCalendar(1980, 0, 1)))
.fetch(AUTHOR.DATE_OF_BIRTH);
}
Unless the spring.jooq.sql-dialect property has been configured, Spring Boot determines the SQL
dialect to use for your datasource. If Spring Boot could not detect the dialect, it uses DEFAULT.
Spring Boot can only auto-configure dialects supported by the open source version
of jOOQ.
Customizing jOOQ
More advanced customizations can be achieved by defining your own @Bean definitions, which is
used when the jOOQ Configuration is created. You can define beans for the following jOOQ Types:
• ConnectionProvider
• ExecutorProvider
• TransactionProvider
• RecordMapperProvider
• RecordUnmapperProvider
• Settings
• RecordListenerProvider
• ExecuteListenerProvider
• VisitListenerProvider
• TransactionListenerProvider
You can also create your own org.jooq.Configuration @Bean if you want to take complete control of
the jOOQ configuration.
The Reactive Relational Database Connectivity (R2DBC) project brings reactive programming APIs
to relational databases. R2DBC’s io.r2dbc.spi.Connection provides a standard method of working
with non-blocking database connections. Connections are provided via a ConnectionFactory, similar
to a DataSource with jdbc.
132
spring.r2dbc.url=r2dbc:postgresql://localhost/test
spring.r2dbc.username=dbuser
spring.r2dbc.password=dbpass
You do not need to specify a driver class name, since Spring Boot obtains the
driver from R2DBC’s Connection Factory discovery.
At least the url should be provided. Information specified in the URL takes
precedence over individual properties, i.e. name, username, password and pooling
options.
To customize the connections created by a ConnectionFactory, i.e., set specific parameters that you
do not want (or cannot) configure in your central database configuration, you can use a
ConnectionFactoryOptionsBuilderCustomizer @Bean. The following example shows how to manually
override the database port while the rest of the options is taken from the application configuration:
@Bean
public ConnectionFactoryOptionsBuilderCustomizer connectionFactoryPortCustomizer() {
return (builder) -> builder.option(PORT, 5432);
}
The following examples shows how to set some PostgreSQL connection options:
@Bean
public ConnectionFactoryOptionsBuilderCustomizer postgresCustomizer() {
Map<String, String> options = new HashMap<>();
options.put("lock_timeout", "30s");
options.put("statement_timeout", "60s");
return (builder) -> builder.option(OPTIONS, options);
}
When a ConnectionFactory bean is available, the regular JDBC DataSource auto-configuration backs
off. If you want to retain the JDBC DataSource auto-configuration, and are comfortable with the risk
of using the blocking JDBC API in a reactive application, add
@Import(DataSourceAutoConfiguration.class) on a @Configuration class in your application to re-
enable it.
Similarly to the JDBC support, Spring Boot can automatically configure an embedded database for
reactive usage. You need not provide any connection URLs. You need only include a build
dependency to the embedded database that you want to use, as shown in the following example:
133
<dependency>
<groupId>io.r2dbc</groupId>
<artifactId>r2dbc-h2</artifactId>
<scope>runtime</scope>
</dependency>
If you are using this feature in your tests, you may notice that the same database is
reused by your whole test suite regardless of the number of application contexts
that you use. If you want to make sure that each context has a separate embedded
database, you should set spring.r2dbc.generate-unique-name to true.
Using DatabaseClient
Spring Data’s DatabaseClient class is auto-configured, and you can @Autowire it directly into your
own beans, as shown in the following example:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.r2dbc.function.DatabaseClient;
import org.springframework.stereotype.Component;
@Component
public class MyBean {
@Autowired
public MyBean(DatabaseClient databaseClient) {
this.databaseClient = databaseClient;
}
// ...
Spring Data R2DBC repositories are interfaces that you can define to access data. Queries are
created automatically from your method names. For example, a CityRepository interface might
declare a findAllByState(String state) method to find all the cities in a given state.
For more complex queries, you can annotate your method with Spring Data’s Query annotation.
Spring Data repositories usually extend from the Repository or CrudRepository interfaces. If you use
auto-configuration, repositories are searched from the package containing your main configuration
class (the one annotated with @EnableAutoConfiguration or @SpringBootApplication) down.
The following example shows a typical Spring Data repository interface definition:
134
package com.example.myapp.domain;
import org.springframework.data.domain.*;
import org.springframework.data.repository.*;
import reactor.core.publisher.Mono;
We have barely scratched the surface of Spring Data R2DBC. For complete details,
see the Spring Data R2DBC reference documentation.
• MongoDB
• Neo4J
• Elasticsearch
• Solr
• Redis
• GemFire or Geode
• Cassandra
• Couchbase
• LDAP
Spring Boot provides auto-configuration for Redis, MongoDB, Neo4j, Elasticsearch, Solr Cassandra,
Couchbase, and LDAP. You can make use of the other projects, but you must configure them
yourself. Refer to the appropriate reference documentation at spring.io/projects/spring-data.
5.12.1. Redis
Redis is a cache, message broker, and richly-featured key-value store. Spring Boot offers basic auto-
configuration for the Lettuce and Jedis client libraries and the abstractions on top of them provided
by Spring Data Redis.
135
we also provide a spring-boot-starter-data-redis-reactive “Starter” for
consistency with the other stores with reactive support.
Connecting to Redis
@Component
public class MyBean {
@Autowired
public MyBean(StringRedisTemplate template) {
this.template = template;
}
// ...
If you add your own @Bean of any of the auto-configured types, it replaces the default (except in the
case of RedisTemplate, when the exclusion is based on the bean name, redisTemplate, not its type).
A pooled connection factory is auto-configured if commons-pool2 is on the classpath and at least one
Pool option of RedisProperties is set.
5.12.2. MongoDB
MongoDB is an open-source NoSQL document database that uses a JSON-like schema instead of
traditional table-based relational data. Spring Boot offers several conveniences for working with
MongoDB, including the spring-boot-starter-data-mongodb and spring-boot-starter-data-mongodb-
reactive “Starters”.
136
import org.springframework.data.mongodb.MongoDatabaseFactory;
import com.mongodb.client.MongoDatabase;
@Component
public class MyBean {
@Autowired
public MyBean(MongoDatabaseFactory mongo) {
this.mongo = mongo;
}
// ...
You can set the spring.data.mongodb.uri property to change the URL and configure additional
settings such as the replica set, as shown in the following example:
spring.data.mongodb.uri=mongodb://user:secret@mongo1.example.com:12345,mongo2.example.
com:23456/test
Alternatively, you can specify connection details using discrete properties. For example, you might
declare the following settings in your application.properties:
spring.data.mongodb.host=mongoserver.example.com
spring.data.mongodb.port=27017
spring.data.mongodb.database=test
spring.data.mongodb.username=user
spring.data.mongodb.password=secret
If you have defined your own MongoClient, it will be used to auto-configure a suitable
MongoDatabaseFactory.
137
If you do not use Spring Data MongoDB, you can inject a MongoClient bean instead
of using MongoDatabaseFactory. If you want to take complete control of establishing
the MongoDB connection, you can also declare your own MongoDatabaseFactory or
MongoClient bean.
If you are using the reactive driver, Netty is required for SSL. The auto-
configuration configures this factory automatically if Netty is available and the
factory to use hasn’t been customized already.
MongoTemplate
Spring Data MongoDB provides a MongoTemplate class that is very similar in its design to Spring’s
JdbcTemplate. As with JdbcTemplate, Spring Boot auto-configures a bean for you to inject the
template, as follows:
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.stereotype.Component;
@Component
public class MyBean {
// ...
Spring Data includes repository support for MongoDB. As with the JPA repositories discussed
earlier, the basic principle is that queries are constructed automatically, based on method names.
In fact, both Spring Data JPA and Spring Data MongoDB share the same common infrastructure. You
could take the JPA example from earlier and, assuming that City is now a MongoDB data class
rather than a JPA @Entity, it works in the same way, as shown in the following example:
138
package com.example.myapp.domain;
import org.springframework.data.domain.*;
import org.springframework.data.repository.*;
For complete details of Spring Data MongoDB, including its rich object mapping
technologies, refer to its reference documentation.
Embedded Mongo
Spring Boot offers auto-configuration for Embedded Mongo. To use it in your Spring Boot
application, add a dependency on de.flapdoodle.embed:de.flapdoodle.embed.mongo.
The port that Mongo listens on can be configured by setting the spring.data.mongodb.port property.
To use a randomly allocated free port, use a value of 0. The MongoClient created by
MongoAutoConfiguration is automatically configured to use the randomly allocated port.
If you do not configure a custom port, the embedded support uses a random port
(rather than 27017) by default.
If you have SLF4J on the classpath, the output produced by Mongo is automatically routed to a
logger named org.springframework.boot.autoconfigure.mongo.embedded.EmbeddedMongo.
You can declare your own IMongodConfig and IRuntimeConfig beans to take control of the Mongo
instance’s configuration and logging routing. The download configuration can be customized by
declaring a DownloadConfigBuilderCustomizer bean.
5.12.3. Neo4j
Neo4j is an open-source NoSQL graph database that uses a rich data model of nodes connected by
first class relationships, which is better suited for connected big data than traditional RDBMS
approaches. Spring Boot offers several conveniences for working with Neo4j, including the spring-
boot-starter-data-neo4j “Starter”.
139
default, the instance tries to connect to a Neo4j server at localhost:7687 using the Bolt protocol. The
following example shows how to inject a Neo4j Session:
@Component
public class MyBean {
@Autowired
public MyBean(Session session) {
this.session = session;
}
// ...
You can configure the uri and credentials to use by setting the spring.data.neo4j.* properties, as
shown in the following example:
spring.data.neo4j.uri=bolt://my-server:7687
spring.data.neo4j.username=neo4j
spring.data.neo4j.password=secret
You can take full control over the session creation by adding either an
org.neo4j.ogm.config.Configuration bean or an org.neo4j.ogm.session.SessionFactory bean.
As the embedded Neo4j OGM driver does not provide the Neo4j kernel itself, you
have to declare org.neo4j:neo4j as dependency yourself. Refer to the Neo4j OGM
documentation for a list of compatible versions.
The embedded driver takes precedence over the other drivers when there are multiple drivers on
the classpath. You can explicitly disable the embedded mode by setting
spring.data.neo4j.embedded.enabled=false.
Data Neo4j Tests automatically make use of an embedded Neo4j instance if the embedded driver
and Neo4j kernel are on the classpath as described above.
You can enable persistence for the embedded mode by providing a path to a
database file in your
spring.data.neo4j.uri=file://var/tmp/graph.db.
configuration, e.g.
140
Using Native Types
Neo4j-OGM can map some types, like those in java.time.*, to String-based properties or to one of
the native types that Neo4j provides. For backwards compatibility reasons the default for Neo4j-
OGM is to use a String-based representation. To use native types, add a dependency on either
org.neo4j:neo4j-ogm-bolt-native-types or org.neo4j:neo4j-ogm-embedded-native-types, and
configure the spring.data.neo4j.use-native-types property as shown in the following example:
spring.data.neo4j.use-native-types=true
Neo4jSession
By default, if you are running a web application, the session is bound to the thread for the entire
processing of the request (that is, it uses the "Open Session in View" pattern). If you do not want this
behavior, add the following line to your application.properties file:
spring.data.neo4j.open-in-view=false
Spring Data Neo4j shares the common infrastructure with Spring Data JPA as many other Spring
Data modules do. You could take the JPA example from earlier and define City as Neo4j OGM
@NodeEntity rather than JPA @Entity and the repository abstraction works in the same way, as
shown in the following example:
package com.example.myapp.domain;
import java.util.Optional;
import org.springframework.data.neo4j.repository.*;
For complete details of Spring Data Neo4j, including its object mapping
technologies, refer to the reference documentation.
141
5.12.4. Solr
Apache Solr is a search engine. Spring Boot offers basic auto-configuration for the Solr 5 client
library and the abstractions on top of it provided by Spring Data Solr. There is a spring-boot-
starter-data-solr “Starter” for collecting the dependencies in a convenient way.
As of Spring Boot 2.3, support for Spring Data Solr has been deprecated and will be
removed in a future release.
Connecting to Solr
You can inject an auto-configured SolrClient instance as you would any other Spring bean. By
default, the instance tries to connect to a server at localhost:8983/solr. The following example
shows how to inject a Solr bean:
@Component
public class MyBean {
@Autowired
public MyBean(SolrClient solr) {
this.solr = solr;
}
// ...
If you add your own @Bean of type SolrClient, it replaces the default.
Spring Data includes repository support for Apache Solr. As with the JPA repositories discussed
earlier, the basic principle is that queries are automatically constructed for you based on method
names.
In fact, both Spring Data JPA and Spring Data Solr share the same common infrastructure. You
could take the JPA example from earlier and, assuming that City is now a @SolrDocument class rather
than a JPA @Entity, it works in the same way.
IP: For complete details of Spring Data Solr, refer to the reference documentation.
5.12.5. Elasticsearch
Elasticsearch is an open source, distributed, RESTful search and analytics engine. Spring Boot offers
basic auto-configuration for Elasticsearch.
142
• The official Java "Low Level" and "High Level" REST clients
Elasticsearch ships two different REST clients that you can use to query a cluster: the "Low Level"
client and the "High Level" client.
spring.elasticsearch.rest.uris=https://search.example.com:9200
spring.elasticsearch.rest.read-timeout=10s
spring.elasticsearch.rest.username=user
spring.elasticsearch.rest.password=secret
You can also register an arbitrary number of beans that implement RestClientBuilderCustomizer for
more advanced customizations. To take full control over the registration, define a RestClientBuilder
bean.
By default, Spring Boot will auto-configure and register a ReactiveElasticsearchClient bean that
targets localhost:9200. You can further tune how it is configured, as shown in the following
example:
spring.data.elasticsearch.client.reactive.endpoints=search.example.com:9200
spring.data.elasticsearch.client.reactive.use-ssl=true
spring.data.elasticsearch.client.reactive.socket-timeout=10s
spring.data.elasticsearch.client.reactive.username=user
spring.data.elasticsearch.client.reactive.password=secret
If the configuration properties are not enough and you’d like to fully control the client
configuration, you can register a custom ClientConfiguration bean.
143
Connecting to Elasticsearch by Using Spring Data
@Component
public class MyBean {
// ...
In the presence of spring-data-elasticsearch and the required dependencies for using a WebClient
(typically spring-boot-starter-webflux), Spring Boot can also auto-configure a
ReactiveElasticsearchClient and a ReactiveElasticsearchTemplate as beans. They are the reactive
equivalent of the other REST clients.
Spring Data includes repository support for Elasticsearch. As with the JPA repositories discussed
earlier, the basic principle is that queries are constructed for you automatically based on method
names.
In fact, both Spring Data JPA and Spring Data Elasticsearch share the same common infrastructure.
You could take the JPA example from earlier and, assuming that City is now an Elasticsearch
@Document class rather than a JPA @Entity, it works in the same way.
Spring Boot supports both classic and reactive Elasticsearch repositories, using the
ElasticsearchRestTemplate or ReactiveElasticsearchTemplate beans. Most likely those beans are
auto-configured by Spring Boot given the required dependencies are present.
If you wish to use your own template for backing the Elasticsearch repositories, you can add your
own ElasticsearchRestTemplate or ElasticsearchOperations @Bean, as long as it is named
"elasticsearchTemplate". Same applies to ReactiveElasticsearchTemplate and
ReactiveElasticsearchOperations, with the bean name "reactiveElasticsearchTemplate".
You can choose to disable the repositories support with the following property:
144
spring.data.elasticsearch.repositories.enabled=false
5.12.6. Cassandra
Cassandra is an open source, distributed database management system designed to handle large
amounts of data across many commodity servers. Spring Boot offers auto-configuration for
Cassandra and the abstractions on top of it provided by Spring Data Cassandra. There is a spring-
boot-starter-data-cassandra “Starter” for collecting the dependencies in a convenient way.
Connecting to Cassandra
spring.data.cassandra.keyspace-name=mykeyspace
spring.data.cassandra.contact-points=cassandrahost1:9042,cassandrahost2:9042
spring.data.cassandra.local-datacenter=datacenter1
If the port is the same for all your contact points you can use a shortcut and only specify the host
names, as shown in the following example:
spring.data.cassandra.keyspace-name=mykeyspace
spring.data.cassandra.contact-points=cassandrahost1,cassandrahost2
spring.data.cassandra.local-datacenter=datacenter1
Those two examples are identical as the port default to 9042. If you need to
configure the port, use spring.data.cassandra.port.
The Cassandra driver has its own configuration infrastructure that loads an
application.conf at the root of the classpath.
Spring Boot does not look for such a file and rather provides a number of
configuration properties via the spring.data.cassandra.* namespace. For more
advanced driver customizations, you can register an arbitrary number of beans
that implement DriverConfigLoaderBuilderCustomizer. The CqlSession can be
customized with a bean of type CqlSessionBuilderCustomizer.
145
@Component
public class MyBean {
// ...
If you add your own @Bean of type CassandraTemplate, it replaces the default.
Spring Data includes basic repository support for Cassandra. Currently, this is more limited than
the JPA repositories discussed earlier and needs to annotate finder methods with @Query.
5.12.7. Couchbase
Connecting to Couchbase
You can get a Cluster by adding the Couchbase SDK and some configuration. The spring.couchbase.*
properties can be used to customize the connection. Generally, you provide the connection string,
username, and password, as shown in the following example:
spring.couchbase.connection-string=couchbase://192.168.1.123
spring.couchbase.username=user
spring.couchbase.password=secret
It is also possible to customize some of the ClusterEnvironment settings. For instance, the following
configuration changes the timeout to use to open a new Bucket and enables SSL support:
146
spring.couchbase.env.timeouts.connect=3000
spring.couchbase.env.ssl.key-store=/location/of/keystore.jks
spring.couchbase.env.ssl.key-store-password=secret
Spring Data includes repository support for Couchbase. For complete details of Spring Data
Couchbase, refer to the reference documentation.
You can inject an auto-configured CouchbaseTemplate instance as you would with any other Spring
Bean, provided a CouchbaseClientFactory bean is available. This happens when a Cluster is
available, as described above, and a bucket name has been specified:
spring.data.couchbase.bucket-name=my-bucket
@Component
public class MyBean {
@Autowired
public MyBean(CouchbaseTemplate template) {
this.template = template;
}
// ...
There are a few beans that you can define in your own configuration to override those provided by
the auto-configuration:
To avoid hard-coding those names in your own config, you can reuse BeanNames provided by Spring
Data Couchbase. For instance, you can customize the converters to use, as follows:
147
@Configuration(proxyBeanMethods = false)
public class SomeConfiguration {
@Bean(BeanNames.COUCHBASE_CUSTOM_CONVERSIONS)
public CustomConversions myCustomConversions() {
return new CustomConversions(...);
}
// ...
5.12.8. LDAP
To connect to an LDAP server, make sure you declare a dependency on the spring-boot-starter-
data-ldap “Starter” or spring-ldap-core and then declare the URLs of your server in your
application.properties, as shown in the following example:
spring.ldap.urls=ldap://myserver:1235
spring.ldap.username=admin
spring.ldap.password=secret
If you need to customize connection settings, you can use the spring.ldap.base and
spring.ldap.base-environment properties.
Spring Data includes repository support for LDAP. For complete details of Spring Data LDAP, refer to
the reference documentation.
You can also inject an auto-configured LdapTemplate instance as you would with any other Spring
Bean, as shown in the following example:
148
@Component
public class MyBean {
@Autowired
public MyBean(LdapTemplate template) {
this.template = template;
}
// ...
For testing purposes, Spring Boot supports auto-configuration of an in-memory LDAP server from
UnboundID. To configure the server, add a dependency to com.unboundid:unboundid-ldapsdk and
declare a spring.ldap.embedded.base-dn property, as follows:
spring.ldap.embedded.base-dn=dc=spring,dc=io
spring.ldap.embedded.base-dn:
- dc=spring,dc=io
- dc=pivotal,dc=io
In properties files, you must include the index as part of the property name:
spring.ldap.embedded.base-dn[0]=dc=spring,dc=io
spring.ldap.embedded.base-dn[1]=dc=pivotal,dc=io
By default, the server starts on a random port and triggers the regular LDAP support. There is no
need to specify a spring.ldap.urls property.
If there is a schema.ldif file on your classpath, it is used to initialize the server. If you want to load
the initialization script from a different resource, you can also use the spring.ldap.embedded.ldif
property.
By default, a standard schema is used to validate LDIF files. You can turn off validation altogether by
setting the spring.ldap.embedded.validation.enabled property. If you have custom attributes, you
149
can use spring.ldap.embedded.validation.schema to define your custom attribute types or object
classes.
5.12.9. InfluxDB
InfluxDB is an open-source time series database optimized for fast, high-availability storage and
retrieval of time series data in fields such as operations monitoring, application metrics, Internet-
of-Things sensor data, and real-time analytics.
Connecting to InfluxDB
Spring Boot auto-configures an InfluxDB instance, provided the influxdb-java client is on the
classpath and the URL of the database is set, as shown in the following example:
spring.influx.url=https://172.0.0.1:8086
If the connection to InfluxDB requires a user and password, you can set the spring.influx.user and
spring.influx.password properties accordingly.
InfluxDB relies on OkHttp. If you need to tune the http client InfluxDB uses behind the scenes, you
can register an InfluxDbOkHttpClientBuilderProvider bean.
5.13. Caching
The Spring Framework provides support for transparently adding caching to an application. At its
core, the abstraction applies caching to methods, thus reducing the number of executions based on
the information available in the cache. The caching logic is applied transparently, without any
interference to the invoker. Spring Boot auto-configures the cache infrastructure as long as caching
support is enabled via the @EnableCaching annotation.
Check the relevant section of the Spring Framework reference for more details.
In a nutshell, to add caching to an operation of your service add the relevant annotation to its
method, as shown in the following example:
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Component;
@Component
public class MathService {
@Cacheable("piDecimals")
public int computePiDecimal(int i) {
// ...
}
150
This example demonstrates the use of caching on a potentially costly operation. Before invoking
computePiDecimal, the abstraction looks for an entry in the piDecimals cache that matches the i
argument. If an entry is found, the content in the cache is immediately returned to the caller, and
the method is not invoked. Otherwise, the method is invoked, and the cache is updated before
returning the value.
You can also use the standard JSR-107 (JCache) annotations (such as @CacheResult)
transparently. However, we strongly advise you to not mix and match the Spring
Cache and JCache annotations.
If you do not add any specific cache library, Spring Boot auto-configures a simple provider that uses
concurrent maps in memory. When a cache is required (such as piDecimals in the preceding
example), this provider creates it for you. The simple provider is not really recommended for
production usage, but it is great for getting started and making sure that you understand the
features. When you have made up your mind about the cache provider to use, please make sure to
read its documentation to figure out how to configure the caches that your application uses. Nearly
all providers require you to explicitly configure every cache that you use in the application. Some
offer a way to customize the default caches defined by the spring.cache.cache-names property.
The cache abstraction does not provide an actual store and relies on abstraction materialized by the
org.springframework.cache.Cache and org.springframework.cache.CacheManager interfaces.
If you have not defined a bean of type CacheManager or a CacheResolver named cacheResolver (see
CachingConfigurer), Spring Boot tries to detect the following providers (in the indicated order):
1. Generic
3. EhCache 2.x
4. Hazelcast
5. Infinispan
6. Couchbase
7. Redis
8. Caffeine
9. Simple
151
Use the spring-boot-starter-cache “Starter” to quickly add basic caching
dependencies. The starter brings in spring-context-support. If you add
dependencies manually, you must include spring-context-support in order to use
the JCache, EhCache 2.x, or Caffeine support.
If the CacheManager is auto-configured by Spring Boot, you can further tune its configuration before
it is fully initialized by exposing a bean that implements the CacheManagerCustomizer interface. The
following example sets a flag to say that null values should be passed down to the underlying map:
@Bean
public CacheManagerCustomizer<ConcurrentMapCacheManager> cacheManagerCustomizer() {
return new CacheManagerCustomizer<ConcurrentMapCacheManager>() {
@Override
public void customize(ConcurrentMapCacheManager cacheManager) {
cacheManager.setAllowNullValues(false);
}
};
}
Generic
Generic caching is used if the context defines at least one org.springframework.cache.Cache bean. A
CacheManager wrapping all beans of that type is created.
JCache (JSR-107)
It might happen that more than one provider is present, in which case the provider must be
explicitly specified. Even if the JSR-107 standard does not enforce a standardized way to define the
location of the configuration file, Spring Boot does its best to accommodate setting a cache with
implementation details, as shown in the following example:
152
When a cache library offers both a native implementation and JSR-107 support,
Spring Boot prefers the JSR-107 support, so that the same features are available if
you switch to a different JSR-107 implementation.
EhCache 2.x
EhCache 2.x is used if a file named ehcache.xml can be found at the root of the classpath. If EhCache
2.x is found, the EhCacheCacheManager provided by the spring-boot-starter-cache “Starter” is used to
bootstrap the cache manager. An alternate configuration file can be provided as well, as shown in
the following example:
spring.cache.ehcache.config=classpath:config/another-config.xml
Hazelcast
Spring Boot has general support for Hazelcast. If a HazelcastInstance has been auto-configured, it is
automatically wrapped in a CacheManager.
Infinispan
Infinispan has no default configuration file location, so it must be specified explicitly. Otherwise,
the default bootstrap is used.
spring.cache.infinispan.config=infinispan.xml
153
The support of Infinispan in Spring Boot is restricted to the embedded mode and is
quite basic. If you want more options, you should use the official Infinispan Spring
Boot starter instead. See Infinispan’s documentation for more details.
Couchbase
spring.cache.cache-names=cache1,cache2
spring.cache.couchbase.expiration=10m
@Bean
public CouchbaseCacheManagerBuilderCustomizer
myCouchbaseCacheManagerBuilderCustomizer() {
return (builder) -> builder
.withCacheConfiguration("cache1",
CouchbaseCacheConfiguration.defaultCacheConfig().entryExpiry(Duration.ofSeconds(10)))
.withCacheConfiguration("cache2",
CouchbaseCacheConfiguration.defaultCacheConfig().entryExpiry(Duration.ofMinutes(1)));
Redis
spring.cache.cache-names=cache1,cache2
spring.cache.redis.time-to-live=600000
154
By default, a key prefix is added so that, if two separate caches use the same key,
Redis does not have overlapping keys and cannot return invalid values. We
strongly recommend keeping this setting enabled if you create your own
RedisCacheManager.
@Bean
public RedisCacheManagerBuilderCustomizer myRedisCacheManagerBuilderCustomizer() {
return (builder) -> builder
.withCacheConfiguration("cache1",
RedisCacheConfiguration.defaultCacheConfig().entryTtl(Duration.ofSeconds(10)))
.withCacheConfiguration("cache2",
RedisCacheConfiguration.defaultCacheConfig().entryTtl(Duration.ofMinutes(1)));
Caffeine
Caffeine is a Java 8 rewrite of Guava’s cache that supersedes support for Guava. If Caffeine is
present, a CaffeineCacheManager (provided by the spring-boot-starter-cache “Starter”) is auto-
configured. Caches can be created on startup by setting the spring.cache.cache-names property and
can be customized by one of the following (in the indicated order):
For instance, the following configuration creates cache1 and cache2 caches with a maximum size of
500 and a time to live of 10 minutes
spring.cache.cache-names=cache1,cache2
spring.cache.caffeine.spec=maximumSize=500,expireAfterAccess=600s
155
Simple
If none of the other providers can be found, a simple implementation using a ConcurrentHashMap as
the cache store is configured. This is the default if no caching library is present in your application.
By default, caches are created as needed, but you can restrict the list of available caches by setting
the cache-names property. For instance, if you want only cache1 and cache2 caches, set the cache-
names property as follows:
spring.cache.cache-names=cache1,cache2
If you do so and your application uses a cache not listed, then it fails at runtime when the cache is
needed, but not on startup. This is similar to the way the "real" cache providers behave if you use
an undeclared cache.
None
spring.cache.type=none
5.14. Messaging
The Spring Framework provides extensive support for integrating with messaging systems, from
simplified use of the JMS API using JmsTemplate to a complete infrastructure to receive messages
asynchronously. Spring AMQP provides a similar feature set for the Advanced Message Queuing
Protocol. Spring Boot also provides auto-configuration options for RabbitTemplate and RabbitMQ.
Spring WebSocket natively includes support for STOMP messaging, and Spring Boot has support for
that through starters and a small amount of auto-configuration. Spring Boot also has support for
Apache Kafka.
5.14.1. JMS
ActiveMQ Support
When ActiveMQ is available on the classpath, Spring Boot can also configure a ConnectionFactory. If
the broker is present, an embedded broker is automatically started and configured (provided no
broker URL is specified through configuration).
156
If you use spring-boot-starter-activemq, the necessary dependencies to connect or
embed an ActiveMQ instance are provided, as is the Spring infrastructure to
integrate with JMS.
spring.activemq.broker-url=tcp://192.168.1.210:9876
spring.activemq.user=admin
spring.activemq.password=secret
spring.jms.cache.session-cache-size=5
spring.activemq.pool.enabled=true
spring.activemq.pool.max-connections=50
See ActiveMQProperties for more of the supported options. You can also register an
arbitrary number of beans that implement ActiveMQConnectionFactoryCustomizer
for more advanced customizations.
By default, ActiveMQ creates a destination if it does not yet exist so that destinations are resolved
against their provided names.
Spring Boot can auto-configure a ConnectionFactory when it detects that ActiveMQ Artemis is
available on the classpath. If the broker is present, an embedded broker is automatically started
and configured (unless the mode property has been explicitly set). The supported modes are
embedded (to make explicit that an embedded broker is required and that an error should occur if
the broker is not available on the classpath) and native (to connect to a broker using the netty
transport protocol). When the latter is configured, Spring Boot configures a ConnectionFactory that
connects to a broker running on the local machine with the default settings.
157
ActiveMQ Artemis configuration is controlled by external configuration properties in
spring.artemis.*. For example, you might declare the following section in application.properties:
spring.artemis.mode=native
spring.artemis.host=192.168.1.210
spring.artemis.port=9876
spring.artemis.user=admin
spring.artemis.password=secret
When embedding the broker, you can choose if you want to enable persistence and list the
destinations that should be made available. These can be specified as a comma-separated list to
create them with the default options, or you can define bean(s) of type
org.apache.activemq.artemis.jms.server.config.JMSQueueConfiguration or
org.apache.activemq.artemis.jms.server.config.TopicConfiguration, for advanced queue and topic
configurations, respectively.
spring.jms.cache.session-cache-size=5
spring.artemis.pool.enabled=true
spring.artemis.pool.max-connections=50
No JNDI lookup is involved, and destinations are resolved against their names, using either the name
attribute in the Artemis configuration or the names provided through configuration.
If you are running your application in an application server, Spring Boot tries to locate a JMS
ConnectionFactory by using JNDI. By default, the java:/JmsXA and java:/XAConnectionFactory location
are checked. You can use the spring.jms.jndi-name property if you need to specify an alternative
location, as shown in the following example:
spring.jms.jndi-name=java:/MyConnectionFactory
Sending a Message
Spring’s JmsTemplate is auto-configured, and you can autowire it directly into your own beans, as
158
shown in the following example:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.stereotype.Component;
@Component
public class MyBean {
@Autowired
public MyBean(JmsTemplate jmsTemplate) {
this.jmsTemplate = jmsTemplate;
}
// ...
Receiving a Message
When the JMS infrastructure is present, any bean can be annotated with @JmsListener to create a
listener endpoint. If no JmsListenerContainerFactory has been defined, a default one is configured
automatically. If a DestinationResolver or a MessageConverter beans is defined, it is associated
automatically to the default factory.
159
@Component
public class MyBean {
@JmsListener(destination = "someQueue")
public void processMessage(String content) {
// ...
}
If you need to create more JmsListenerContainerFactory instances or if you want to override the
default, Spring Boot provides a DefaultJmsListenerContainerFactoryConfigurer that you can use to
initialize a DefaultJmsListenerContainerFactory with the same settings as the one that is auto-
configured.
For instance, the following example exposes another factory that uses a specific MessageConverter:
@Configuration(proxyBeanMethods = false)
static class JmsConfiguration {
@Bean
public DefaultJmsListenerContainerFactory myFactory(
DefaultJmsListenerContainerFactoryConfigurer configurer) {
DefaultJmsListenerContainerFactory factory =
new DefaultJmsListenerContainerFactory();
configurer.configure(factory, connectionFactory());
factory.setMessageConverter(myMessageConverter());
return factory;
}
Then you can use the factory in any @JmsListener-annotated method as follows:
@Component
public class MyBean {
160
5.14.2. AMQP
The Advanced Message Queuing Protocol (AMQP) is a platform-neutral, wire-level protocol for
message-oriented middleware. The Spring AMQP project applies core Spring concepts to the
development of AMQP-based messaging solutions. Spring Boot offers several conveniences for
working with AMQP through RabbitMQ, including the spring-boot-starter-amqp “Starter”.
RabbitMQ support
RabbitMQ is a lightweight, reliable, scalable, and portable message broker based on the AMQP
protocol. Spring uses RabbitMQ to communicate through the AMQP protocol.
spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672
spring.rabbitmq.username=admin
spring.rabbitmq.password=secret
Alternatively, you could configure the same connection using the addresses attribute:
spring.rabbitmq.addresses=amqp://admin:secret@localhost
When specifying addresses that way, the host and port properties are ignored. If
the address uses the amqps protocol, SSL support is enabled automatically.
See Understanding AMQP, the protocol used by RabbitMQ for more details.
Sending a Message
Spring’s AmqpTemplate and AmqpAdmin are auto-configured, and you can autowire them directly into
your own beans, as shown in the following example:
161
import org.springframework.amqp.core.AmqpAdmin;
import org.springframework.amqp.core.AmqpTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
@Component
public class MyBean {
@Autowired
public MyBean(AmqpAdmin amqpAdmin, AmqpTemplate amqpTemplate) {
this.amqpAdmin = amqpAdmin;
this.amqpTemplate = amqpTemplate;
}
// ...
To retry operations, you can enable retries on the AmqpTemplate (for example, in the event that the
broker connection is lost):
spring.rabbitmq.template.retry.enabled=true
spring.rabbitmq.template.retry.initial-interval=2s
Retries are disabled by default. You can also customize the RetryTemplate programmatically by
declaring a RabbitRetryTemplateCustomizer bean.
If you need to create more RabbitTemplate instances or if you want to override the default, Spring
Boot provides a RabbitTemplateConfigurer bean that you can use to initialize a RabbitTemplate with
the same settings as the factories used by the auto-configuration.
Receiving a Message
When the Rabbit infrastructure is present, any bean can be annotated with @RabbitListener to
create a listener endpoint. If no RabbitListenerContainerFactory has been defined, a default
SimpleRabbitListenerContainerFactory is automatically configured and you can switch to a direct
container using the spring.rabbitmq.listener.type property. If a MessageConverter or a
MessageRecoverer bean is defined, it is automatically associated with the default factory.
162
The following sample component creates a listener endpoint on the someQueue queue:
@Component
public class MyBean {
@RabbitListener(queues = "someQueue")
public void processMessage(String content) {
// ...
}
If you need to create more RabbitListenerContainerFactory instances or if you want to override the
default, Spring Boot provides a SimpleRabbitListenerContainerFactoryConfigurer and a
DirectRabbitListenerContainerFactoryConfigurer that you can use to initialize a
SimpleRabbitListenerContainerFactory and a DirectRabbitListenerContainerFactory with the same
settings as the factories used by the auto-configuration.
It does not matter which container type you chose. Those two beans are exposed
by the auto-configuration.
For instance, the following configuration class exposes another factory that uses a specific
MessageConverter:
@Configuration(proxyBeanMethods = false)
static class RabbitConfiguration {
@Bean
public SimpleRabbitListenerContainerFactory myFactory(
SimpleRabbitListenerContainerFactoryConfigurer configurer) {
SimpleRabbitListenerContainerFactory factory =
new SimpleRabbitListenerContainerFactory();
configurer.configure(factory, connectionFactory);
factory.setMessageConverter(myMessageConverter());
return factory;
}
Then you can use the factory in any @RabbitListener-annotated method, as follows:
163
@Component
public class MyBean {
You can enable retries to handle situations where your listener throws an exception. By default,
RejectAndDontRequeueRecoverer is used, but you can define a MessageRecoverer of your own. When
retries are exhausted, the message is rejected and either dropped or routed to a dead-letter
exchange if the broker is configured to do so. By default, retries are disabled. You can also
customize the RetryTemplate programmatically by declaring a RabbitRetryTemplateCustomizer bean.
By default, if retries are disabled and the listener throws an exception, the delivery
is retried indefinitely. You can modify this behavior in two ways: Set the
defaultRequeueRejected property to false so that zero re-deliveries are attempted
or throw an AmqpRejectAndDontRequeueException to signal the message should be
rejected. The latter is the mechanism used when retries are enabled and the
maximum number of delivery attempts is reached.
spring.kafka.bootstrap-servers=localhost:9092
spring.kafka.consumer.group-id=myGroup
To create a topic on startup, add a bean of type NewTopic. If the topic already exists,
the bean is ignored.
Sending a Message
Spring’s KafkaTemplate is auto-configured, and you can autowire it directly in your own beans, as
shown in the following example:
164
@Component
public class MyBean {
@Autowired
public MyBean(KafkaTemplate kafkaTemplate) {
this.kafkaTemplate = kafkaTemplate;
}
// ...
Receiving a Message
When the Apache Kafka infrastructure is present, any bean can be annotated with @KafkaListener
to create a listener endpoint. If no KafkaListenerContainerFactory has been defined, a default one is
automatically configured with keys defined in spring.kafka.listener.*.
@Component
public class MyBean {
@KafkaListener(topics = "someTopic")
public void processMessage(String content) {
// ...
}
165
Kafka Streams
Spring for Apache Kafka provides a factory bean to create a StreamsBuilder object and manage the
lifecycle of its streams. Spring Boot auto-configures the required KafkaStreamsConfiguration bean as
long as kafka-streams is on the classpath and Kafka Streams is enabled via the @EnableKafkaStreams
annotation.
Enabling Kafka Streams means that the application id and bootstrap servers must be set. The
former can be configured using spring.kafka.streams.application-id, defaulting to
spring.application.name if not set. The latter can be set globally or specifically overridden only for
streams.
Several additional properties are available using dedicated properties; other arbitrary Kafka
properties can be set using the spring.kafka.streams.properties namespace. See also Additional
Kafka Properties for more information.
To use the factory bean, wire StreamsBuilder into your @Bean as shown in the following example:
@Configuration(proxyBeanMethods = false)
@EnableKafkaStreams
public static class KafkaStreamsExampleConfiguration {
@Bean
public KStream<Integer, String> kStream(StreamsBuilder streamsBuilder) {
KStream<Integer, String> stream = streamsBuilder.stream("ks1In");
stream.map((k, v) -> new KeyValue<>(k, v.toUpperCase())).to("ks1Out",
Produced.with(Serdes.Integer(), new JsonSerde<>()));
return stream;
}
By default, the streams managed by the StreamBuilder object it creates are started automatically.
You can customize this behaviour using the spring.kafka.streams.auto-startup property.
The properties supported by auto configuration are shown in Common Application properties. Note
that, for the most part, these properties (hyphenated or camelCase) map directly to the Apache
Kafka dotted properties. Refer to the Apache Kafka documentation for details.
The first few of these properties apply to all components (producers, consumers, admins, and
streams) but can be specified at the component level if you wish to use different values. Apache
Kafka designates properties with an importance of HIGH, MEDIUM, or LOW. Spring Boot auto-
configuration supports all HIGH importance properties, some selected MEDIUM and LOW
properties, and any properties that do not have a default value.
Only a subset of the properties supported by Kafka are available directly through the
KafkaProperties class. If you wish to configure the producer or consumer with additional properties
166
that are not directly supported, use the following properties:
spring.kafka.properties.prop.one=first
spring.kafka.admin.properties.prop.two=second
spring.kafka.consumer.properties.prop.three=third
spring.kafka.producer.properties.prop.four=fourth
spring.kafka.streams.properties.prop.five=fifth
This sets the common prop.one Kafka property to first (applies to producers, consumers and
admins), the prop.two admin property to second, the prop.three consumer property to third, the
prop.four producer property to fourth and the prop.five streams property to fifth.
spring.kafka.consumer.value-
deserializer=org.springframework.kafka.support.serializer.JsonDeserializer
spring.kafka.consumer.properties.spring.json.value.default.type=com.example.Invoice
spring.kafka.consumer.properties.spring.json.trusted.packages=com.example,org.acme
Similarly, you can disable the JsonSerializer default behavior of sending type information in
headers:
spring.kafka.producer.value-
serializer=org.springframework.kafka.support.serializer.JsonSerializer
spring.kafka.producer.properties.spring.json.add.type.headers=false
Properties set in this way override any configuration item that Spring Boot
explicitly supports.
Spring for Apache Kafka provides a convenient way to test projects with an embedded Apache
Kafka broker. To use this feature, annotate a test class with @EmbeddedKafka from the spring-kafka-
test module. For more information, please see the Spring for Apache Kafka reference manual.
To make Spring Boot auto-configuration work with the aforementioned embedded Apache Kafka
broker, you need to remap a system property for embedded broker addresses (populated by the
EmbeddedKafkaBroker) into the Spring Boot configuration property for Apache Kafka. There are
several ways to do that:
167
static {
System.setProperty(EmbeddedKafkaBroker.BROKER_LIST_PROPERTY,
"spring.kafka.bootstrap-servers");
}
@EmbeddedKafka(topics = "someTopic",
bootstrapServersProperty = "spring.kafka.bootstrap-servers")
spring.kafka.bootstrap-servers=${spring.embedded.kafka.brokers}
@Service
public class MyService {
168
5.15.1. RestTemplate Customization
There are three main approaches to RestTemplate customization, depending on how broadly you
want the customizations to apply.
To make the scope of any customizations as narrow as possible, inject the auto-configured
RestTemplateBuilder and then call its methods as required. Each method call returns a new
RestTemplateBuilder instance, so the customizations only affect this use of the builder.
The following example shows a customizer that configures the use of a proxy for all hosts except
192.168.0.5:
@Override
public void customize(RestTemplate restTemplate) {
HttpHost proxy = new HttpHost("proxy.example.com");
HttpClient httpClient = HttpClientBuilder.create().setRoutePlanner(new
DefaultProxyRoutePlanner(proxy) {
@Override
public HttpHost determineProxy(HttpHost target, HttpRequest request,
HttpContext context)
throws HttpException {
if (target.getHostName().equals("192.168.0.5")) {
return null;
}
return super.determineProxy(target, request, context);
}
}).build();
restTemplate.setRequestFactory(new
HttpComponentsClientHttpRequestFactory(httpClient));
}
Finally, the most extreme (and rarely used) option is to create your own RestTemplateBuilder bean.
Doing so switches off the auto-configuration of a RestTemplateBuilder and prevents any
RestTemplateCustomizer beans from being used.
169
You can learn more about the WebClient in the dedicated section in the Spring Framework docs.
Spring Boot creates and pre-configures a WebClient.Builder for you; it is strongly advised to inject it
in your components and use it to create WebClient instances. Spring Boot is configuring that builder
to share HTTP resources, reflect codecs setup in the same fashion as the server ones (see WebFlux
HTTP codecs auto-configuration), and more.
@Service
public class MyService {
Spring Boot will auto-detect which ClientHttpConnector to use to drive WebClient, depending on the
libraries available on the application classpath. For now, Reactor Netty and Jetty RS client are
supported.
Developers can override the resource configuration for Jetty and Reactor Netty by providing a
custom ReactorResourceFactory or JettyResourceFactory bean - this will be applied to both clients
and servers.
If you wish to override that choice for the client, you can define your own ClientHttpConnector bean
and have full control over the client configuration.
You can learn more about the WebClient configuration options in the Spring Framework reference
documentation.
170
5.16.2. WebClient Customization
There are three main approaches to WebClient customization, depending on how broadly you want
the customizations to apply.
To make the scope of any customizations as narrow as possible, inject the auto-configured
WebClient.Builder and then call its methods as required. WebClient.Builder instances are stateful:
Any change on the builder is reflected in all clients subsequently created with it. If you want to
create several clients with the same builder, you can also consider cloning the builder with
WebClient.Builder other = builder.clone();.
Finally, you can fall back to the original API and use WebClient.create(). In that case, no auto-
configuration or WebClientCustomizer is applied.
5.17. Validation
The method validation feature supported by Bean Validation 1.1 is automatically enabled as long as
a JSR-303 implementation (such as Hibernate validator) is on the classpath. This lets bean methods
be annotated with javax.validation constraints on their parameters and/or on their return value.
Target classes with such annotated methods need to be annotated with the @Validated annotation at
the type level for their methods to be searched for inline constraint annotations.
For instance, the following service triggers the validation of the first argument, making sure its size
is between 8 and 10:
@Service
@Validated
public class MyBean {
See the reference documentation for a detailed explanation of how you can use
JavaMailSender.
171
If spring.mail.host and the relevant libraries (as defined by spring-boot-starter-mail) are
available, a default JavaMailSender is created if none exists. The sender can be further customized
by configuration items from the spring.mail namespace. See MailProperties for more details.
In particular, certain default timeout values are infinite, and you may want to change that to avoid
having a thread blocked by an unresponsive mail server, as shown in the following example:
spring.mail.properties.mail.smtp.connectiontimeout=5000
spring.mail.properties.mail.smtp.timeout=3000
spring.mail.properties.mail.smtp.writetimeout=5000
spring.mail.jndi-name=mail/Session
When a jndi-name is set, it takes precedence over all other Session-related settings.
Atomikos is a popular open source transaction manager which can be embedded into your Spring
Boot application. You can use the spring-boot-starter-jta-atomikos starter to pull in the
appropriate Atomikos libraries. Spring Boot auto-configures Atomikos and ensures that appropriate
depends-on settings are applied to your Spring beans for correct startup and shutdown ordering.
172
To ensure that multiple transaction managers can safely coordinate the same
resource managers, each Atomikos instance must be configured with a unique ID.
By default, this ID is the IP address of the machine on which Atomikos is running.
To ensure uniqueness in production, you should configure the
spring.jta.transaction-manager-id property with a different value for each
instance of your application.
As of Spring Boot 2.3, support for Bitronix has been deprecated and will be
removed in a future release.
You can use the spring-boot-starter-jta-bitronix starter to add the appropriate Bitronix
dependencies to your project. As with Atomikos, Spring Boot automatically configures Bitronix and
post-processes your beans to ensure that startup and shutdown ordering is correct.
By default, Bitronix transaction log files (part1.btm and part2.btm) are written to a transaction-logs
directory in your application home directory. You can customize the location of this directory by
setting the spring.jta.log-dir property. Properties starting with spring.jta.bitronix.properties are
also bound to the bitronix.tm.Configuration bean, allowing for complete customization. See the
Bitronix documentation for details.
To ensure that multiple transaction managers can safely coordinate the same
resource managers, each Bitronix instance must be configured with a unique ID.
By default, this ID is the IP address of the machine on which Bitronix is running.
To ensure uniqueness in production, you should configure the
spring.jta.transaction-manager-id property with a different value for each
instance of your application.
If you package your Spring Boot application as a war or ear file and deploy it to a Java EE application
server, you can use your application server’s built-in transaction manager. Spring Boot tries to
auto-configure a transaction manager by looking at common JNDI locations
(java:comp/UserTransaction, java:comp/TransactionManager, and so on). If you use a transaction
service provided by your application server, you generally also want to ensure that all resources
are managed by the server and exposed over JNDI. Spring Boot tries to auto-configure JMS by
looking for a ConnectionFactory at the JNDI path (java:/JmsXA or java:/XAConnectionFactory), and
you can use the spring.datasource.jndi-name property to configure your DataSource.
When using JTA, the primary JMS ConnectionFactory bean is XA-aware and participates in
distributed transactions. In some situations, you might want to process certain JMS messages by
using a non-XA ConnectionFactory. For example, your JMS processing logic might take longer than
the XA timeout.
173
If you want to use a non-XA ConnectionFactory, you can inject the nonXaJmsConnectionFactory bean
rather than the @Primary jmsConnectionFactory bean. For consistency, the jmsConnectionFactory bean
is also provided by using the bean alias xaJmsConnectionFactory.
// Inject the XA aware ConnectionFactory (uses the alias and injects the same as
above)
@Autowired
@Qualifier("xaJmsConnectionFactory")
private ConnectionFactory xaConnectionFactory;
5.20. Hazelcast
If Hazelcast is on the classpath and a suitable configuration is found, Spring Boot auto-configures a
HazelcastInstance that you can inject in your application.
If you define a com.hazelcast.config.Config bean, Spring Boot uses that. If your configuration
defines an instance name, Spring Boot tries to locate an existing instance rather than creating a
new one.
You could also specify the Hazelcast configuration file to use through configuration, as shown in the
following example:
spring.hazelcast.config=classpath:config/my-hazelcast.xml
174
Otherwise, Spring Boot tries to find the Hazelcast configuration from the default locations:
hazelcast.xml in the working directory or at the root of the classpath, or a .yaml counterpart in the
same locations. We also check if the hazelcast.config system property is set. See the Hazelcast
documentation for more details.
If hazelcast-client is present on the classpath, Spring Boot first attempts to create a client by
checking the following configuration options:
Spring Boot also has explicit caching support for Hazelcast. If caching is enabled,
the HazelcastInstance is automatically wrapped in a CacheManager implementation.
Beans of the following types are automatically picked up and associated with the Scheduler:
• JobDetail: defines a particular Job. JobDetail instances can be built with the JobBuilder API.
• Calendar.
spring.quartz.job-store-type=jdbc
When the JDBC store is used, the schema can be initialized on startup, as shown in the following
example:
spring.quartz.jdbc.initialize-schema=always
By default, the database is detected and initialized by using the standard scripts
provided with the Quartz library. These scripts drop existing tables, deleting all
triggers on every restart. It is also possible to provide a custom script by setting the
spring.quartz.jdbc.schema property.
175
To have Quartz use a DataSource other than the application’s main DataSource, declare a DataSource
bean, annotating its @Bean method with @QuartzDataSource. Doing so ensures that the Quartz-specific
DataSource is used by both the SchedulerFactoryBean and for schema initialization. Similarly, to have
Quartz use a TransactionManager other than the application’s main TransactionManager declare a
TransactionManager bean, annotating its @Bean method with @QuartzTransactionManager.
By default, jobs created by configuration will not overwrite already registered jobs that have been
read from a persistent job store. To enable overwriting existing job definitions set the
spring.quartz.overwrite-existing-jobs property.
Jobs can define setters to inject data map properties. Regular beans can also be injected in a similar
manner, as shown in the following example:
@Override
protected void executeInternal(JobExecutionContext context)
throws JobExecutionException {
...
}
176
If you have defined a custom Executor in the context, regular task execution (i.e.
@EnableAsync) will use it transparently but the Spring MVC support will not be
configured as it requires an AsyncTaskExecutor implementation (named
applicationTaskExecutor). Depending on your target arrangement, you could
change your Executor into a ThreadPoolTaskExecutor or define both a
ThreadPoolTaskExecutor and an AsyncConfigurer wrapping your custom Executor.
The thread pool uses 8 core threads that can grow and shrink according to the load. Those default
settings can be fine-tuned using the spring.task.execution namespace as shown in the following
example:
spring.task.execution.pool.max-size=16
spring.task.execution.pool.queue-capacity=100
spring.task.execution.pool.keep-alive=10s
This changes the thread pool to use a bounded queue so that when the queue is full (100 tasks), the
thread pool increases to maximum 16 threads. Shrinking of the pool is more aggressive as threads
are reclaimed when they are idle for 10 seconds (rather than 60 seconds by default).
Both a TaskExecutorBuilder bean and a TaskSchedulerBuilder bean are made available in the context
if a custom executor or scheduler needs to be created.
Spring Boot also configures some features that are triggered by the presence of additional Spring
Integration modules. If spring-integration-jmx is also on the classpath, message processing
statistics are published over JMX. If spring-integration-jdbc is available, the default database
schema can be created on startup, as shown in the following line:
spring.integration.jdbc.initialize-schema=always
177
handle Spring Integration RSocket channel adapters and @MessageMapping handlers (given
"spring.integration.rsocket.server.message-mapping-enabled" is configured).
• JDBC
• Redis
• Hazelcast
• MongoDB
When building a reactive web application, the following stores can be auto-configured:
• Redis
• MongoDB
If a single Spring Session module is present on the classpath, Spring Boot uses that store
implementation automatically. If you have more than one implementation, you must choose the
StoreType that you wish to use to store the sessions. For instance, to use JDBC as the back-end store,
you can configure your application as follows:
spring.session.store-type=jdbc
178
Each store has specific additional settings. For instance, it is possible to customize the name of the
table for the JDBC store, as shown in the following example:
spring.session.jdbc.table-name=SESSIONS
For setting the timeout of the session you can use the spring.session.timeout property. If that
property is not set, the auto-configuration falls back to the value of server.servlet.session.timeout.
You can take control over Spring Session’s configuration using @Enable*HttpSession (Servlet) or
@Enable*WebSession (Reactive). This will cause the auto-configuration to back off. Spring Session can
then be configured using the annotation’s attributes rather than the previously described
configuration properties.
If your platform provides a standard MBeanServer, Spring Boot will use that and default to the VM
MBeanServer if necessary. If all that fails, a new MBeanServer will be created.
5.26. Testing
Spring Boot provides a number of utilities and annotations to help when testing your application.
Test support is provided by two modules: spring-boot-test contains core items, and spring-boot-
test-autoconfigure supports auto-configuration for tests.
Most developers use the spring-boot-starter-test “Starter”, which imports both Spring Boot test
modules as well as JUnit Jupiter, AssertJ, Hamcrest, and a number of other useful libraries.
179
The starter also brings the vintage engine so that you can run both JUnit 4 and
JUnit 5 tests. If you have migrated your tests to JUnit 5, you should exclude JUnit 4
support, as shown in the following example:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
The spring-boot-starter-test “Starter” (in the test scope) contains the following provided libraries:
• JUnit 5 (including the vintage engine for backward compatibility with JUnit 4): The de-facto
standard for unit testing Java applications.
• Spring Test & Spring Boot Test: Utilities and integration test support for Spring Boot
applications.
We generally find these common libraries to be useful when writing tests. If these libraries do not
suit your needs, you can add additional test dependencies of your own.
One of the major advantages of dependency injection is that it should make your code easier to unit
test. You can instantiate objects by using the new operator without even involving Spring. You can
also use mock objects instead of real dependencies.
Often, you need to move beyond unit testing and start integration testing (with a Spring
ApplicationContext). It is useful to be able to perform integration testing without requiring
deployment of your application or needing to connect to other infrastructure.
The Spring Framework includes a dedicated test module for such integration testing. You can
declare a dependency directly to org.springframework:spring-test or use the spring-boot-starter-
test “Starter” to pull it in transitively.
180
If you have not used the spring-test module before, you should start by reading the relevant
section of the Spring Framework reference documentation.
A Spring Boot application is a Spring ApplicationContext, so nothing very special has to be done to
test it beyond what you would normally do with a vanilla Spring context.
External properties, logging, and other features of Spring Boot are installed in the
context by default only if you use SpringApplication to create it.
Spring Boot provides a @SpringBootTest annotation, which can be used as an alternative to the
standard spring-test @ContextConfiguration annotation when you need Spring Boot features. The
annotation works by creating the ApplicationContext used in your tests through SpringApplication.
In addition to @SpringBootTest a number of other annotations are also provided for testing more
specific slices of an application.
By default, @SpringBootTest will not start a server. You can use the webEnvironment attribute of
@SpringBootTest to further refine how your tests run:
• NONE: Loads an ApplicationContext by using SpringApplication but does not provide any web
environment (mock or otherwise).
If your test is @Transactional, it rolls back the transaction at the end of each test
method by default. However, as using this arrangement with either RANDOM_PORT or
DEFINED_PORT implicitly provides a real servlet environment, the HTTP client and
server run in separate threads and, thus, in separate transactions. Any transaction
initiated on the server does not roll back in this case.
181
@SpringBootTest with webEnvironment = WebEnvironment.RANDOM_PORT will also start
the management server on a separate random port if your application uses a
different port for the management server.
If Spring MVC is available, a regular MVC-based application context is configured. If you have only
Spring WebFlux, we’ll detect that and configure a WebFlux-based application context instead.
If both are present, Spring MVC takes precedence. If you want to test a reactive web application in
this scenario, you must set the spring.main.web-application-type property:
@SpringBootTest(properties = "spring.main.web-application-type=reactive")
class MyWebFluxTests { ... }
If you are familiar with the Spring Test Framework, you may be used to using
@ContextConfiguration(classes=…) in order to specify which Spring @Configuration to load.
Alternatively, you might have often used nested @Configuration classes within your test.
When testing Spring Boot applications, this is often not required. Spring Boot’s @*Test annotations
search for your primary configuration automatically whenever you do not explicitly define one.
The search algorithm works up from the package that contains the test until it finds a class
annotated with @SpringBootApplication or @SpringBootConfiguration. As long as you structured your
code in a sensible way, your main configuration is usually found.
If you use a test annotation to test a more specific slice of your application, you
should avoid adding configuration settings that are specific to a particular area on
the main method’s application class.
If you want to customize the primary configuration, you can use a nested @TestConfiguration class.
Unlike a nested @Configuration class, which would be used instead of your application’s primary
configuration, a nested @TestConfiguration class is used in addition to your application’s primary
configuration.
182
Excluding Test Configuration
If your application uses component scanning (for example, if you use @SpringBootApplication or
@ComponentScan), you may find top-level configuration classes that you created only for specific tests
accidentally get picked up everywhere.
As we have seen earlier, @TestConfiguration can be used on an inner class of a test to customize the
primary configuration. When placed on a top-level class, @TestConfiguration indicates that classes
in src/test/java should not be picked up by scanning. You can then import that class explicitly
where it is required, as shown in the following example:
@SpringBootTest
@Import(MyTestsConfiguration.class)
class MyTests {
@Test
void exampleTest() {
...
}
If you directly use @ComponentScan (that is, not through @SpringBootApplication) you
need to register the TypeExcludeFilter with it. See the Javadoc for details.
If your application expects arguments, you can have @SpringBootTest inject them using the args
attribute.
@SpringBootTest(args = "--app.test=one")
class ApplicationArgumentsExampleTests {
@Test
void applicationArgumentsPopulated(@Autowired ApplicationArguments args) {
assertThat(args.getOptionNames()).containsOnly("app.test");
assertThat(args.getOptionValues("app.test")).containsOnly("one");
}
By default, @SpringBootTest does not start the server. If you have web endpoints that you want to
test against this mock environment, you can additionally configure MockMvc as shown in the
following example:
183
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.web.servlet.MockMvc;
@SpringBootTest
@AutoConfigureMockMvc
class MockMvcExampleTests {
@Test
void exampleTest(@Autowired MockMvc mvc) throws Exception {
mvc.perform(get("/")).andExpect(status().isOk()).andExpect(content().string("Hello
World"));
}
If you want to focus only on the web layer and not start a complete
ApplicationContext, consider using @WebMvcTest instead.
184
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import
org.springframework.boot.test.autoconfigure.web.reactive.AutoConfigureWebTestClient;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.web.reactive.server.WebTestClient;
@SpringBootTest
@AutoConfigureWebTestClient
class MockWebTestClientExampleTests {
@Test
void exampleTest(@Autowired WebTestClient webClient) {
webClient.get().uri("/").exchange().expectStatus().isOk().expectBody(String.class).isE
qualTo("Hello World");
}
Testing within a mocked environment is usually faster than running with a full
Servlet container. However, since mocking occurs at the Spring MVC layer, code
that relies on lower-level Servlet container behavior cannot be directly tested with
MockMvc.
For example, Spring Boot’s error handling is based on the “error page” support
provided by the Servlet container. This means that, whilst you can test your MVC
layer throws and handles exceptions as expected, you cannot directly test that a
specific custom error page is rendered. If you need to test these lower-level
concerns, you can start a fully running server as described in the next section.
If you need to start a full running server, we recommend that you use random ports. If you use
@SpringBootTest(webEnvironment=WebEnvironment.RANDOM_PORT), an available port is picked at random
each time your test runs.
The @LocalServerPort annotation can be used to inject the actual port used into your test. For
convenience, tests that need to make REST calls to the started server can additionally @Autowire a
WebTestClient, which resolves relative links to the running server and comes with a dedicated API
for verifying responses, as shown in the following example:
185
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.context.SpringBootTest.WebEnvironment;
import org.springframework.test.web.reactive.server.WebTestClient;
@SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT)
class RandomPortWebTestClientExampleTests {
@Test
void exampleTest(@Autowired WebTestClient webClient) {
webClient.get().uri("/").exchange().expectStatus().isOk().expectBody(String.class).isE
qualTo("Hello World");
}
This setup requires spring-webflux on the classpath. If you can’t or won’t add webflux, Spring Boot
also provides a TestRestTemplate facility:
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.context.SpringBootTest.WebEnvironment;
import org.springframework.boot.test.web.client.TestRestTemplate;
@SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT)
class RandomPortTestRestTemplateExampleTests {
@Test
void exampleTest(@Autowired TestRestTemplate restTemplate) {
String body = restTemplate.getForObject("/", String.class);
assertThat(body).isEqualTo("Hello World");
}
Customizing WebTestClient
186
Using JMX
As the test context framework caches context, JMX is disabled by default to prevent identical
components to register on the same domain. If such test needs access to an MBeanServer, consider
marking it dirty as well:
@ExtendWith(SpringExtension.class)
@SpringBootTest(properties = "spring.jmx.enabled=true")
@DirtiesContext
class SampleJmxTests {
@Autowired
private MBeanServer mBeanServer;
@Test
void exampleTest() {
// ...
}
When running tests, it is sometimes necessary to mock certain components within your application
context. For example, you may have a facade over some remote service that is unavailable during
development. Mocking can also be useful when you want to simulate failures that might be hard to
trigger in a real environment.
Spring Boot includes a @MockBean annotation that can be used to define a Mockito mock for a bean
inside your ApplicationContext. You can use the annotation to add new beans or replace a single
existing bean definition. The annotation can be used directly on test classes, on fields within your
test, or on @Configuration classes and fields. When used on a field, the instance of the created mock
is also injected. Mock beans are automatically reset after each test method.
If your test uses one of Spring Boot’s test annotations (such as @SpringBootTest),
this feature is automatically enabled. To use this feature with a different
arrangement, listeners must be explicitly added, as shown in the following
example:
@TestExecutionListeners({ MockitoTestExecutionListener.class,
ResetMocksTestExecutionListener.class })
The following example replaces an existing RemoteService bean with a mock implementation:
187
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.*;
import org.springframework.boot.test.context.*;
import org.springframework.boot.test.mock.mockito.*;
@SpringBootTest
class MyTests {
@MockBean
private RemoteService remoteService;
@Autowired
private Reverser reverser;
@Test
void exampleTest() {
// RemoteService has been injected into the reverser bean
given(this.remoteService.someCall()).willReturn("mock");
String reverse = reverser.reverseSomeCall();
assertThat(reverse).isEqualTo("kcom");
}
@MockBean cannot be used to mock the behavior of a bean that’s exercised during
application context refresh. By the time the test is executed, the application
context refresh has completed and it is too late to configure the mocked behavior.
We recommend using a @Bean method to create and configure the mock in this
situation.
Additionally, you can use @SpyBean to wrap any existing bean with a Mockito spy. See the Javadoc for
full details.
CGLib proxies, such as those created for scoped beans, declare the proxied
methods as final. This stops Mockito from functioning correctly as it cannot mock
or spy on final methods in its default configuration. If you want to mock or spy on
such a bean, configure Mockito to use its inline mock maker by adding
org.mockito:mockito-inline to your application’s test dependencies. This allows
Mockito to mock and spy on final methods.
While Spring’s test framework caches application contexts between tests and
reuses a context for tests sharing the same configuration, the use of @MockBean or
@SpyBean influences the cache key, which will most likely increase the number of
contexts.
188
If you are using @SpyBean to spy on a bean with @Cacheable methods that refer to
parameters by name, your application must be compiled with -parameters. This
ensures that the parameter names are available to the caching infrastructure once
the bean has been spied upon.
When you are using @SpyBean to spy on a bean that is proxied by Spring, you may
need to remove Spring’s proxy in some situations, for example when setting
expectations using given or when. Use
AopTestUtils.getTargetObject(yourProxiedSpy) to do so.
Auto-configured Tests
Spring Boot’s auto-configuration system works well for applications but can sometimes be a little
too much for tests. It often helps to load only the parts of the configuration that are required to test
a “slice” of your application. For example, you might want to test that Spring MVC controllers are
mapping URLs correctly, and you do not want to involve database calls in those tests, or you might
want to test JPA entities, and you are not interested in the web layer when those tests run.
Each slice restricts component scan to appropriate components and loads a very
restricted set of auto-configuration classes. If you need to exclude one of them,
most @…Test annotations provide an excludeAutoConfiguration attribute.
Alternatively, you can use @ImportAutoConfiguration#exclude.
Including multiple “slices” by using several @…Test annotations in one test is not
supported. If you need multiple “slices”, pick one of the @…Test annotations and
include the @AutoConfigure… annotations of the other “slices” by hand.
To test that object JSON serialization and deserialization is working as expected, you can use the
@JsonTest annotation. @JsonTest auto-configures the available supported JSON mapper, which can
be one of the following libraries:
• Gson
• Jsonb
189
A list of the auto-configurations that are enabled by @JsonTest can be found in the
appendix.
If you need to configure elements of the auto-configuration, you can use the
@AutoConfigureJsonTesters annotation.
Spring Boot includes AssertJ-based helpers that work with the JSONAssert and JsonPath libraries to
check that JSON appears as expected. The JacksonTester, GsonTester, JsonbTester, and
BasicJsonTester classes can be used for Jackson, Gson, Jsonb, and Strings respectively. Any helper
fields on the test class can be @Autowired when using @JsonTest. The following example shows a test
class for Jackson:
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.*;
import org.springframework.boot.test.autoconfigure.json.*;
import org.springframework.boot.test.context.*;
import org.springframework.boot.test.json.*;
@JsonTest
class MyJsonTests {
@Autowired
private JacksonTester<VehicleDetails> json;
@Test
void testSerialize() throws Exception {
VehicleDetails details = new VehicleDetails("Honda", "Civic");
// Assert against a `.json` file in the same package as the test
assertThat(this.json.write(details)).isEqualToJson("expected.json");
// Or use JSON path based assertions
assertThat(this.json.write(details)).hasJsonPathStringValue("@.make");
assertThat(this.json.write(details)).extractingJsonPathStringValue("@.make")
.isEqualTo("Honda");
}
@Test
void testDeserialize() throws Exception {
String content = "{\"make\":\"Ford\",\"model\":\"Focus\"}";
assertThat(this.json.parse(content))
.isEqualTo(new VehicleDetails("Ford", "Focus"));
assertThat(this.json.parseObject(content).getMake()).isEqualTo("Ford");
}
190
JSON helper classes can also be used directly in standard unit tests. To do so, call
the initFields method of the helper in your @Before method if you do not use
@JsonTest.
If you’re using Spring Boot’s AssertJ-based helpers to assert on a number value at a given JSON
path, you might not be able to use isEqualTo depending on the type. Instead, you can use AssertJ’s
satisfies to assert that the value matches the given condition. For instance, the following example
asserts that the actual number is a float value close to 0.15 within an offset of 0.01.
assertThat(json.write(message))
.extractingJsonPathNumberValue("@.test.numberValue")
.satisfies((number) -> assertThat(number.floatValue()).isCloseTo(0.15f,
within(0.01f)));
To test whether Spring MVC controllers are working as expected, use the @WebMvcTest annotation.
@WebMvcTest auto-configures the Spring MVC infrastructure and limits scanned beans to @Controller,
@ControllerAdvice, @JsonComponent, Converter, GenericConverter, Filter, HandlerInterceptor,
WebMvcConfigurer, and HandlerMethodArgumentResolver. Regular @Component and
@ConfigurationProperties beans are not scanned when the @WebMvcTest annotation is used.
@EnableConfigurationProperties can be used to include @ConfigurationProperties beans.
If you need to register extra components, such as the Jackson Module, you can
import additional configuration classes by using @Import on your test.
Often, @WebMvcTest is limited to a single controller and is used in combination with @MockBean to
provide mock implementations for required collaborators.
@WebMvcTest also auto-configures MockMvc. Mock MVC offers a powerful way to quickly test MVC
controllers without needing to start a full HTTP server.
191
import org.junit.jupiter.api.*;
import org.springframework.beans.factory.annotation.*;
import org.springframework.boot.test.autoconfigure.web.servlet.*;
import org.springframework.boot.test.mock.mockito.*;
@WebMvcTest(UserVehicleController.class)
class MyControllerTests {
@Autowired
private MockMvc mvc;
@MockBean
private UserVehicleService userVehicleService;
@Test
void testExample() throws Exception {
given(this.userVehicleService.getVehicleDetails("sboot"))
.willReturn(new VehicleDetails("Honda", "Civic"));
this.mvc.perform(get("/sboot/vehicle").accept(MediaType.TEXT_PLAIN))
.andExpect(status().isOk()).andExpect(content().string("Honda
Civic"));
}
If you use HtmlUnit or Selenium, auto-configuration also provides an HtmlUnit WebClient bean
and/or a Selenium WebDriver bean. The following example uses HtmlUnit:
192
import com.gargoylesoftware.htmlunit.*;
import org.junit.jupiter.api.*;
import org.springframework.beans.factory.annotation.*;
import org.springframework.boot.test.autoconfigure.web.servlet.*;
import org.springframework.boot.test.mock.mockito.*;
@WebMvcTest(UserVehicleController.class)
class MyHtmlUnitTests {
@Autowired
private WebClient webClient;
@MockBean
private UserVehicleService userVehicleService;
@Test
void testExample() throws Exception {
given(this.userVehicleService.getVehicleDetails("sboot"))
.willReturn(new VehicleDetails("Honda", "Civic"));
HtmlPage page = this.webClient.getPage("/sboot/vehicle.html");
assertThat(page.getBody().getTextContent()).isEqualTo("Honda Civic");
}
By default, Spring Boot puts WebDriver beans in a special “scope” to ensure that the
driver exits after each test and that a new instance is injected. If you do not want
this behavior, you can add @Scope("singleton") to your WebDriver @Bean definition.
The webDriver scope created by Spring Boot will replace any user defined scope of
the same name. If you define your own webDriver scope you may find it stops
working when you use @WebMvcTest.
If you have Spring Security on the classpath, @WebMvcTest will also scan WebSecurityConfigurer
beans. Instead of disabling security completely for such tests, you can use Spring Security’s test
support. More details on how to use Spring Security’s MockMvc support can be found in this Testing
With Spring Security how-to section.
Sometimes writing Spring MVC tests is not enough; Spring Boot can help you run
full end-to-end tests with an actual server.
To test that Spring WebFlux controllers are working as expected, you can use the @WebFluxTest
annotation. @WebFluxTest auto-configures the Spring WebFlux infrastructure and limits scanned
193
beans to @Controller, @ControllerAdvice, @JsonComponent, Converter, GenericConverter, WebFilter, and
WebFluxConfigurer. Regular @Component and @ConfigurationProperties beans are not scanned when
the @WebFluxTest annotation is used. @EnableConfigurationProperties can be used to include
@ConfigurationProperties beans.
If you need to register extra components, such as Jackson Module, you can import
additional configuration classes using @Import on your test.
Often, @WebFluxTest is limited to a single controller and used in combination with the @MockBean
annotation to provide mock implementations for required collaborators.
@WebFluxTest also auto-configures WebTestClient, which offers a powerful way to quickly test
WebFlux controllers without needing to start a full HTTP server.
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest;
import org.springframework.http.MediaType;
import org.springframework.test.web.reactive.server.WebTestClient;
@WebFluxTest(UserVehicleController.class)
class MyControllerTests {
@Autowired
private WebTestClient webClient;
@MockBean
private UserVehicleService userVehicleService;
@Test
void testExample() throws Exception {
given(this.userVehicleService.getVehicleDetails("sboot"))
.willReturn(new VehicleDetails("Honda", "Civic"));
this.webClient.get().uri("/sboot/vehicle").accept(MediaType.TEXT_PLAIN)
.exchange()
.expectStatus().isOk()
.expectBody(String.class).isEqualTo("Honda Civic");
}
194
This setup is only supported by WebFlux applications as using WebTestClient in a
mocked web application only works with WebFlux at the moment.
@WebFluxTest cannot detect routes registered via the functional web framework.
For testing RouterFunction beans in the context, consider importing your
RouterFunction yourself via @Import or using @SpringBootTest.
Sometimes writing Spring WebFlux tests is not enough; Spring Boot can help you
run full end-to-end tests with an actual server.
You can use the @DataJpaTest annotation to test JPA applications. By default, it scans for @Entity
classes and configures Spring Data JPA repositories. If an embedded database is available on the
classpath, it configures one as well. SQL queries are logged by default by setting the
spring.jpa.show-sql property to true. This can be disabled using the showSql() attribute of the
annotation.
Regular @Component and @ConfigurationProperties beans are not scanned when the @DataJpaTest
annotation is used. @EnableConfigurationProperties can be used to include @ConfigurationProperties
beans.
By default, data JPA tests are transactional and roll back at the end of each test. See the relevant
section in the Spring Framework Reference Documentation for more details. If that is not what you
want, you can disable transaction management for a test or for the whole class as follows:
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
@DataJpaTest
@Transactional(propagation = Propagation.NOT_SUPPORTED)
class ExampleNonTransactionalTests {
Data JPA tests may also inject a TestEntityManager bean, which provides an alternative to the
standard JPA EntityManager that is specifically designed for tests. If you want to use
TestEntityManager outside of @DataJpaTest instances, you can also use the
195
@AutoConfigureTestEntityManager annotation. A JdbcTemplate is also available if you need that. The
following example shows the @DataJpaTest annotation in use:
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.autoconfigure.orm.jpa.*;
@DataJpaTest
class ExampleRepositoryTests {
@Autowired
private TestEntityManager entityManager;
@Autowired
private UserRepository repository;
@Test
void testExample() throws Exception {
this.entityManager.persist(new User("sboot", "1234"));
User user = this.repository.findByUsername("sboot");
assertThat(user.getUsername()).isEqualTo("sboot");
assertThat(user.getVin()).isEqualTo("1234");
}
In-memory embedded databases generally work well for tests, since they are fast and do not
require any installation. If, however, you prefer to run tests against a real database you can use the
@AutoConfigureTestDatabase annotation, as shown in the following example:
@DataJpaTest
@AutoConfigureTestDatabase(replace=Replace.NONE)
class ExampleRepositoryTests {
// ...
@JdbcTest is similar to @DataJpaTest but is for tests that only require a DataSource and do not use
Spring Data JDBC. By default, it configures an in-memory embedded database and a JdbcTemplate.
Regular @Component and @ConfigurationProperties beans are not scanned when the @JdbcTest
annotation is used. @EnableConfigurationProperties can be used to include @ConfigurationProperties
beans.
196
A list of the auto-configurations that are enabled by @JdbcTest can be found in the
appendix.
By default, JDBC tests are transactional and roll back at the end of each test. See the relevant section
in the Spring Framework Reference Documentation for more details. If that is not what you want,
you can disable transaction management for a test or for the whole class, as follows:
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.autoconfigure.jdbc.JdbcTest;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
@JdbcTest
@Transactional(propagation = Propagation.NOT_SUPPORTED)
class ExampleNonTransactionalTests {
If you prefer your test to run against a real database, you can use the @AutoConfigureTestDatabase
annotation in the same way as for DataJpaTest. (See "Auto-configured Data JPA Tests".)
@DataJdbcTest is similar to @JdbcTest but is for tests that use Spring Data JDBC repositories. By
default, it configures an in-memory embedded database, a JdbcTemplate, and Spring Data JDBC
repositories. Regular @Component and @ConfigurationProperties beans are not scanned when the
@DataJdbcTest annotation is used. @EnableConfigurationProperties can be used to include
@ConfigurationProperties beans.
By default, Data JDBC tests are transactional and roll back at the end of each test. See the relevant
section in the Spring Framework Reference Documentation for more details. If that is not what you
want, you can disable transaction management for a test or for the whole test class as shown in the
JDBC example.
If you prefer your test to run against a real database, you can use the @AutoConfigureTestDatabase
annotation in the same way as for DataJpaTest. (See "Auto-configured Data JPA Tests".)
You can use @JooqTest in a similar fashion as @JdbcTest but for jOOQ-related tests. As jOOQ relies
heavily on a Java-based schema that corresponds with the database schema, the existing DataSource
is used. If you want to replace it with an in-memory database, you can use
@AutoConfigureTestDatabase to override those settings. (For more about using jOOQ with Spring
Boot, see "Using jOOQ", earlier in this chapter.) Regular @Component and @ConfigurationProperties
beans are not scanned when the @JooqTest annotation is used. @EnableConfigurationProperties can
197
be used to include @ConfigurationProperties beans.
A list of the auto-configurations that are enabled by @JooqTest can be found in the
appendix.
@JooqTest configures a DSLContext. The following example shows the @JooqTest annotation in use:
import org.jooq.DSLContext;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.autoconfigure.jooq.JooqTest;
@JooqTest
class ExampleJooqTests {
@Autowired
private DSLContext dslContext;
}
JOOQ tests are transactional and roll back at the end of each test by default. If that is not what you
want, you can disable transaction management for a test or for the whole test class as shown in the
JDBC example.
You can use @DataMongoTest to test MongoDB applications. By default, it configures an in-memory
embedded MongoDB (if available), configures a MongoTemplate, scans for @Document classes, and
configures Spring Data MongoDB repositories. Regular @Component and @ConfigurationProperties
beans are not scanned when the @DataMongoTest annotation is used. @EnableConfigurationProperties
can be used to include @ConfigurationProperties beans. (For more about using MongoDB with
Spring Boot, see "MongoDB", earlier in this chapter.)
198
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.data.mongo.DataMongoTest;
import org.springframework.data.mongodb.core.MongoTemplate;
@DataMongoTest
class ExampleDataMongoTests {
@Autowired
private MongoTemplate mongoTemplate;
//
}
In-memory embedded MongoDB generally works well for tests, since it is fast and does not require
any developer installation. If, however, you prefer to run tests against a real MongoDB server, you
should exclude the embedded MongoDB auto-configuration, as shown in the following example:
import
org.springframework.boot.autoconfigure.mongo.embedded.EmbeddedMongoAutoConfiguration;
import org.springframework.boot.test.autoconfigure.data.mongo.DataMongoTest;
@DataMongoTest(excludeAutoConfiguration = EmbeddedMongoAutoConfiguration.class)
class ExampleDataMongoNonEmbeddedTests {
You can use @DataNeo4jTest to test Neo4j applications. By default, it uses an in-memory embedded
Neo4j (if the embedded driver is available), scans for @NodeEntity classes, and configures Spring
Data Neo4j repositories. Regular @Component and @ConfigurationProperties beans are not scanned
when the @DataNeo4jTest annotation is used. @EnableConfigurationProperties can be used to include
@ConfigurationProperties beans. (For more about using Neo4J with Spring Boot, see "Neo4j", earlier
in this chapter.)
The following example shows a typical setup for using Neo4J tests in Spring Boot:
199
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.data.neo4j.DataNeo4jTest;
@DataNeo4jTest
class ExampleDataNeo4jTests {
@Autowired
private YourRepository repository;
//
}
By default, Data Neo4j tests are transactional and roll back at the end of each test. See the relevant
section in the Spring Framework Reference Documentation for more details. If that is not what you
want, you can disable transaction management for a test or for the whole class, as follows:
import org.springframework.boot.test.autoconfigure.data.neo4j.DataNeo4jTest;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
@DataNeo4jTest
@Transactional(propagation = Propagation.NOT_SUPPORTED)
class ExampleNonTransactionalTests {
You can use @DataRedisTest to test Redis applications. By default, it scans for @RedisHash classes and
configures Spring Data Redis repositories. Regular @Component and @ConfigurationProperties beans
are not scanned when the @DataRedisTest annotation is used. @EnableConfigurationProperties can be
used to include @ConfigurationProperties beans. (For more about using Redis with Spring Boot, see
"Redis", earlier in this chapter.)
200
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.data.redis.DataRedisTest;
@DataRedisTest
class ExampleDataRedisTests {
@Autowired
private YourRepository repository;
//
}
You can use @DataLdapTest to test LDAP applications. By default, it configures an in-memory
embedded LDAP (if available), configures an LdapTemplate, scans for @Entry classes, and configures
Spring Data LDAP repositories. Regular @Component and @ConfigurationProperties beans are not
scanned when the @DataLdapTest annotation is used. @EnableConfigurationProperties can be used to
include @ConfigurationProperties beans. (For more about using LDAP with Spring Boot, see "LDAP",
earlier in this chapter.)
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.data.ldap.DataLdapTest;
import org.springframework.ldap.core.LdapTemplate;
@DataLdapTest
class ExampleDataLdapTests {
@Autowired
private LdapTemplate ldapTemplate;
//
}
In-memory embedded LDAP generally works well for tests, since it is fast and does not require any
developer installation. If, however, you prefer to run tests against a real LDAP server, you should
exclude the embedded LDAP auto-configuration, as shown in the following example:
201
import
org.springframework.boot.autoconfigure.ldap.embedded.EmbeddedLdapAutoConfiguration;
import org.springframework.boot.test.autoconfigure.data.ldap.DataLdapTest;
@DataLdapTest(excludeAutoConfiguration = EmbeddedLdapAutoConfiguration.class)
class ExampleDataLdapNonEmbeddedTests {
You can use the @RestClientTest annotation to test REST clients. By default, it auto-configures
Jackson, GSON, and Jsonb support, configures a RestTemplateBuilder, and adds support for
MockRestServiceServer. Regular @Component and @ConfigurationProperties beans are not scanned
when the @RestClientTest annotation is used. @EnableConfigurationProperties can be used to
include @ConfigurationProperties beans.
The specific beans that you want to test should be specified by using the value or components
attribute of @RestClientTest, as shown in the following example:
@RestClientTest(RemoteVehicleDetailsService.class)
class ExampleRestClientTest {
@Autowired
private RemoteVehicleDetailsService service;
@Autowired
private MockRestServiceServer server;
@Test
void getVehicleDetailsWhenResultIsSuccessShouldReturnDetails()
throws Exception {
this.server.expect(requestTo("/greet/details"))
.andRespond(withSuccess("hello", MediaType.TEXT_PLAIN));
String greeting = this.service.callRestService();
assertThat(greeting).isEqualTo("hello");
}
You can use the @AutoConfigureRestDocs annotation to use Spring REST Docs in your tests with Mock
MVC, REST Assured, or WebTestClient. It removes the need for the JUnit extension in Spring REST
202
Docs.
@AutoConfigureRestDocs customizes the MockMvc bean to use Spring REST Docs when testing Servlet-
based web applications. You can inject it by using @Autowired and use it in your tests as you
normally would when using Mock MVC and Spring REST Docs, as shown in the following example:
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.web.servlet.WebMvcTest;
import org.springframework.http.MediaType;
import org.springframework.test.web.servlet.MockMvc;
@WebMvcTest(UserController.class)
@AutoConfigureRestDocs
class UserDocumentationTests {
@Autowired
private MockMvc mvc;
@Test
void listUsers() throws Exception {
this.mvc.perform(get("/users").accept(MediaType.TEXT_PLAIN))
.andExpect(status().isOk())
.andDo(document("list-users"));
}
If you require more control over Spring REST Docs configuration than offered by the attributes of
@AutoConfigureRestDocs, you can use a RestDocsMockMvcConfigurationCustomizer bean, as shown in
the following example:
203
@TestConfiguration
static class CustomizationConfiguration
implements RestDocsMockMvcConfigurationCustomizer {
@Override
public void customize(MockMvcRestDocumentationConfigurer configurer) {
configurer.snippets().withTemplateFormat(TemplateFormats.markdown());
}
If you want to make use of Spring REST Docs support for a parameterized output directory, you can
create a RestDocumentationResultHandler bean. The auto-configuration calls alwaysDo with this result
handler, thereby causing each MockMvc call to automatically generate the default snippets. The
following example shows a RestDocumentationResultHandler being defined:
@TestConfiguration(proxyBeanMethods = false)
static class ResultHandlerConfiguration {
@Bean
public RestDocumentationResultHandler restDocumentation() {
return MockMvcRestDocumentation.document("{method-name}");
}
@AutoConfigureRestDocs can also be used with WebTestClient when testing reactive web applications.
You can inject it by using @Autowired and use it in your tests as you normally would when using
@WebFluxTest and Spring REST Docs, as shown in the following example:
204
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.restdocs.AutoConfigureRestDocs;
import org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest;
import org.springframework.test.web.reactive.server.WebTestClient;
import static
org.springframework.restdocs.webtestclient.WebTestClientRestDocumentation.document;
@WebFluxTest
@AutoConfigureRestDocs
class UsersDocumentationTests {
@Autowired
private WebTestClient webTestClient;
@Test
void listUsers() {
this.webTestClient.get().uri("/").exchange().expectStatus().isOk().expectBody()
.consumeWith(document("list-users"));
}
If you require more control over Spring REST Docs configuration than offered by the attributes of
@AutoConfigureRestDocs, you can use a RestDocsWebTestClientConfigurationCustomizer bean, as
shown in the following example:
@TestConfiguration(proxyBeanMethods = false)
public static class CustomizationConfiguration implements
RestDocsWebTestClientConfigurationCustomizer {
@Override
public void customize(WebTestClientRestDocumentationConfigurer configurer) {
configurer.snippets().withEncoding("UTF-8");
}
205
import io.restassured.specification.RequestSpecification;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.restdocs.AutoConfigureRestDocs;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.context.SpringBootTest.WebEnvironment;
import org.springframework.boot.web.server.LocalServerPort;
@SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT)
@AutoConfigureRestDocs
class UserDocumentationTests {
@Test
void listUsers(@Autowired RequestSpecification documentationSpec, @LocalServerPort
int port) {
given(documentationSpec).filter(document("list-
users")).when().port(port).get("/").then().assertThat()
.statusCode(is(200));
}
If you require more control over Spring REST Docs configuration than offered by the attributes of
@AutoConfigureRestDocs, a RestDocsRestAssuredConfigurationCustomizer bean can be used, as shown
in the following example:
@TestConfiguration(proxyBeanMethods = false)
public static class CustomizationConfiguration implements
RestDocsRestAssuredConfigurationCustomizer {
@Override
public void customize(RestAssuredRestDocumentationConfigurer configurer) {
configurer.snippets().withTemplateFormat(TemplateFormats.markdown());
}
You can use @WebServiceClientTest to test applications that use call web services using the Spring
Web Services project. By default, it configures a mock WebServiceServer bean and automatically
customizes your WebServiceTemplateBuilder. (For more about using Web Services with Spring Boot,
206
see "Web Services", earlier in this chapter.)
@WebServiceClientTest(ExampleWebServiceClient.class)
class WebServiceClientIntegrationTests {
@Autowired
private MockWebServiceServer server;
@Autowired
private ExampleWebServiceClient client;
@Test
void mockServerCall() {
this.server.expect(payload(new StringSource("<request/>"))).andRespond(
withPayload(new
StringSource("<response><status>200</status></response>")));
assertThat(this.client.test()).extracting(Response::getStatus).isEqualTo(200);
}
Each slice provides one or more @AutoConfigure… annotations that namely defines the auto-
configurations that should be included as part of a slice. Additional auto-configurations can be
added on a test-by-test basis by creating a custom @AutoConfigure… annotation or by adding
@ImportAutoConfiguration to the test as shown in the following example:
@JdbcTest
@ImportAutoConfiguration(IntegrationAutoConfiguration.class)
class ExampleJdbcTests {
Make sure to not use the regular @Import annotation to import auto-configurations
as they are handled in a specific way by Spring Boot.
Alternatively, additional auto-configurations can be added for any use of a slice annotation by
registering them in META-INF/spring.factories as shown in the following example:
207
org.springframework.boot.test.autoconfigure.jdbc.JdbcTest=com.example.IntegrationAutoC
onfiguration
If you structure your code in a sensible way, your @SpringBootApplication class is used by default as
the configuration of your tests.
It then becomes important not to litter the application’s main class with configuration settings that
are specific to a particular area of its functionality.
Assume that you are using Spring Batch and you rely on the auto-configuration for it. You could
define your @SpringBootApplication as follows:
@SpringBootApplication
@EnableBatchProcessing
public class SampleApplication { ... }
Because this class is the source configuration for the test, any slice test actually tries to start Spring
Batch, which is definitely not what you want to do. A recommended approach is to move that area-
specific configuration to a separate @Configuration class at the same level as your application, as
shown in the following example:
@Configuration(proxyBeanMethods = false)
@EnableBatchProcessing
public class BatchConfiguration { ... }
Depending on the complexity of your application, you may either have a single
@Configuration class for your customizations or one class per domain area. The
latter approach lets you enable it in one of your tests, if necessary, with the @Import
annotation.
Test slices exclude @Configuration classes from scanning. For example, for a @WebMvcTest, the
following configuration will not include the given WebMvcConfigurer bean in the application context
loaded by the test slice:
208
@Configuration
public class WebConfiguration {
@Bean
public WebMvcConfigurer testConfigurer() {
return new WebMvcConfigurer() {
...
};
}
}
The configuration below will, however, cause the custom WebMvcConfigurer to be loaded by the test
slice.
@Component
public class TestWebMvcConfigurer implements WebMvcConfigurer {
...
}
Another source of confusion is classpath scanning. Assume that, while you structured your code in
a sensible way, you need to scan an additional package. Your application may resemble the
following code:
@SpringBootApplication
@ComponentScan({ "com.example.app", "org.acme.another" })
public class SampleApplication { ... }
Doing so effectively overrides the default component scan directive with the side effect of scanning
those two packages regardless of the slice that you chose. For instance, a @DataJpaTest seems to
suddenly scan components and user configurations of your application. Again, moving the custom
directive to a separate class is a good way to fix this issue.
If you wish to use Spock to test a Spring Boot application, you should add a dependency on Spock’s
spock-spring module to your application’s build. spock-spring integrates Spring’s test framework
into Spock. It is recommended that you use Spock 1.2 or later to benefit from a number of
improvements to Spock’s Spring Framework and Spring Boot integration. See the documentation
for Spock’s Spring module for further details.
209
5.26.4. Test Utilities
A few test utility classes that are generally useful when testing your application are packaged as
part of spring-boot.
ConfigFileApplicationContextInitializer
@ContextConfiguration(classes = Config.class,
initializers = ConfigFileApplicationContextInitializer.class)
TestPropertyValues
TestPropertyValues.of("org=Spring", "name=Boot").applyTo(env);
OutputCapture
OutputCapture is a JUnit Extension that you can use to capture System.out and System.err output. To
use add @ExtendWith(OutputCaptureExtension.class) and inject CapturedOutput as an argument to
your test class constructor or test method as follows:
@ExtendWith(OutputCaptureExtension.class)
class OutputCaptureTests {
@Test
void testName(CapturedOutput output) {
System.out.println("Hello World!");
assertThat(output).contains("World");
}
210
TestRestTemplate
Spring Framework 5.0 provides a new WebTestClient that works for WebFlux
integration tests and both WebFlux and MVC end-to-end testing. It provides a
fluent API for assertions, unlike TestRestTemplate.
It is recommended, but not mandatory, to use the Apache HTTP Client (version 4.3.2 or better). If
you have that on your classpath, the TestRestTemplate responds by configuring the client
appropriately. If you do use Apache’s HTTP client, some additional test-friendly features are
enabled:
• Redirects are not followed (so you can assert the response location).
TestRestTemplate can be instantiated directly in your integration tests, as shown in the following
example:
@Test
public void testRequest() throws Exception {
HttpHeaders headers = this.template.getForEntity(
"https://myhost.example.com/example", String.class).getHeaders();
assertThat(headers.getLocation()).hasHost("other.example.com");
}
211
@SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT)
class SampleWebClientTests {
@Autowired
private TestRestTemplate template;
@Test
void testRequest() {
HttpHeaders headers = this.template.getForEntity("/example",
String.class).getHeaders();
assertThat(headers.getLocation()).hasHost("other.example.com");
}
@TestConfiguration(proxyBeanMethods = false)
static class Config {
@Bean
RestTemplateBuilder restTemplateBuilder() {
return new RestTemplateBuilder().setConnectTimeout(Duration.ofSeconds(1))
.setReadTimeout(Duration.ofSeconds(1));
}
}
5.27. WebSockets
Spring Boot provides WebSockets auto-configuration for embedded Tomcat, Jetty, and Undertow. If
you deploy a war file to a standalone container, Spring Boot assumes that the container is
responsible for the configuration of its WebSocket support.
Spring Framework provides rich WebSocket support for MVC web applications that can be easily
accessed through the spring-boot-starter-websocket module.
WebSocket support is also available for reactive web applications and requires to include the
WebSocket API alongside spring-boot-starter-webflux:
<dependency>
<groupId>javax.websocket</groupId>
<artifactId>javax.websocket-api</artifactId>
</dependency>
212
The Spring Web Services features can be easily accessed with the spring-boot-starter-webservices
module.
SimpleWsdl11Definition and SimpleXsdSchema beans can be automatically created for your WSDLs
and XSDs respectively. To do so, configure their location, as shown in the following example:
spring.webservices.wsdl-locations=classpath:/wsdl
If you need to call remote Web services from your application, you can use the WebServiceTemplate
class. Since WebServiceTemplate instances often need to be customized before being used, Spring
Boot does not provide any single auto-configured WebServiceTemplate bean. It does, however, auto-
configure a WebServiceTemplateBuilder, which can be used to create WebServiceTemplate instances
when needed.
@Service
public class MyService {
@Bean
public WebServiceTemplate webServiceTemplate(WebServiceTemplateBuilder builder) {
return builder.messageSenders(new HttpWebServiceMessageSenderBuilder()
.setConnectTimeout(5000).setReadTimeout(2000).build()).build();
}
213
5.29. Creating Your Own Auto-configuration
If you work in a company that develops shared libraries, or if you work on an open-source or
commercial library, you might want to develop your own auto-configuration. Auto-configuration
classes can be bundled in external jars and still be picked-up by Spring Boot.
A demo project is available to showcase how you can create a starter step-by-step.
You can browse the source code of spring-boot-autoconfigure to see the @Configuration classes that
Spring provides (see the META-INF/spring.factories file).
Spring Boot checks for the presence of a META-INF/spring.factories file within your published jar.
The file should list your configuration classes under the EnableAutoConfiguration key, as shown in
the following example:
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
com.mycorp.libx.autoconfigure.LibXAutoConfiguration,\
com.mycorp.libx.autoconfigure.LibXWebAutoConfiguration
Auto-configurations must be loaded that way only. Make sure that they are defined
in a specific package space and that they are never the target of component
scanning. Furthermore, auto-configuration classes should not enable component
scanning to find additional components. Specific @Imports should be used instead.
If you want to order certain auto-configurations that should not have any direct knowledge of each
other, you can also use @AutoConfigureOrder. That annotation has the same semantic as the regular
@Order annotation but provides a dedicated order for auto-configuration classes.
214
As with standard @Configuration classes, the order in which auto-configuration classes are applied
only affects the order in which their beans are defined. The order in which those beans are
subsequently created is unaffected and is determined by each bean’s dependencies and any
@DependsOn relationships.
You almost always want to include one or more @Conditional annotations on your auto-
configuration class. The @ConditionalOnMissingBean annotation is one common example that is used
to allow developers to override auto-configuration if they are not happy with your defaults.
Spring Boot includes a number of @Conditional annotations that you can reuse in your own code by
annotating @Configuration classes or individual @Bean methods. These annotations include:
• Class Conditions
• Bean Conditions
• Property Conditions
• Resource Conditions
Class Conditions
This mechanism does not apply the same way to @Bean methods where typically the return type is
the target of the condition: before the condition on the method applies, the JVM will have loaded
the class and potentially processed method references which will fail if the class is not present.
To handle this scenario, a separate @Configuration class can be used to isolate the condition, as
shown in the following example:
215
@Configuration(proxyBeanMethods = false)
// Some conditions
public class MyAutoConfiguration {
// Auto-configured beans
@Configuration(proxyBeanMethods = false)
@ConditionalOnClass(EmbeddedAcmeService.class)
static class EmbeddedConfiguration {
@Bean
@ConditionalOnMissingBean
public EmbeddedAcmeService embeddedAcmeService() { ... }
}
Bean Conditions
When placed on a @Bean method, the target type defaults to the return type of the method, as shown
in the following example:
@Configuration(proxyBeanMethods = false)
public class MyAutoConfiguration {
@Bean
@ConditionalOnMissingBean
public MyService myService() { ... }
In the preceding example, the myService bean is going to be created if no bean of type MyService is
already contained in the ApplicationContext.
216
You need to be very careful about the order in which bean definitions are added,
as these conditions are evaluated based on what has been processed so far. For
this reason, we recommend using only @ConditionalOnBean
@ConditionalOnMissingBean annotations on auto-configuration classes (since these
and
are guaranteed to load after any user-defined bean definitions have been added).
Property Conditions
Resource Conditions
The @ConditionalOnResource annotation lets configuration be included only when a specific resource
is present. Resources can be specified by using the usual Spring conventions, as shown in the
following example: file:/home/user/test.dat.
217
5.29.4. Testing your Auto-configuration
An auto-configuration can be affected by many factors: user configuration (@Bean definition and
Environment customization), condition evaluation (presence of a particular library), and others.
Concretely, each test should create a well defined ApplicationContext that represents a combination
of those customizations. ApplicationContextRunner provides a great way to achieve that.
ApplicationContextRunner is usually defined as a field of the test class to gather the base, common
configuration. The following example makes sure that UserServiceAutoConfiguration is always
invoked:
Each test can use the runner to represent a particular use case. For instance, the sample below
invokes a user configuration (UserConfiguration) and checks that the auto-configuration backs off
properly. Invoking run provides a callback context that can be used with AssertJ.
@Test
void defaultServiceBacksOff() {
this.contextRunner.withUserConfiguration(UserConfiguration.class).run((context) ->
{
assertThat(context).hasSingleBean(UserService.class);
assertThat(context).getBean("myUserService").isSameAs(context.getBean(UserService.clas
s));
});
}
@Configuration(proxyBeanMethods = false)
static class UserConfiguration {
@Bean
UserService myUserService() {
return new UserService("mine");
}
It is also possible to easily customize the Environment, as shown in the following example:
218
@Test
void serviceNameCanBeConfigured() {
this.contextRunner.withPropertyValues("user.name=test123").run((context) -> {
assertThat(context).hasSingleBean(UserService.class);
assertThat(context.getBean(UserService.class).getName()).isEqualTo("test123");
});
}
The runner can also be used to display the ConditionEvaluationReport. The report can be printed at
INFO or DEBUG level. The following example shows how to use the
ConditionEvaluationReportLoggingListener to print the report in auto-configuration tests.
@Test
public void autoConfigTest {
ConditionEvaluationReportLoggingListener initializer = new
ConditionEvaluationReportLoggingListener(
LogLevel.INFO);
ApplicationContextRunner contextRunner = new ApplicationContextRunner()
.withInitializer(initializer).run((context) -> {
// Do something...
});
}
If you need to test an auto-configuration that only operates in a Servlet or Reactive web application
context, use the WebApplicationContextRunner or ReactiveWebApplicationContextRunner respectively.
It is also possible to test what happens when a particular class and/or package is not present at
runtime. Spring Boot ships with a FilteredClassLoader that can easily be used by the runner. In the
following example, we assert that if UserService is not present, the auto-configuration is properly
disabled:
@Test
void serviceIsIgnoredIfLibraryIsNotPresent() {
this.contextRunner.withClassLoader(new FilteredClassLoader(UserService.class))
.run((context) -> assertThat(context).doesNotHaveBean("userService"));
}
A typical Spring Boot starter contains code to auto-configure and customize the infrastructure of a
given technology, let’s call that "acme". To make it easily extensible, a number of configuration keys
in a dedicated namespace can be exposed to the environment. Finally, a single "starter" dependency
219
is provided to help users get started as easily as possible.
• The autoconfigure module that contains the auto-configuration code for "acme".
• The starter module that provides a dependency to the autoconfigure module as well as "acme"
and any additional dependencies that are typically useful. In a nutshell, adding the starter
should provide everything needed to start using that library.
This separation in two modules is in no way necessary. If "acme" has several flavours, options or
optional features, then it is better to separate the auto-configuration as you can clearly express the
fact some features are optional. Besides, you have the ability to craft a starter that provides an
opinion about those optional dependencies. At the same time, others can rely only on the
autoconfigure module and craft their own starter with different opinions.
If the auto-configuration is relatively straightforward and does not have optional feature, merging
the two modules in the starter is definitely an option.
Naming
You should make sure to provide a proper namespace for your starter. Do not start your module
names with spring-boot, even if you use a different Maven groupId. We may offer official support
for the thing you auto-configure in the future.
As a rule of thumb, you should name a combined module after the starter. For example, assume
that you are creating a starter for "acme" and that you name the auto-configure module acme-
spring-boot and the starter acme-spring-boot-starter. If you only have one module that combines
the two, name it acme-spring-boot-starter.
Configuration keys
If your starter provides configuration keys, use a unique namespace for them. In particular, do not
include your keys in the namespaces that Spring Boot uses (such as server, management, spring, and
so on). If you use the same namespace, we may modify these namespaces in the future in ways that
break your modules. As a rule of thumb, prefix all your keys with a namespace that you own (e.g.
acme).
Make sure that configuration keys are documented by adding field javadoc for each property, as
shown in the following example:
220
@ConfigurationProperties("acme")
public class AcmeProperties {
/**
* Whether to check the location of acme resources.
*/
private boolean checkLocation = true;
/**
* Timeout for establishing a connection to the acme server.
*/
private Duration loginTimeout = Duration.ofSeconds(3);
You should only use plain text with @ConfigurationProperties field Javadoc, since
they are not processed before being added to the JSON.
Here are some rules we follow internally to make sure descriptions are consistent:
• Use java.time.Duration rather than long and describe the default unit if it differs from
milliseconds, e.g. "If a duration suffix is not specified, seconds will be used".
• Do not provide the default value in the description unless it has to be determined at runtime.
Make sure to trigger meta-data generation so that IDE assistance is available for your keys as well.
You may want to review the generated metadata (META-INF/spring-configuration-metadata.json) to
make sure your keys are properly documented. Using your own starter in a compatible IDE is also a
good idea to validate that quality of the metadata.
The autoconfigure module contains everything that is necessary to get started with the library. It
may also contain configuration key definitions (such as @ConfigurationProperties) and any callback
interface that can be used to further customize how the components are initialized.
You should mark the dependencies to the library as optional so that you can
include the autoconfigure module in your projects more easily. If you do it that
way, the library is not provided and, by default, Spring Boot backs off.
221
to eagerly filter auto-configurations that do not match, which will improve startup time. It is
recommended to add the following dependency in a module that contains auto-configurations:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-autoconfigure-processor</artifactId>
<optional>true</optional>
</dependency>
If you have defined auto-configurations directly in your application, make sure to configure the
spring-boot-maven-plugin to prevent the repackage goal from adding the dependency into the fat jar:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-autoconfigure-
processor</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
With Gradle 4.5 and earlier, the dependency should be declared in the compileOnly configuration, as
shown in the following example:
dependencies {
compileOnly "org.springframework.boot:spring-boot-autoconfigure-processor"
}
With Gradle 4.6 and later, the dependency should be declared in the annotationProcessor
configuration, as shown in the following example:
dependencies {
annotationProcessor "org.springframework.boot:spring-boot-autoconfigure-processor"
}
222
Starter Module
The starter is really an empty jar. Its only purpose is to provide the necessary dependencies to work
with the library. You can think of it as an opinionated view of what is required to get started.
Do not make assumptions about the project in which your starter is added. If the library you are
auto-configuring typically requires other starters, mention them as well. Providing a proper set of
default dependencies may be hard if the number of optional dependencies is high, as you should
avoid including dependencies that are unnecessary for a typical usage of the library. In other
words, you should not include optional dependencies.
Either way, your starter must reference the core Spring Boot starter (spring-boot-
starter) directly or indirectly (i.e. no need to add it if your starter relies on another
starter). If a project is created with only your custom starter, Spring Boot’s core
features will be honoured by the presence of the core starter.
Spring Boot provides Kotlin support by leveraging the support in other Spring projects such as
Spring Framework, Spring Data, and Reactor. See the Spring Framework Kotlin support
documentation for more information.
The easiest way to start with Spring Boot and Kotlin is to follow this comprehensive tutorial. You
can create new Kotlin projects via start.spring.io. Feel free to join the #spring channel of Kotlin
Slack or ask a question with the spring and kotlin tags on Stack Overflow if you need support.
5.30.1. Requirements
Since Kotlin classes are final by default, you are likely to want to configure kotlin-spring plugin in
order to automatically open Spring-annotated classes so that they can be proxied.
Jackson’s Kotlin module is required for serializing / deserializing JSON data in Kotlin. It is
automatically registered when found on the classpath. A warning message is logged if Jackson and
Kotlin are present but the Jackson Kotlin module is not.
These dependencies and plugins are provided by default if one bootstraps a Kotlin
project on start.spring.io.
5.30.2. Null-safety
One of Kotlin’s key features is null-safety. It deals with null values at compile time rather than
deferring the problem to runtime and encountering a NullPointerException. This helps to eliminate
223
a common source of bugs without paying the cost of wrappers like Optional. Kotlin also allows using
functional constructs with nullable values as described in this comprehensive guide to null-safety
in Kotlin.
Although Java does not allow one to express null-safety in its type system, Spring Framework,
Spring Data, and Reactor now provide null-safety of their API via tooling-friendly annotations. By
default, types from Java APIs used in Kotlin are recognized as platform types for which null-checks
are relaxed. Kotlin’s support for JSR 305 annotations combined with nullability annotations provide
null-safety for the related Spring API in Kotlin.
The JSR 305 checks can be configured by adding the -Xjsr305 compiler flag with the following
options: -Xjsr305={strict|warn|ignore}. The default behavior is the same as -Xjsr305=warn. The
strict value is required to have null-safety taken in account in Kotlin types inferred from Spring
API but should be used with the knowledge that Spring API nullability declaration could evolve
even between minor releases and more checks may be added in the future).
Generic type arguments, varargs and array elements nullability are not yet
supported. See SPR-15942 for up-to-date information. Also be aware that Spring
Boot’s own API is not yet annotated.
runApplication
import org.springframework.boot.autoconfigure.SpringBootApplication
import org.springframework.boot.runApplication
@SpringBootApplication
class MyApplication
runApplication<MyApplication>(*args) {
setBannerMode(OFF)
}
Extensions
Kotlin extensions provide the ability to extend existing classes with additional functionality. The
224
Spring Boot Kotlin API makes use of these extensions to add new Kotlin specific conveniences to
existing APIs.
In order to avoid mixing different versions of Kotlin dependencies on the classpath, Spring Boot
imports the Kotlin BOM.
With Maven, the Kotlin version can be customized via the kotlin.version property and plugin
management is provided for kotlin-maven-plugin. With Gradle, the Spring Boot plugin
automatically aligns the kotlin.version with the version of the Kotlin plugin.
Spring Boot also manages the version of Coroutines dependencies by importing the Kotlin
Coroutines BOM. The version can be customized via the kotlin-coroutines.version property.
5.30.5. @ConfigurationProperties
@ConstructorBinding
@ConfigurationProperties("example.kotlin")
data class KotlinExampleProperties(
val name: String,
val description: String,
val myService: MyService) {
To generate your own metadata using the annotation processor, kapt should be
configured with the spring-boot-configuration-processor dependency. Note that
some features (such as detecting the default value or deprecated items) are not
working due to limitations in the model kapt provides.
225
5.30.6. Testing
While it is possible to use JUnit 4 to test Kotlin code, JUnit 5 is provided by default and is
recommended. JUnit 5 enables a test class to be instantiated once and reused for all of the class’s
tests. This makes it possible to use @BeforeAll and @AfterAll annotations on non-static methods,
which is a good fit for Kotlin.
JUnit 5 is the default and the vintage engine is provided for backward compatibility with JUnit 4. If
you don’t use it, exclude org.junit.vintage:junit-vintage-engine. You also need to switch test
instance lifecycle to "per-class".
To mock Kotlin classes, MockK is recommended. If you need the Mockk equivalent of the Mockito
specific @MockBean and @SpyBean annotations, you can use SpringMockK which provides similar
@MockkBean and @SpykBean annotations.
5.30.7. Resources
Further reading
• Kotlin blog
• Awesome Kotlin
Examples
• spring-kotlin-fullstack: WebFlux Kotlin fullstack example with Kotlin2js for frontend instead of
JavaScript or TypeScript
• spring-kotlin-deepdive: a step by step migration for Boot 1.0 + Java to Boot 2.0 + Kotlin
226
5.31. Container Images
It is easily possible to package a Spring Boot fat jar as a docker image. However, there are various
downsides to copying and running the fat jar as is in the docker image. There’s always a certain
amount of overhead when running a fat jar without unpacking it, and in a containerized
environment this can be noticeable. The other issue is that putting your application’s code and all
its dependencies in one layer in the Docker image is sub-optimal. Since you probably recompile
your code more often than you upgrade the version of Spring Boot you use, it’s often better to
separate things a bit more. If you put jar files in the layer before your application classes, Docker
often only needs to change the very bottom layer and can pick others up from its cache.
To make it easier to create optimized Docker images, Spring Boot supports adding a layer index file
to the jar. It provides a list of layers and the parts of the jar that should be contained within them.
The list of layers in the index is ordered based on the order in which the layers should be added to
the Docker/OCI image. Out-of-the-box, the following layers are supported:
- "dependencies":
- BOOT-INF/lib/library1.jar
- BOOT-INF/lib/library2.jar
- "spring-boot-loader":
- org/springframework/boot/loader/JarLauncher.class
- org/springframework/boot/loader/jar/JarEntry.class
- "snapshot-dependencies":
- BOOT-INF/lib/library3-SNAPSHOT.jar
- "application":
- META-INF/MANIFEST.MF
- BOOT-INF/classes/a/b/C.class
This layering is designed to separate code based on how likely it is to change between application
builds. Library code is less likely to change between builds, so it is placed in its own layers to allow
tooling to re-use the layers from cache. Application code is more likely to change between builds so
it is isolated in a separate layer.
For Maven, refer to the packaging layered jars section for more details on adding a layer index to
the jar. For Gradle, refer to the packaging layered jars section of the Gradle plugin documentation.
227
5.31.2. Building Container Images
Spring Boot applications can be containerized using Dockerfiles, or by using Cloud Native
Buildpacks to create docker compatible container images that you can run anywhere.
Dockerfiles
While it is possible to convert a Spring Boot fat jar into a docker image with just a few lines in the
Dockerfile, we will use the layering feature to create an optimized docker image. When you create a
jar containing the layers index file, the spring-boot-jarmode-layertools jar will be added as a
dependency to your jar. With this jar on the classpath, you can launch your application in a special
mode which allows the bootstrap code to run something entirely different from your application,
for example, something that extracts the layers.
The layertools mode can not be used with a fully executable Spring Boot archive
that includes a launch script. Disable launch script configuration when building a
jar file that is intended to be used with layertools.
Here’s how you can launch your jar with a layertools jar mode:
Usage:
java -Djarmode=layertools -jar my-app.jar
Available commands:
list List layers from the jar that can be extracted
extract Extracts layers from the jar for image creation
help Help about any command
The extract command can be used to easily split the application into layers to be added to the
dockerfile. Here’s an example of a Dockerfile using jarmode.
228
FROM adoptopenjdk:11-jre-hotspot as builder
WORKDIR application
ARG JAR_FILE=target/*.jar
COPY ${JAR_FILE} application.jar
RUN java -Djarmode=layertools -jar application.jar extract
FROM adoptopenjdk:11-jre-hotspot
WORKDIR application
COPY --from=builder application/dependencies/ ./
COPY --from=builder application/spring-boot-loader/ ./
COPY --from=builder application/snapshot-dependencies/ ./
COPY --from=builder application/application/ ./
ENTRYPOINT ["java", "org.springframework.boot.loader.JarLauncher"]
Assuming the above Dockerfile is in the current directory, your docker image can be built with
docker build ., or optionally specifying the path to your application jar, as shown in the following
example:
This is a multi-stage dockerfile. The builder stage extracts the directories that are needed later. Each
of the COPY commands relates to the layers extracted by the jarmode.
Of course, a Dockerfile can be written without using the jarmode. You can use some combination of
unzip and mv to move things to the right layer but jarmode simplifies that.
Dockerfiles are just one way to build docker images. Another way to build docker images is directly
from your Maven or Gradle plugin, using buildpacks. If you’ve ever used an application platform
such as Cloud Foundry or Heroku then you’ve probably used a buildpack. Buildpacks are the part of
the platform that takes your application and converts it into something that the platform can
actually run. For example, Cloud Foundry’s Java buildpack will notice that you’re pushing a .jar file
and automatically add a relevant JRE.
With Cloud Native Buildpacks, you can create Docker compatible images that you can run
anywhere. Spring Boot includes buildpack support directly for both Maven and Gradle. This means
you can just type a single command and quickly get a sensible image into your locally running
Docker daemon.
Refer to the individual plugin documentation on how to use buildpacks with Maven and Gradle.
The Paketo Spring Boot buildpack has also been updated to support the layers.idx
file so any customization that is applied to it will be reflected in the image created
by the buildpack.
229
5.32. What to Read Next
If you want to learn more about any of the classes discussed in this section, you can check out the
Spring Boot API documentation or you can browse the source code directly. If you have specific
questions, take a look at the how-to section.
If you are comfortable with Spring Boot’s core features, you can continue on and read about
production-ready features.
230
Chapter 6. Spring Boot Actuator: Production-
ready Features
Spring Boot includes a number of additional features to help you monitor and manage your
application when you push it to production. You can choose to manage and monitor your
application by using HTTP endpoints or with JMX. Auditing, health, and metrics gathering can also
be automatically applied to your application.
Definition of Actuator
To add the actuator to a Maven based project, add the following ‘Starter’ dependency:
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
</dependencies>
dependencies {
implementation 'org.springframework.boot:spring-boot-starter-actuator'
}
6.2. Endpoints
Actuator endpoints let you monitor and interact with your application. Spring Boot includes a
number of built-in endpoints and lets you add your own. For example, the health endpoint provides
basic application health information.
Each individual endpoint can be enabled or disabled and exposed (made remotely accessible) over
HTTP or JMX. An endpoint is considered to be available when it is both enabled and exposed. The
built-in endpoints will only be auto-configured when they are available. Most applications choose
231
exposure via HTTP, where the ID of the endpoint along with a prefix of /actuator is mapped to a
URL. For example, by default, the health endpoint is mapped to /actuator/health.
To learn more about the Actuator’s endpoints and their request and response
formats, please refer to the separate API documentation (HTML or PDF).
ID Description
auditevents Exposes audit events information for the current application.
Requires an AuditEventRepository bean.
beans Displays a complete list of all the Spring beans in your application.
caches Exposes available caches.
conditions Shows the conditions that were evaluated on configuration and auto-
configuration classes and the reasons why they did or did not match.
configprops Displays a collated list of all @ConfigurationProperties.
env Exposes properties from Spring’s ConfigurableEnvironment.
flyway Shows any Flyway database migrations that have been applied.
Requires one or more Flyway beans.
health Shows application health information.
httptrace Displays HTTP trace information (by default, the last 100 HTTP
request-response exchanges). Requires an HttpTraceRepository bean.
info Displays arbitrary application info.
integrationgraph Shows the Spring Integration graph. Requires a dependency on
spring-integration-core.
loggers Shows and modifies the configuration of loggers in the application.
liquibase Shows any Liquibase database migrations that have been applied.
Requires one or more Liquibase beans.
metrics Shows ‘metrics’ information for the current application.
mappings Displays a collated list of all @RequestMapping paths.
scheduledtasks Displays the scheduled tasks in your application.
sessions Allows retrieval and deletion of user sessions from a Spring Session-
backed session store. Requires a Servlet-based web application using
Spring Session.
shutdown Lets the application be gracefully shutdown. Disabled by default.
threaddump Performs a thread dump.
If your application is a web application (Spring MVC, Spring WebFlux, or Jersey), you can use the
following additional endpoints:
232
ID Description
heapdump Returns an hprof heap dump file. Requires a HotSpot JVM.
jolokia Exposes JMX beans over HTTP (when Jolokia is on the classpath, not
available for WebFlux). Requires a dependency on jolokia-core.
logfile Returns the contents of the logfile (if logging.file.name or
logging.file.path properties have been set). Supports the use of the
HTTP Range header to retrieve part of the log file’s content.
prometheus Exposes metrics in a format that can be scraped by a Prometheus
server. Requires a dependency on micrometer-registry-prometheus.
By default, all endpoints except for shutdown are enabled. To configure the enablement of an
endpoint, use its management.endpoint.<id>.enabled property. The following example enables the
shutdown endpoint:
management.endpoint.shutdown.enabled=true
If you prefer endpoint enablement to be opt-in rather than opt-out, set the
management.endpoints.enabled-by-default property to false and use individual endpoint enabled
properties to opt back in. The following example enables the info endpoint and disables all other
endpoints:
management.endpoints.enabled-by-default=false
management.endpoint.info.enabled=true
Disabled endpoints are removed entirely from the application context. If you want
to change only the technologies over which an endpoint is exposed, use the include
and exclude properties instead.
Since Endpoints may contain sensitive information, careful consideration should be given about
when to expose them. The following table shows the default exposure for the built-in endpoints:
ID JMX Web
auditevents Yes No
beans Yes No
caches Yes No
conditions Yes No
configprops Yes No
233
ID JMX Web
env Yes No
flyway Yes No
health Yes Yes
heapdump N/A No
httptrace Yes No
info Yes Yes
integrationgraph Yes No
jolokia N/A No
logfile N/A No
loggers Yes No
liquibase Yes No
metrics Yes No
mappings Yes No
prometheus N/A No
scheduledtasks Yes No
sessions Yes No
shutdown Yes No
threaddump Yes No
To change which endpoints are exposed, use the following technology-specific include and exclude
properties:
Property Default
management.endpoints.jmx.exposure.exclude
management.endpoints.jmx.exposure.include *
management.endpoints.web.exposure.exclude
management.endpoints.web.exposure.include info, health
The include property lists the IDs of the endpoints that are exposed. The exclude property lists the
IDs of the endpoints that should not be exposed. The exclude property takes precedence over the
include property. Both include and exclude properties can be configured with a list of endpoint IDs.
For example, to stop exposing all endpoints over JMX and only expose the health and info
endpoints, use the following property:
management.endpoints.jmx.exposure.include=health,info
* can be used to select all endpoints. For example, to expose everything over HTTP except the env
234
and beans endpoints, use the following properties:
management.endpoints.web.exposure.include=*
management.endpoints.web.exposure.exclude=env,beans
* has a special meaning in YAML, so be sure to add quotes if you want to include
(or exclude) all endpoints, as shown in the following example:
management:
endpoints:
web:
exposure:
include: "*"
If you want to implement your own strategy for when endpoints are exposed, you
can register an EndpointFilter bean.
You should take care to secure HTTP endpoints in the same way that you would any other sensitive
URL. If Spring Security is present, endpoints are secured by default using Spring Security’s content-
negotiation strategy. If you wish to configure custom security for HTTP endpoints, for example, only
allow users with a certain role to access them, Spring Boot provides some convenient
RequestMatcher objects that can be used in combination with Spring Security.
A typical Spring Security configuration might look something like the following example:
@Configuration(proxyBeanMethods = false)
public class ActuatorSecurity extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http.requestMatcher(EndpointRequest.toAnyEndpoint()).authorizeRequests((requests) ->
requests.anyRequest().hasRole("ENDPOINT_ADMIN"));
http.httpBasic();
}
235
available on EndpointRequest. See the API documentation (HTML or PDF) for details.
If you deploy applications behind a firewall, you may prefer that all your actuator endpoints can be
accessed without requiring authentication. You can do so by changing the
management.endpoints.web.exposure.include property, as follows:
application.properties
management.endpoints.web.exposure.include=*
Additionally, if Spring Security is present, you would need to add custom security configuration that
allows unauthenticated access to the endpoints as shown in the following example:
@Configuration(proxyBeanMethods = false)
public class ActuatorSecurity extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http.requestMatcher(EndpointRequest.toAnyEndpoint()).authorizeRequests((requests) ->
requests.anyRequest().permitAll());
}
Endpoints automatically cache responses to read operations that do not take any parameters. To
configure the amount of time for which an endpoint will cache a response, use its cache.time-to-
live property. The following example sets the time-to-live of the beans endpoint’s cache to 10
seconds:
application.properties
management.endpoint.beans.cache.time-to-live=10s
A “discovery page” is added with links to all the endpoints. The “discovery page” is available on
/actuator by default.
When a custom management context path is configured, the “discovery page” automatically moves
from /actuator to the root of the management context. For example, if the management context
path is /management, then the discovery page is available from /management. When the management
236
context path is set to /, the discovery page is disabled to prevent the possibility of a clash with other
mappings.
Cross-origin resource sharing (CORS) is a W3C specification that lets you specify in a flexible way
what kind of cross-domain requests are authorized. If you use Spring MVC or Spring WebFlux,
Actuator’s web endpoints can be configured to support such scenarios.
management.endpoints.web.cors.allowed-origins=https://example.com
management.endpoints.web.cors.allowed-methods=GET,POST
If you add a @Bean annotated with @Endpoint, any methods annotated with @ReadOperation,
@WriteOperation, or @DeleteOperation are automatically exposed over JMX and, in a web application,
over HTTP as well. Endpoints can be exposed over HTTP using Jersey, Spring MVC, or Spring
WebFlux. If both Jersey and Spring MVC are available, Spring MVC will be used.
The following example exposes a read operation that returns a custom object:
@ReadOperation
public CustomData getCustomData() {
return new CustomData("test", 5);
}
You can also write technology-specific endpoints by using @JmxEndpoint or @WebEndpoint. These
endpoints are restricted to their respective technologies. For example, @WebEndpoint is exposed only
over HTTP and not over JMX.
Finally, if you need access to web-framework-specific functionality, you can implement Servlet or
Spring @Controller and @RestController endpoints at the cost of them not being available over JMX
or when using a different web framework.
Receiving Input
Operations on an endpoint receive input via their parameters. When exposed via the web, the
237
values for these parameters are taken from the URL’s query parameters and from the JSON request
body. When exposed via JMX, the parameters are mapped to the parameters of the MBean’s
operations. Parameters are required by default. They can be made optional by annotating them
with either @javax.annotation.Nullable or @org.springframework.lang.Nullable.
Each root property in the JSON request body can be mapped to a parameter of the endpoint.
Consider the following JSON request body:
{
"name": "test",
"counter": 42
}
This can be used to invoke a write operation that takes String name and int counter parameters, as
shown in the following example:
@WriteOperation
public void updateCustomData(String name, int counter) {
// injects "test" and 42
}
Because endpoints are technology agnostic, only simple types can be specified in
the method signature. In particular declaring a single parameter with a CustomData
type defining a name and counter properties is not supported.
To allow the input to be mapped to the operation method’s parameters, Java code
implementing an endpoint should be compiled with -parameters, and Kotlin code
implementing an endpoint should be compiled with -java-parameters. This will
happen automatically if you are using Spring Boot’s Gradle plugin or if you are
using Maven and spring-boot-starter-parent.
The parameters passed to endpoint operation methods are, if necessary, automatically converted to
the required type. Before calling an operation method, the input received via JMX or an HTTP
request is converted to the required types using an instance of ApplicationConversionService as well
as any Converter or GenericConverter beans qualified with @EndpointConverter.
238
Path
The path of the predicate is determined by the ID of the endpoint and the base path of web-exposed
endpoints. The default base path is /actuator. For example, an endpoint with the ID sessions will
use /actuator/sessions as its path in the predicate.
The path can be further customized by annotating one or more parameters of the operation method
with @Selector. Such a parameter is added to the path predicate as a path variable. The variable’s
value is passed into the operation method when the endpoint operation is invoked. If you want to
capture all remaining path elements, you can add @Selector(Match=ALL_REMAINING) to the last
parameter and make it a type that is conversion compatible with a String[].
HTTP method
The HTTP method of the predicate is determined by the operation type, as shown in the following
table:
Consumes
For a @WriteOperation (HTTP POST) that uses the request body, the consumes clause of the predicate
is application/vnd.spring-boot.actuator.v2+json, application/json. For all other operations the
consumes clause is empty.
Produces
The produces clause of the predicate can be determined by the produces attribute of the
@DeleteOperation, @ReadOperation, and @WriteOperation annotations. The attribute is optional. If it is
not used, the produces clause is determined automatically.
If the operation method returns void or Void the produces clause is empty. If the operation method
returns a org.springframework.core.io.Resource, the produces clause is application/octet-stream.
For all other operations the produces clause is application/vnd.spring-boot.actuator.v2+json,
application/json.
The default response status for an endpoint operation depends on the operation type (read, write,
or delete) and what, if anything, the operation returns.
A @ReadOperation returns a value, the response status will be 200 (OK). If it does not return a value,
the response status will be 404 (Not Found).
If a @WriteOperation or @DeleteOperation returns a value, the response status will be 200 (OK). If it
does not return a value the response status will be 204 (No Content).
239
If an operation is invoked without a required parameter, or with a parameter that cannot be
converted to the required type, the operation method will not be called and the response status will
be 400 (Bad Request).
An HTTP range request can be used to request part of an HTTP resource. When using Spring MVC
or Spring Web Flux, operations that return a org.springframework.core.io.Resource automatically
support range requests.
An operation on a web endpoint or a web-specific endpoint extension can receive the current
java.security.Principal or org.springframework.boot.actuate.endpoint.SecurityContext as a
method parameter. The former is typically used in conjunction with @Nullable to provide different
behavior for authenticated and unauthenticated users. The latter is typically used to perform
authorization checks using its isUserInRole(String) method.
Servlet endpoints
Controller endpoints
You can use health information to check the status of your running application. It is often used by
monitoring software to alert someone when a production system goes down. The information
exposed by the health endpoint depends on the management.endpoint.health.show-details and
management.endpoint.health.show-components properties which can be configured with one of the
following values:
Name Description
never Details are never shown.
240
Name Description
when-authorized Details are only shown to authorized users. Authorized roles can be
configured using management.endpoint.health.roles.
always Details are shown to all users.
The default value is never. A user is considered to be authorized when they are in one or more of
the endpoint’s roles. If the endpoint has no configured roles (the default) all authenticated users are
considered to be authorized. The roles can be configured using the
management.endpoint.health.roles property.
If you have secured your application and wish to use always, your security
configuration must permit access to the health endpoint for both authenticated
and unauthenticated users.
Health information is collected from the content of a HealthContributorRegistry (by default all
HealthContributor instances defined in your ApplicationContext). Spring Boot includes a number of
auto-configured HealthContributors and you can also write your own.
By default, the final system health is derived by a StatusAggregator which sorts the statuses from
each HealthIndicator based on an ordered list of statuses. The first status in the sorted list is used as
the overall health status. If no HealthIndicator returns a status that is known to the
StatusAggregator, an UNKNOWN status is used.
Auto-configured HealthIndicators
The following HealthIndicators are auto-configured by Spring Boot when appropriate. You can also
enable/disable selected indicators by configuring management.health.key.enabled, with the key listed
in the table below.
241
Key Name Description
hazelcast HazelcastHealthIndicator Checks that a Hazelcast server is up.
influxdb InfluxDbHealthIndicator Checks that an InfluxDB server is up.
jms JmsHealthIndicator Checks that a JMS broker is up.
ldap LdapHealthIndicator Checks that an LDAP server is up.
mail MailHealthIndicator Checks that a mail server is up.
mongo MongoHealthIndicator Checks that a Mongo database is up.
neo4j Neo4jHealthIndicator Checks that a Neo4j database is up.
ping PingHealthIndicator Always responds with UP.
rabbit RabbitHealthIndicator Checks that a Rabbit server is up.
redis RedisHealthIndicator Checks that a Redis server is up.
solr SolrHealthIndicator Checks that a Solr server is up.
To provide custom health information, you can register Spring beans that implement the
HealthIndicator interface. You need to provide an implementation of the health() method and
return a Health response. The Health response should include a status and can optionally include
additional details to be displayed. The following code shows a sample HealthIndicator
implementation:
242
import org.springframework.boot.actuate.health.Health;
import org.springframework.boot.actuate.health.HealthIndicator;
import org.springframework.stereotype.Component;
@Component
public class MyHealthIndicator implements HealthIndicator {
@Override
public Health health() {
int errorCode = check(); // perform some specific health check
if (errorCode != 0) {
return Health.down().withDetail("Error Code", errorCode).build();
}
return Health.up().build();
}
The identifier for a given HealthIndicator is the name of the bean without the
HealthIndicator suffix, if it exists. In the preceding example, the health
information is available in an entry named my.
In addition to Spring Boot’s predefined Status types, it is also possible for Health to return a custom
Status that represents a new system state. In such cases, a custom implementation of the
StatusAggregator interface also needs to be provided, or the default implementation has to be
configured by using the management.endpoint.health.status.order configuration property.
For example, assume a new Status with code FATAL is being used in one of your HealthIndicator
implementations. To configure the severity order, add the following property to your application
properties:
management.endpoint.health.status.order=fatal,down,out-of-service,unknown,up
The HTTP status code in the response reflects the overall health status. By default, OUT_OF_SERVICE
and DOWN map to 503. Any unmapped health statuses, including UP, map to 200. You might also want
to register custom status mappings if you access the health endpoint over HTTP. Configuring a
custom mapping disables the defaults mappings for DOWN and OUT_OF_SERVICE. If you want to retain
the default mappings they must be configured explicitly alongside any custom mappings. For
example, the following property maps FATAL to 503 (service unavailable) and retains the default
mappings for DOWN and OUT_OF_SERVICE:
management.endpoint.health.status.http-mapping.down=503
management.endpoint.health.status.http-mapping.fatal=503
management.endpoint.health.status.http-mapping.out-of-service=503
243
If you need more control, you can define your own HttpCodeStatusMapper bean.
The following table shows the default status mappings for the built-in statuses:
Status Mapping
For reactive applications, such as those using Spring WebFlux, ReactiveHealthContributor provides
a non-blocking contract for getting application health. Similar to a traditional HealthContributor,
health information is collected from the content of a ReactiveHealthContributorRegistry (by default
all HealthContributor and ReactiveHealthContributor instances defined in your ApplicationContext).
Regular HealthContributors that do not check against a reactive API are executed on the elastic
scheduler.
To provide custom health information from a reactive API, you can register Spring beans that
implement the ReactiveHealthIndicator interface. The following code shows a sample
ReactiveHealthIndicator implementation:
@Component
public class MyReactiveHealthIndicator implements ReactiveHealthIndicator {
@Override
public Mono<Health> health() {
return doHealthCheck() //perform some specific health check that returns a
Mono<Health>
.onErrorResume(ex -> Mono.just(new Health.Builder().down(ex).build()));
}
244
Auto-configured ReactiveHealthIndicators
If necessary, reactive indicators replace the regular ones. Also, any HealthIndicator
that is not handled explicitly is wrapped automatically.
Health Groups
It’s sometimes useful to organize health indicators into groups that can be used for different
purposes.
management.endpoint.health.group.custom.include=db
By default groups will inherit the same StatusAggregator and HttpCodeStatusMapper settings as the
system health, however, these can also be defined on a per-group basis. It’s also possible to override
the show-details and roles properties if required:
management.endpoint.health.group.custom.show-details=when-authorized
management.endpoint.health.group.custom.roles=admin
management.endpoint.health.group.custom.status.order=fatal,up
management.endpoint.health.group.custom.status.http-mapping.fatal=500
management.endpoint.health.group.custom.status.http-mapping.out-of-service=500
Applications deployed on Kubernetes can provide information about their internal state with
245
Container Probes. Depending on your Kubernetes configuration, the kubelet will call those probes
and react to the result.
Spring Boot manages your Application Availability State out-of-the-box. If deployed in a Kubernetes
environment, actuator will gather the "Liveness" and "Readiness" information from the
ApplicationAvailability interface and use that information in dedicated Health Indicators:
LivenessStateHealthIndicator and ReadinessStateHealthIndicator. These indicators will be shown
on the global health endpoint ("/actuator/health"). They will also be exposed as separate HTTP
Probes using Health Groups: "/actuator/health/liveness" and "/actuator/health/readiness".
You can then configure your Kubernetes infrastructure with the following endpoint information:
livenessProbe:
httpGet:
path: /actuator/health/liveness
port: <actuator-port>
failureThreshold: ...
periodSeconds: ...
readinessProbe:
httpGet:
path: /actuator/health/readiness
port: <actuator-port>
failureThreshold: ...
periodSeconds: ...
<actuator-port> should be set to the port that the actuator endpoints are available
on. It could be the main web server port, or a separate management port if the
"management.server.port" property has been set.
These health groups are only enabled automatically if the application is running in a Kubernetes
environment. You can enable them in any environment using the
management.endpoint.health.probes.enabled configuration property.
246
Checking external state with Kubernetes Probes
Actuator configures the "liveness" and "readiness" probes as Health Groups; this means that all the
Health Groups features are available for them. You can, for example, configure additional Health
Indicators:
management.endpoint.health.group.readiness.include=readinessState,customCheck
By default, Spring Boot does not add other Health Indicators to these groups.
The “liveness” Probe should not depend on health checks for external systems. If the Liveness State
of an application is broken, Kubernetes will try to solve that problem by restarting the application
instance. This means that if an external system fails (e.g. a database, a Web API, an external cache),
Kubernetes might restart all application instances and create cascading failures.
As for the “readiness” Probe, the choice of checking external systems must be made carefully by the
application developers, i.e. Spring Boot does not include any additional health checks in the
readiness probe. If the Readiness State of an application instance is unready, Kubernetes will not
route traffic to that instance. Some external systems might not be shared by application instances,
in which case they could quite naturally be included in a readiness probe. Other external systems
might not be essential to the application (the application could have circuit breakers and fallbacks),
in which case they definitely should not be included. Unfortunately, an external system that is
shared by all application instances is common, and you have to make a judgement call: include it in
the readiness probe and expect that the application is taken out of service when the external
service is down, or leave it out and deal with failures higher up the stack, e.g. using a circuit
breaker in the caller.
Also, if an application is using Kubernetes autoscaling it may react differently to applications being
taken out of the load-balancer, depending on its autoscaler configuration.
An important aspect of the Kubernetes Probes support is its consistency with the application
lifecycle. Spring Boot publishes Application Events during startup and shutdown.
247
Application startup Liveness Readiness Notes
phase State State
Shutdown complete broken unready The application context is closed and the
application cannot serve traffic.
Check out the Kubernetes container lifecycle section for more information about
Kubernetes deployment.
Application information exposes various information collected from all InfoContributor beans
defined in your ApplicationContext. Spring Boot includes a number of auto-configured
InfoContributor beans, and you can write your own.
Auto-configured InfoContributors
The following InfoContributor beans are auto-configured by Spring Boot, when appropriate:
Name Description
EnvironmentInfoCon Exposes any key from the Environment under the info key.
tributor
GitInfoContributor Exposes git information if a git.properties file is available.
248
Custom Application Information
You can customize the data exposed by the info endpoint by setting info.* Spring properties. All
Environment properties under the info key are automatically exposed. For example, you could add
the following settings to your application.properties file:
info.app.encoding=UTF-8
info.app.java.source=1.8
info.app.java.target=1.8
Rather than hardcoding those values, you could also expand info properties at
build time.
Assuming you use Maven, you could rewrite the preceding example as follows:
info.app.encoding=@project.build.sourceEncoding@
info.app.java.source=@java.version@
info.app.java.target=@java.version@
Another useful feature of the info endpoint is its ability to publish information about the state of
your git source code repository when the project was built. If a GitProperties bean is available, the
info endpoint can be used to expose these properties.
management.info.git.mode=full
To disable the git commit information from the info endpoint completely, set the
management.info.git.enabled property to false, as follows:
management.info.git.enabled=false
Build Information
If a BuildProperties bean is available, the info endpoint can also publish information about your
build. This happens if a META-INF/build-info.properties file is available in the classpath.
249
The Maven and Gradle plugins can both generate that file. See "Generate build
information" for more details.
To provide custom application information, you can register Spring beans that implement the
InfoContributor interface.
import java.util.Collections;
import org.springframework.boot.actuate.info.Info;
import org.springframework.boot.actuate.info.InfoContributor;
import org.springframework.stereotype.Component;
@Component
public class ExampleInfoContributor implements InfoContributor {
@Override
public void contribute(Info.Builder builder) {
builder.withDetail("example",
Collections.singletonMap("key", "value"));
}
If you reach the info endpoint, you should see a response that contains the following additional
entry:
{
"example": {
"key" : "value"
}
}
Actuator is supported natively with Spring MVC, Spring WebFlux, and Jersey. If
both Jersey and Spring MVC are available, Spring MVC will be used.
250
Jackson is a required dependency in order to get the correct JSON responses as
documented in the API documentation (HTML or PDF).
Sometimes, it is useful to customize the prefix for the management endpoints. For example, your
application might already use /actuator for another purpose. You can use the
management.endpoints.web.base-path property to change the prefix for your management endpoint,
as shown in the following example:
management.endpoints.web.base-path=/manage
Unless the management port has been configured to expose endpoints by using a
different HTTP port, management.endpoints.web.base-path is relative to
server.servlet.context-path.
management.endpoints.web.base-path
If management.server.port
is
is
relative
configured,
to
management.server.servlet.context-path.
If you want to map endpoints to a different path, you can use the management.endpoints.web.path-
mapping property.
application.properties
management.endpoints.web.base-path=/
management.endpoints.web.path-mapping.health=healthcheck
Exposing management endpoints by using the default HTTP port is a sensible choice for cloud-
based deployments. If, however, your application runs inside your own data center, you may prefer
to expose endpoints by using a different HTTP port.
You can set the management.server.port property to change the HTTP port, as shown in the following
example:
management.server.port=8081
251
On Cloud Foundry, applications only receive requests on port 8080 for both HTTP
and TCP routing, by default. If you want to use a custom management port on
Cloud Foundry, you will need to explicitly set up the application’s routes to
forward traffic to the custom port.
When configured to use a custom port, the management server can also be configured with its own
SSL by using the various management.server.ssl.* properties. For example, doing so lets a
management server be available over HTTP while the main application uses HTTPS, as shown in
the following property settings:
server.port=8443
server.ssl.enabled=true
server.ssl.key-store=classpath:store.jks
server.ssl.key-password=secret
management.server.port=8080
management.server.ssl.enabled=false
Alternatively, both the main server and the management server can use SSL but with different key
stores, as follows:
server.port=8443
server.ssl.enabled=true
server.ssl.key-store=classpath:main.jks
server.ssl.key-password=secret
management.server.port=8080
management.server.ssl.enabled=true
management.server.ssl.key-store=classpath:management.jks
management.server.ssl.key-password=secret
You can customize the address that the management endpoints are available on by setting the
management.server.address property. Doing so can be useful if you want to listen only on an internal
or ops-facing network or to listen only for connections from localhost.
You can listen on a different address only when the port differs from the main
server port.
The following example application.properties does not allow remote management connections:
management.server.port=8081
management.server.address=127.0.0.1
252
6.3.5. Disabling HTTP Endpoints
If you do not want to expose endpoints over HTTP, you can set the management port to -1, as shown
in the following example:
management.server.port=-1
management.endpoints.web.exposure.exclude=*
The name of the MBean is usually generated from the id of the endpoint. For example, the health
endpoint is exposed as org.springframework.boot:type=Endpoint,name=Health.
If your application contains more than one Spring ApplicationContext, you may find that names
clash. To solve this problem, you can set the spring.jmx.unique-names property to true so that MBean
names are always unique.
You can also customize the JMX domain under which endpoints are exposed. The following settings
show an example of doing so in application.properties:
spring.jmx.unique-names=true
management.endpoints.jmx.domain=com.example.myapp
If you do not want to expose endpoints over JMX, you can set the
management.endpoints.jmx.exposure.exclude property to *, as shown in the following example:
management.endpoints.jmx.exposure.exclude=*
Jolokia is a JMX-HTTP bridge that provides an alternative method of accessing JMX beans. To use
253
Jolokia, include a dependency to org.jolokia:jolokia-core. For example, with Maven, you would
add the following dependency:
<dependency>
<groupId>org.jolokia</groupId>
<artifactId>jolokia-core</artifactId>
</dependency>
Customizing Jolokia
Jolokia has a number of settings that you would traditionally configure by setting servlet
parameters. With Spring Boot, you can use your application.properties file. To do so, prefix the
parameter with management.endpoint.jolokia.config., as shown in the following example:
management.endpoint.jolokia.config.debug=true
Disabling Jolokia
If you use Jolokia but do not want Spring Boot to configure it, set the
management.endpoint.jolokia.enabled property to false, as follows:
management.endpoint.jolokia.enabled=false
6.5. Loggers
Spring Boot Actuator includes the ability to view and configure the log levels of your application at
runtime. You can view either the entire list or an individual logger’s configuration, which is made
up of both the explicitly configured logging level as well as the effective logging level given to it by
the logging framework. These levels can be one of:
• TRACE
• DEBUG
• INFO
• WARN
• ERROR
254
• FATAL
• OFF
• null
To configure a given logger, POST a partial entity to the resource’s URI, as shown in the following
example:
{
"configuredLevel": "DEBUG"
}
To “reset” the specific level of the logger (and use the default configuration
instead), you can pass a value of null as the configuredLevel.
6.6. Metrics
Spring Boot Actuator provides dependency management and auto-configuration for Micrometer, an
application metrics facade that supports numerous monitoring systems, including:
• AppOptics
• Atlas
• Datadog
• Dynatrace
• Elastic
• Ganglia
• Graphite
• Humio
• Influx
• JMX
• KairosDB
• New Relic
• Prometheus
• SignalFx
• Simple (in-memory)
• Stackdriver
• StatsD
255
• Wavefront
Spring Boot auto-configures a composite MeterRegistry and adds a registry to the composite for
each of the supported implementations that it finds on the classpath. Having a dependency on
micrometer-registry-{system} in your runtime classpath is enough for Spring Boot to configure the
registry.
Most registries share common features. For instance, you can disable a particular registry even if
the Micrometer registry implementation is on the classpath. For example, to disable Datadog:
management.metrics.export.datadog.enabled=false
Spring Boot will also add any auto-configured registries to the global static composite registry on
the Metrics class unless you explicitly tell it not to:
management.metrics.use-global-registry=false
You can register any number of MeterRegistryCustomizer beans to further configure the registry,
such as applying common tags, before any meters are registered with the registry:
@Bean
MeterRegistryCustomizer<MeterRegistry> metricsCommonTags() {
return registry -> registry.config().commonTags("region", "us-east-1");
}
You can apply customizations to particular registry implementations by being more specific about
the generic type:
@Bean
MeterRegistryCustomizer<GraphiteMeterRegistry> graphiteMetricsNamingConvention() {
return registry -> registry.config().namingConvention(MY_CUSTOM_CONVENTION);
}
Spring Boot also configures built-in instrumentation that you can control via configuration or
dedicated annotation markers.
256
AppOptics
management.metrics.export.appoptics.api-token=YOUR_TOKEN
Atlas
By default, metrics are exported to Atlas running on your local machine. The location of the Atlas
server to use can be provided using:
management.metrics.export.atlas.uri=https://atlas.example.com:7101/api/v1/publish
Datadog
Datadog registry pushes metrics to datadoghq periodically. To export metrics to Datadog, your API
key must be provided:
management.metrics.export.datadog.api-key=YOUR_KEY
You can also change the interval at which metrics are sent to Datadog:
management.metrics.export.datadog.step=30s
Dynatrace
Dynatrace registry pushes metrics to the configured URI periodically. To export metrics to
Dynatrace, your API token, device ID, and URI must be provided:
management.metrics.export.dynatrace.api-token=YOUR_TOKEN
management.metrics.export.dynatrace.device-id=YOUR_DEVICE_ID
management.metrics.export.dynatrace.uri=YOUR_URI
You can also change the interval at which metrics are sent to Dynatrace:
management.metrics.export.dynatrace.step=30s
Elastic
By default, metrics are exported to Elastic running on your local machine. The location of the
Elastic server to use can be provided using the following property:
257
management.metrics.export.elastic.host=https://elastic.example.com:8086
Ganglia
By default, metrics are exported to Ganglia running on your local machine. The Ganglia server host
and port to use can be provided using:
management.metrics.export.ganglia.host=ganglia.example.com
management.metrics.export.ganglia.port=9649
Graphite
By default, metrics are exported to Graphite running on your local machine. The Graphite server
host and port to use can be provided using:
management.metrics.export.graphite.host=graphite.example.com
management.metrics.export.graphite.port=9004
To take control over this behaviour, define your GraphiteMeterRegistry and supply
your own HierarchicalNameMapper. An auto-configured GraphiteConfig and Clock
beans are provided unless you define your own:
@Bean
public GraphiteMeterRegistry graphiteMeterRegistry(GraphiteConfig config, Clock clock)
{
return new GraphiteMeterRegistry(config, clock, MY_HIERARCHICAL_MAPPER);
}
Humio
By default, the Humio registry pushes metrics to cloud.humio.com periodically. To export metrics to
SaaS Humio, your API token must be provided:
management.metrics.export.humio.api-token=YOUR_TOKEN
You should also configure one or more tags to identify the data source to which metrics will be
pushed:
258
management.metrics.export.humio.tags.alpha=a
management.metrics.export.humio.tags.bravo=b
Influx
By default, metrics are exported to Influx running on your local machine. The location of the Influx
server to use can be provided using:
management.metrics.export.influx.uri=https://influx.example.com:8086
JMX
Micrometer provides a hierarchical mapping to JMX, primarily as a cheap and portable way to view
metrics locally. By default, metrics are exported to the metrics JMX domain. The domain to use can
be provided using:
management.metrics.export.jmx.domain=com.example.app.metrics
To take control over this behaviour, define your JmxMeterRegistry and supply your
own HierarchicalNameMapper. An auto-configured JmxConfig and Clock beans are
provided unless you define your own:
@Bean
public JmxMeterRegistry jmxMeterRegistry(JmxConfig config, Clock clock) {
return new JmxMeterRegistry(config, clock, MY_HIERARCHICAL_MAPPER);
}
KairosDB
By default, metrics are exported to KairosDB running on your local machine. The location of the
KairosDB server to use can be provided using:
management.metrics.export.kairos.uri=https://kairosdb.example.com:8080/api/v1/datapoin
ts
New Relic
New Relic registry pushes metrics to New Relic periodically. To export metrics to New Relic, your
API key and account id must be provided:
259
management.metrics.export.newrelic.api-key=YOUR_KEY
management.metrics.export.newrelic.account-id=YOUR_ACCOUNT_ID
You can also change the interval at which metrics are sent to New Relic:
management.metrics.export.newrelic.step=30s
By default, metrics are published via REST calls but it is also possible to use the Java Agent API if
you have it on the classpath:
management.metrics.export.newrelic.client-provider-type=insights-agent
Finally, you can take full control by defining your own NewRelicClientProvider bean.
Prometheus
Prometheus expects to scrape or poll individual app instances for metrics. Spring Boot provides an
actuator endpoint available at /actuator/prometheus to present a Prometheus scrape with the
appropriate format.
The endpoint is not available by default and must be exposed, see exposing
endpoints for more details.
scrape_configs:
- job_name: 'spring'
metrics_path: '/actuator/prometheus'
static_configs:
- targets: ['HOST:PORT']
For ephemeral or batch jobs which may not exist long enough to be scraped, Prometheus
Pushgateway support can be used to expose their metrics to Prometheus. To enable Prometheus
Pushgateway support, add the following dependency to your project:
<dependency>
<groupId>io.prometheus</groupId>
<artifactId>simpleclient_pushgateway</artifactId>
</dependency>
When the Prometheus Pushgateway dependency is present on the classpath and the
management.metrics.export.prometheus.pushgateway.enabled property is set to true, a
PrometheusPushGatewayManager bean is auto-configured. This manages the pushing of metrics to a
Prometheus Pushgateway.
260
The PrometheusPushGatewayManager can be tuned using properties under
management.metrics.export.prometheus.pushgateway. For advanced configuration, you can also
provide your own PrometheusPushGatewayManager bean.
SignalFx
SignalFx registry pushes metrics to SignalFx periodically. To export metrics to SignalFx, your access
token must be provided:
management.metrics.export.signalfx.access-token=YOUR_ACCESS_TOKEN
You can also change the interval at which metrics are sent to SignalFx:
management.metrics.export.signalfx.step=30s
Simple
Micrometer ships with a simple, in-memory backend that is automatically used as a fallback if no
other registry is configured. This allows you to see what metrics are collected in the metrics
endpoint.
The in-memory backend disables itself as soon as you’re using any of the other available backend.
You can also disable it explicitly:
management.metrics.export.simple.enabled=false
Stackdriver
management.metrics.export.stackdriver.project-id=my-project
You can also change the interval at which metrics are sent to Stackdriver:
management.metrics.export.stackdriver.step=30s
StatsD
The StatsD registry pushes metrics over UDP to a StatsD agent eagerly. By default, metrics are
exported to a StatsD agent running on your local machine. The StatsD agent host and port to use
can be provided using:
261
management.metrics.export.statsd.host=statsd.example.com
management.metrics.export.statsd.port=9125
You can also change the StatsD line protocol to use (default to Datadog):
management.metrics.export.statsd.flavor=etsy
Wavefront
Wavefront registry pushes metrics to Wavefront periodically. If you are exporting metrics to
Wavefront directly, your API token must be provided:
management.metrics.export.wavefront.api-token=YOUR_API_TOKEN
Alternatively, you may use a Wavefront sidecar or an internal proxy set up in your environment
that forwards metrics data to the Wavefront API host:
management.metrics.export.wavefront.uri=proxy://localhost:2878
You can also change the interval at which metrics are sent to Wavefront:
management.metrics.export.wavefront.step=30s
◦ Threads utilization
• CPU metrics
• Log4j2 metrics: record the number of events logged to Log4j2 at each level
• Logback metrics: record the number of events logged to Logback at each level
262
• Uptime metrics: report a gauge for uptime and a fixed gauge representing the application’s
absolute start time
• Tomcat metrics (server.tomcat.mbeanregistry.enabled must be set to true for all Tomcat metrics
to be registered)
@RestController
@Timed ①
public class MyController {
@GetMapping("/api/people")
@Timed(extraTags = { "region", "us-east-1" }) ②
@Timed(value = "all.people", longTask = true) ③
public List<Person> listPeople() { ... }
② A method to enable for an individual endpoint. This is not necessary if you have it on the class,
but can be used to further customize the timer for this particular endpoint.
③ A method with longTask = true to enable a long task timer for the method. Long task timers
require a separate metric name, and can be stacked with a short task timer.
By default, metrics are generated with the name, http.server.requests. The name can be
customized by setting the management.metrics.web.server.request.metric-name property.
By default, Spring MVC-related metrics are tagged with the following information:
Tag Description
exception Simple class name of any exception that was
thrown while handling the request.
method Request’s method (for example, GET or POST)
outcome Request’s outcome based on the status code of
the response. 1xx is INFORMATIONAL, 2xx is
SUCCESS, 3xx is REDIRECTION, 4xx CLIENT_ERROR,
and 5xx is SERVER_ERROR
status Response’s HTTP status code (for example, 200 or
500)
263
Tag Description
uri Request’s URI template prior to variable
substitution, if possible (for example,
/api/person/{id})
To add to the default tags, provide one or more @Beans that implement WebMvcTagsContributor. To
replace the default tags, provide a @Bean that implements WebMvcTagsProvider.
Auto-configuration enables the instrumentation of all requests handled by WebFlux controllers and
functional handlers.
By default, metrics are generated with the name http.server.requests. You can customize the name
by setting the management.metrics.web.server.request.metric-name property.
Tag Description
exception Simple class name of any exception that was
thrown while handling the request.
method Request’s method (for example, GET or POST)
outcome Request’s outcome based on the status code of
the response. 1xx is INFORMATIONAL, 2xx is
SUCCESS, 3xx is REDIRECTION, 4xx CLIENT_ERROR,
and 5xx is SERVER_ERROR
status Response’s HTTP status code (for example, 200 or
500)
uri Request’s URI template prior to variable
substitution, if possible (for example,
/api/person/{id})
To add to the default tags, provide one or more @Beans that implement WebFluxTagsContributor. To
replace the default tags, provide a @Bean that implements WebFluxTagsProvider.
264
@Component
@Path("/api/people")
@Timed ①
public class Endpoint {
@GET
@Timed(extraTags = { "region", "us-east-1" }) ②
@Timed(value = "all.people", longTask = true) ③
public List<Person> listPeople() { ... }
}
② On a method to enable for an individual endpoint. This is not necessary if you have it on the
class, but can be used to further customize the timer for this particular endpoint.
③ On a method with longTask = true to enable a long task timer for the method. Long task timers
require a separate metric name, and can be stacked with a short task timer.
By default, metrics are generated with the name, http.server.requests. The name can be
customized by setting the management.metrics.web.server.request.metric-name property.
By default, Jersey server metrics are tagged with the following information:
Tag Description
exception Simple class name of any exception that was
thrown while handling the request.
method Request’s method (for example, GET or POST)
outcome Request’s outcome based on the status code of
the response. 1xx is INFORMATIONAL, 2xx is
SUCCESS, 3xx is REDIRECTION, 4xx CLIENT_ERROR,
and 5xx is SERVER_ERROR
status Response’s HTTP status code (for example, 200 or
500)
uri Request’s URI template prior to variable
substitution, if possible (for example,
/api/person/{id})
Spring Boot Actuator manages the instrumentation of both RestTemplate and WebClient. For that,
you have to inject the auto-configured builder and use it to create instances:
It is also possible to apply manually the customizers responsible for this instrumentation, namely
265
MetricsRestTemplateCustomizer and MetricsWebClientCustomizer.
By default, metrics are generated with the name, http.client.requests. The name can be
customized by setting the management.metrics.web.client.request.metric-name property.
By default, metrics generated by an instrumented client are tagged with the following information:
Tag Description
clientName Host portion of the URI
method Request’s method (for example, GET or POST)
outcome Request’s outcome based on the status code of
the response. 1xx is INFORMATIONAL, 2xx is
SUCCESS, 3xx is REDIRECTION, 4xx CLIENT_ERROR,
and 5xx is SERVER_ERROR, UNKNOWN otherwise
status Response’s HTTP status code if available (for
example, 200 or 500), or IO_ERROR in case of I/O
issues, CLIENT_ERROR otherwise
uri Request’s URI template prior to variable
substitution, if possible (for example,
/api/person/{id})
To customize the tags, and depending on your choice of client, you can provide a @Bean that
implements RestTemplateExchangeTagsProvider or WebClientExchangeTagsProvider. There are
convenience static functions in RestTemplateExchangeTags and WebClientExchangeTags.
Cache Metrics
Auto-configuration enables the instrumentation of all available Caches on startup with metrics
prefixed with cache. Cache instrumentation is standardized for a basic set of metrics. Additional,
cache-specific metrics are also available.
• Caffeine
• EhCache 2
• Hazelcast
Metrics are tagged by the name of the cache and by the name of the CacheManager that is derived
from the bean name.
Only caches that are configured on startup are bound to the registry. For caches
not defined in the cache’s configuration, e.g. caches created on-the-fly or
programmatically after the startup phase, an explicit registration is required. A
CacheMetricsRegistrar bean is made available to make that process easier.
266
DataSource Metrics
Auto-configuration enables the instrumentation of all available DataSource objects with metrics
prefixed with jdbc.connections. Data source instrumentation results in gauges representing the
currently active, idle, maximum allowed, and minimum allowed connections in the pool.
Metrics are also tagged by the name of the DataSource computed based on the bean name.
By default, Spring Boot provides metadata for all supported data sources; you can
add additional DataSourcePoolMetadataProvider beans if your favorite data source
isn’t supported out of the box. See DataSourcePoolMetadataProvidersConfiguration
for examples.
Also, Hikari-specific metrics are exposed with a hikaricp prefix. Each metric is tagged by the name
of the Pool (can be controlled with spring.datasource.name).
Hibernate Metrics
Metrics are also tagged by the name of the EntityManagerFactory that is derived from the bean
name.
To enable statistics, the standard JPA property hibernate.generate_statistics must be set to true.
You can enable that on the auto-configured EntityManagerFactory as shown in the following
example:
spring.jpa.properties.hibernate.generate_statistics=true
RabbitMQ Metrics
Auto-configuration will enable the instrumentation of all available RabbitMQ connection factories
with a metric named rabbitmq.
Kafka Metrics
To register custom metrics, inject MeterRegistry into your component, as shown in the following
example:
267
class Dictionary {
Dictionary(MeterRegistry registry) {
registry.gaugeCollectionSize("dictionary.size", Tags.empty(), this.words);
}
// …
If your metrics depend on other beans, it is recommended that you use a MeterBinder to register
them, as shown in the following example:
@Bean
MeterBinder queueSize(Queue queue) {
return (registry) -> Gauge.builder("queueSize", queue::size).register(registry);
}
Using a MeterBinder ensures that the correct dependency relationships are set up and that the bean
is available when the metric’s value is retrieved. A MeterBinder implementation can also be useful if
you find that you repeatedly instrument a suite of metrics across components or applications.
By default, metrics from all MeterBinder beans will be automatically bound to the
Spring-managed MeterRegistry.
If you need to apply customizations to specific Meter instances you can use the
io.micrometer.core.instrument.config.MeterFilter interface.
For example, if you want to rename the mytag.region tag to mytag.area for all meter IDs beginning
with com.example, you can do the following:
@Bean
public MeterFilter renameRegionTagMeterFilter() {
return MeterFilter.renameTag("com.example", "mytag.region", "mytag.area");
}
268
Common tags
Common tags are generally used for dimensional drill-down on the operating environment like
host, instance, region, stack, etc. Commons tags are applied to all meters and can be configured as
shown in the following example:
management.metrics.tags.region=us-east-1
management.metrics.tags.stack=prod
The example above adds region and stack tags to all meters with a value of us-east-1 and prod
respectively.
The order of common tags is important if you are using Graphite. As the order of
common tags cannot be guaranteed using this approach, Graphite users are
advised to define a custom MeterFilter instead.
Per-meter properties
In addition to MeterFilter beans, it’s also possible to apply a limited set of customization on a per-
meter basis using properties. Per-meter customizations apply to any all meter IDs that start with
the given name. For example, the following will disable any meters that have an ID starting with
example.remote
management.metrics.enable.example.remote=false
Property Description
management.metrics.enable Whether to deny meters from emitting any
metrics.
management.metrics.distribution.percentiles- Whether to publish a histogram suitable for
histogram computing aggregable (across dimension)
percentile approximations.
management.metrics.distribution.minimum- Publish less histogram buckets by clamping the
expected-value, range of expected values.
management.metrics.distribution.maximum-
expected-value
management.metrics.distribution.percentiles Publish percentile values computed in your
application
management.metrics.distribution.slo Publish a cumulative histogram with buckets
defined by your service-level objectives.
For more details on concepts behind percentiles-histogram, percentiles and slo refer to the
"Histograms and percentiles" section of the micrometer documentation.
269
6.6.6. Metrics endpoint
Spring Boot provides a metrics endpoint that can be used diagnostically to examine the metrics
collected by an application. The endpoint is not available by default and must be exposed, see
exposing endpoints for more details.
Navigating to /actuator/metrics displays a list of available meter names. You can drill down to view
information about a particular meter by providing its name as a selector, e.g.
/actuator/metrics/jvm.memory.max.
The name you use here should match the name used in the code, not the name
after it has been naming-convention normalized for a monitoring system it is
shipped to. In other words, if jvm.memory.max appears as jvm_memory_max in
Prometheus because of its snake case naming convention, you should still use
jvm.memory.max as the selector when inspecting the meter in the metrics endpoint.
You can also add any number of tag=KEY:VALUE query parameters to the end of the URL to
dimensionally drill down on a meter, e.g. /actuator/metrics/jvm.memory.max?tag=area:nonheap.
The reported measurements are the sum of the statistics of all meters matching the
meter name and any tags that have been applied. So in the example above, the
returned "Value" statistic is the sum of the maximum memory footprints of "Code
Cache", "Compressed Class Space", and "Metaspace" areas of the heap. If you only
wanted to see the maximum size for the "Metaspace", you could add an additional
tag=id:Metaspace, i.e.
/actuator/metrics/jvm.memory.max?tag=area:nonheap&tag=id:Metaspace.
6.7. Auditing
Once Spring Security is in play, Spring Boot Actuator has a flexible audit framework that publishes
events (by default, “authentication success”, “failure” and “access denied” exceptions). This feature
can be very useful for reporting and for implementing a lock-out policy based on authentication
failures.
To customize published security events, you can provide your own implementations of
AbstractAuthenticationAuditListener and AbstractAuthorizationAuditListener.
You can also use the audit services for your own business events. To do so, either inject the
AuditEventRepository bean into your own components and use that directly or publish an
AuditApplicationEvent with the Spring ApplicationEventPublisher (by implementing
270
ApplicationEventPublisherAware).
The httptrace endpoint can be used to obtain information about the request-response exchanges
that are stored in the HttpTraceRepository.
To customize the items that are included in each trace, use the management.trace.http.include
configuration property. For advanced customization, consider registering your own
HttpExchangeTracer implementation.
• ApplicationPidFileWriter creates a file containing the application PID (by default, in the
application directory with a file name of application.pid).
• WebServerPortFileWriter creates a file (or files) containing the ports of the running web server
(by default, in the application directory with a file name of application.port).
By default, these writers are not activated, but you can enable:
• By Extending Configuration
• Programmatically
In the META-INF/spring.factories file, you can activate the listener(s) that writes a PID file, as shown
in the following example:
org.springframework.context.ApplicationListener=\
org.springframework.boot.context.ApplicationPidFileWriter,\
org.springframework.boot.web.context.WebServerPortFileWriter
271
6.9.2. Programmatically
You can also activate a listener by invoking the SpringApplication.addListeners(…) method and
passing the appropriate Writer object. This method also lets you customize the file name and path
in the Writer constructor.
The extended support lets Cloud Foundry management UIs (such as the web application that you
can use to view deployed applications) be augmented with Spring Boot actuator information. For
example, an application status page may include full health information instead of the typical
“running” or “stopped” status.
If you want to fully disable the /cloudfoundryapplication endpoints, you can add the following
setting to your application.properties file:
application.properties
management.cloudfoundry.enabled=false
By default, the security verification for /cloudfoundryapplication endpoints makes SSL calls to
various Cloud Foundry services. If your Cloud Foundry UAA or Cloud Controller services use self-
signed certificates, you need to set the following property:
application.properties
management.cloudfoundry.skip-ssl-validation=true
If the server’s context-path has been configured to anything other than /, the Cloud Foundry
endpoints will not be available at the root of the application. For example, if
server.servlet.context-path=/app, Cloud Foundry endpoints will be available at
/app/cloudfoundryapplication/*.
272
regardless of the server’s context-path, you will need to explicitly configure that in your
application. The configuration will differ depending on the web server in use. For Tomcat, the
following configuration can be added:
@Bean
public TomcatServletWebServerFactory servletWebServerFactory() {
return new TomcatServletWebServerFactory() {
@Override
protected void prepareContext(Host host, ServletContextInitializer[]
initializers) {
super.prepareContext(host, initializers);
StandardContext child = new StandardContext();
child.addLifecycleListener(new Tomcat.FixContextListener());
child.setPath("/cloudfoundryapplication");
ServletContainerInitializer initializer =
getServletContextInitializer(getContextPath());
child.addServletContainerInitializer(initializer, Collections.emptySet());
child.setCrossContext(true);
host.addChild(child);
}
};
}
@Override
public void service(ServletRequest req, ServletResponse res) throws
ServletException, IOException {
ServletContext context =
req.getServletContext().getContext(contextPath);
context.getRequestDispatcher("/cloudfoundryapplication").forward(req,
res);
}
};
context.addServlet("cloudfoundry", servlet).addMapping("/*");
};
}
Otherwise, you can continue on, to read about ‘deployment options’ or jump ahead for some in-
depth information about Spring Boot’s build tool plugins.
273
Chapter 7. Deploying Spring Boot
Applications
Spring Boot’s flexible packaging options provide a great deal of choice when it comes to deploying
your application. You can deploy Spring Boot applications to a variety of cloud platforms, to
container images (such as Docker), or to virtual/real machines.
This is actually slightly faster on startup (depending on the size of the jar) than running from an
unexploded archive. At runtime you shouldn’t expect any differences.
Once you have unpacked the jar file, you can also get an extra boost to startup time by running the
app with its "natural" main method instead of the JarLauncher. For example:
Using the JarLauncher over the application’s main method has the added benefit of
a predictable classpath order. The jar contains a classpath.idx file which is used
by the JarLauncher when constructing the classpath.
More efficient container images can also be created by creating separate layers for your
dependencies and application classes and resources (which normally change more frequently).
Two popular cloud providers, Heroku and Cloud Foundry, employ a “buildpack” approach. The
buildpack wraps your deployed code in whatever is needed to start your application. It might be a
274
JDK and a call to java, an embedded web server, or a full-fledged application server. A buildpack is
pluggable, but ideally you should be able to get by with as few customizations to it as possible. This
reduces the footprint of functionality that is not under your control. It minimizes divergence
between development and production environments.
Ideally, your application, like a Spring Boot executable jar, has everything that it needs to run
packaged within it.
In this section, we look at what it takes to get the application that we developed in the “Getting
Started” section up and running in the Cloud.
Cloud Foundry provides default buildpacks that come into play if no other buildpack is specified.
The Cloud Foundry Java buildpack has excellent support for Spring applications, including Spring
Boot. You can deploy stand-alone executable jar applications as well as traditional .war packaged
applications.
Once you have built your application (by using, for example, mvn clean package) and have installed
the cf command line tool, deploy your application by using the cf push command, substituting the
path to your compiled .jar. Be sure to have logged in with your cf command line client before
pushing an application. The following line shows using the cf push command to deploy an
application:
See the cf push documentation for more options. If there is a Cloud Foundry manifest.yml file
present in the same directory, it is considered.
At this point, cf starts uploading your application, producing output similar to the following
example:
275
Uploading acloudyspringtime... OK
Preparing to start acloudyspringtime... OK
-----> Downloaded app package (8.9M)
-----> Java Buildpack Version: v3.12 (offline) | https://github.com/cloudfoundry/java-
buildpack.git#6f25b7e
-----> Downloading Open Jdk JRE 1.8.0_121 from https://java-
buildpack.cloudfoundry.org/openjdk/trusty/x86_64/openjdk-1.8.0_121.tar.gz (found in
cache)
Expanding Open Jdk JRE to .java-buildpack/open_jdk_jre (1.6s)
-----> Downloading Open JDK Like Memory Calculator 2.0.2_RELEASE from https://java-
buildpack.cloudfoundry.org/memory-calculator/trusty/x86_64/memory-calculator-
2.0.2_RELEASE.tar.gz (found in cache)
Memory Settings: -Xss349K -Xmx681574K -XX:MaxMetaspaceSize=104857K -Xms681574K
-XX:MetaspaceSize=104857K
-----> Downloading Container Certificate Trust Store 1.0.0_RELEASE from https://java-
buildpack.cloudfoundry.org/container-certificate-trust-store/container-certificate-
trust-store-1.0.0_RELEASE.jar (found in cache)
Adding certificates to .java-
buildpack/container_certificate_trust_store/truststore.jks (0.6s)
-----> Downloading Spring Auto Reconfiguration 1.10.0_RELEASE from https://java-
buildpack.cloudfoundry.org/auto-reconfiguration/auto-reconfiguration-
1.10.0_RELEASE.jar (found in cache)
Checking status of app 'acloudyspringtime'...
0 of 1 instances running (1 starting)
...
0 of 1 instances running (1 starting)
...
0 of 1 instances running (1 starting)
...
1 of 1 instances running (1 running)
App started
Once your application is live, you can verify the status of the deployed application by using the cf
apps command, as shown in the following example:
$ cf apps
Getting applications in ...
OK
276
Once Cloud Foundry acknowledges that your application has been deployed, you should be able to
find the application at the URI given. In the preceding example, you could find it at
https://acloudyspringtime.cfapps.io/.
Binding to Services
By default, metadata about the running application as well as service connection information is
exposed to the application as environment variables (for example: $VCAP_SERVICES). This
architecture decision is due to Cloud Foundry’s polyglot (any language and platform can be
supported as a buildpack) nature. Process-scoped environment variables are language agnostic.
Environment variables do not always make for the easiest API, so Spring Boot automatically
extracts them and flattens the data into properties that can be accessed through Spring’s
Environment abstraction, as shown in the following example:
@Component
class MyBean implements EnvironmentAware {
@Override
public void setEnvironment(Environment environment) {
this.instanceId = environment.getProperty("vcap.application.instance_id");
}
// ...
All Cloud Foundry properties are prefixed with vcap. You can use vcap properties to access
application information (such as the public URL of the application) and service information (such
as database credentials). See the ‘CloudFoundryVcapEnvironmentPostProcessor’ Javadoc for
complete details.
The Java CFEnv project is a better fit for tasks such as configuring a DataSource.
7.2.2. Kubernetes
Spring Boot auto-detects Kubernetes deployment environments by checking the environment for
"*_SERVICE_HOST" and "*_SERVICE_PORT" variables. You can override this detection with the
spring.main.cloud-platform configuration property.
Spring Boot helps you to manage the state of your application and export it with HTTP Kubernetes
Probes using Actuator.
When Kubernetes deletes an application instance, the shutdown process involves several
subsystems concurrently: shutdown hooks, unregistering the service, removing the instance from
277
the load-balancer… Because this shutdown processing happens in parallel (and due to the nature of
distributed systems), there is a window during which traffic can be routed to a pod that has also
begun its shutdown processing.
You can configure a sleep execution in a preStop handler to avoid requests being routed to a pod
that has already begun shutting down. This sleep should be long enough for new requests to stop
being routed to the pod and its duration will vary from deployment to deployment. The preStop
handler can be configured via the PodSpec in the pod’s configuration file as follows:
spec:
containers:
- name: example-container
image: example-image
lifecycle:
preStop:
exec:
command: ["sh", "-c", "sleep 10"]
Once the pre-stop hook has completed, SIGTERM will be sent to the container and graceful
shutdown will begin, allowing any remaining in-flight requests to complete.
When Kubernetes sends a SIGTERM signal to the pod, it waits for a specified time
called the termination grace period (the default for which is 30 seconds). If the
containers are still running after the grace period, they are sent the SIGKILL signal
and forcibly removed. If the pod takes longer than 30 seconds to shut down, which
could be because you’ve increased spring.lifecycle.timeout-per-shutdown-phase,
make sure to increase the termination grace period by setting the
terminationGracePeriodSeconds option in the Pod YAML.
7.2.3. Heroku
Heroku is another popular PaaS platform. To customize Heroku builds, you provide a Procfile,
which provides the incantation required to deploy an application. Heroku assigns a port for the
Java application to use and then ensures that routing to the external URI works.
You must configure your application to listen on the correct port. The following example shows the
Procfile for our starter REST application:
Spring Boot makes -D arguments available as properties accessible from a Spring Environment
instance. The server.port configuration property is fed to the embedded Tomcat, Jetty, or Undertow
instance, which then uses the port when it starts up. The $PORT environment variable is assigned to
us by the Heroku PaaS.
This should be everything you need. The most common deployment workflow for Heroku
deployments is to git push the code to production, as shown in the following example:
278
$ git push heroku main
To git@heroku.com:agile-sierra-1405.git
* [new branch] main -> main
Your application should now be up and running on Heroku. For more details, refer to Deploying
Spring Boot Applications to Heroku.
7.2.4. OpenShift
OpenShift has many resources describing how to deploy Spring Boot applications, including:
• Architecture guide
279
• Running as a traditional web application on Wildfly
Amazon Web Services offers multiple ways to install Spring Boot-based applications, either as
traditional web applications (war) or as executable jar files with an embedded web server. The
options include:
Each has different features and pricing models. In this document, we describe to approach using
AWS Elastic Beanstalk.
As described in the official Elastic Beanstalk Java guide, there are two main options to deploy a Java
application. You can either use the “Tomcat Platform” or the “Java SE platform”.
This option applies to Spring Boot projects that produce a war file. No special configuration is
required. You need only follow the official guide.
This option applies to Spring Boot projects that produce a jar file and run an embedded web
container. Elastic Beanstalk environments run an nginx instance on port 80 to proxy the actual
application, running on port 5000. To configure it, add the following line to your
application.properties file:
server.port=5000
280
Reduce costs by setting the environment type
By default an Elastic Beanstalk environment is load balanced. The load balancer
has a significant cost. To avoid that cost, set the environment type to “Single
instance”, as described in the Amazon documentation. You can also create single
instance environments by using the CLI and the following command:
eb create -s
Summary
This is one of the easiest ways to get to AWS, but there are more things to cover, such as how to
integrate Elastic Beanstalk into any CI / CD tool, use the Elastic Beanstalk Maven plugin instead of
the CLI, and others. There is a blog post covering these topics more in detail.
Boxfuse works by turning your Spring Boot executable jar or war into a minimal VM image that can
be deployed unchanged either on VirtualBox or on AWS. Boxfuse comes with deep integration for
Spring Boot and uses the information from your Spring Boot configuration file to automatically
configure ports and health check URLs. Boxfuse leverages this information both for the images it
produces as well as for all the resources it provisions (instances, security groups, elastic load
balancers, and so on).
Once you have created a Boxfuse account, connected it to your AWS account, installed the latest
version of the Boxfuse Client, and ensured that the application has been built by Maven or Gradle
(by using, for example, mvn clean package), you can deploy your Spring Boot application to AWS
with a command similar to the following:
See the boxfuse run documentation for more options. If there is a boxfuse.conf file present in the
current directory, it is considered.
At this point, boxfuse creates an image for your application, uploads it, and configures and starts
the necessary resources on AWS, resulting in output similar to the following example:
281
Fusing Image for myapp-1.0.jar ...
Image fused in 00:06.838s (53937 K) -> axelfontaine/myapp:1.0
Creating axelfontaine/myapp ...
Pushing axelfontaine/myapp:1.0 ...
Verifying axelfontaine/myapp:1.0 ...
Creating Elastic IP ...
Mapping myapp-axelfontaine.boxfuse.io to 52.28.233.167 ...
Waiting for AWS to create an AMI for axelfontaine/myapp:1.0 in eu-central-1 (this may
take up to 50 seconds) ...
AMI created in 00:23.557s -> ami-d23f38cf
Creating security group boxfuse-sg_axelfontaine/myapp:1.0 ...
Launching t2.micro instance of axelfontaine/myapp:1.0 (ami-d23f38cf) in eu-central-1
...
Instance launched in 00:30.306s -> i-92ef9f53
Waiting for AWS to boot Instance i-92ef9f53 and Payload to start at
https://52.28.235.61/ ...
Payload started in 00:29.266s -> https://52.28.235.61/
Remapping Elastic IP 52.28.233.167 to i-92ef9f53 ...
Waiting 15s for AWS to complete Elastic IP Zero Downtime transition ...
Deployment completed successfully. axelfontaine/myapp:1.0 is up and running at
https://myapp-axelfontaine.boxfuse.io/
See the blog post on deploying Spring Boot apps on EC2 as well as the documentation for the
Boxfuse Spring Boot integration to get started with a Maven build to run the app.
Google Cloud has several options that can be used to launch Spring Boot applications. The easiest to
get started with is probably App Engine, but you could also find ways to run Spring Boot in a
container with Container Engine or on a virtual machine with Compute Engine.
To run in App Engine, you can create a project in the UI first, which sets up a unique identifier for
you and also sets up HTTP routes. Add a Java app to the project and leave it empty and then use the
Google Cloud SDK to push your Spring Boot app into that slot from the command line or CI build.
App Engine Standard requires you to use WAR packaging. Follow these steps to deploy App Engine
Standard application to Google Cloud.
Alternatively, App Engine Flex requires you to create an app.yaml file to describe the resources your
app requires. Normally, you put this file in src/main/appengine, and it should resemble the following
file:
282
service: default
runtime: java
env: flex
runtime_config:
jdk: openjdk8
handlers:
- url: /.*
script: this field is required, but ignored
manual_scaling:
instances: 1
health_check:
enable_health_check: False
env_variables:
ENCRYPT_KEY: your_encryption_key_here
You can deploy the app (for example, with a Maven plugin) by adding the project ID to the build
configuration, as shown in the following example:
<plugin>
<groupId>com.google.cloud.tools</groupId>
<artifactId>appengine-maven-plugin</artifactId>
<version>1.3.0</version>
<configuration>
<project>myproject</project>
</configuration>
</plugin>
Then deploy with mvn appengine:deploy (if you need to authenticate first, the build fails).
283
Fully executable jars work by embedding an extra script at the front of the file.
Currently, some tools do not accept this format, so you may not always be able to
use this technique. For example, jar -xf may silently fail to extract a jar or war
that has been made fully executable. It is recommended that you make your jar or
war fully executable only if you intend to execute it directly, rather than running it
with java -jar or deploying it to a servlet container.
To create a ‘fully executable’ jar with Maven, use the following plugin configuration:
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<executable>true</executable>
</configuration>
</plugin>
bootJar {
launchScript()
}
You can then run your application by typing ./my-application.jar (where my-application is the
name of your artifact). The directory containing the jar is used as your application’s working
directory.
The default script supports most Linux distributions and is tested on CentOS and Ubuntu. Other
platforms, such as OS X and FreeBSD, require the use of a custom embeddedLaunchScript.
Spring Boot application can be easily started as Unix/Linux services by using either init.d or
systemd.
If you configured Spring Boot’s Maven or Gradle plugin to generate a fully executable jar, and you
do not use a custom embeddedLaunchScript, your application can be used as an init.d service. To do
284
so, symlink the jar to init.d to support the standard start, stop, restart, and status commands.
• Starts the services as the user that owns the jar file
Assuming that you have a Spring Boot application installed in /var/myapp, to install a Spring Boot
application as an init.d service, create a symlink, as follows:
Once installed, you can start and stop the service in the usual way. For example, on a Debian-based
system, you could start it with the following command:
You can also flag the application to start automatically by using your standard operating system
tools. For example, on Debian, you could use the following command:
The following is a set of guidelines on how to secure a Spring Boot application that
runs as an init.d service. It is not intended to be an exhaustive list of everything
that should be done to harden an application and the environment in which it
runs.
When executed as root, as is the case when root is being used to start an init.d service, the default
executable script runs the application as the user specified in the RUN_AS_USER environment
variable. When the environment variable is not set, the user who owns the jar file is used instead.
You should never run a Spring Boot application as root, so RUN_AS_USER should never be root and
your application’s jar file should never be owned by root. Instead, create a specific user to run your
application and set the RUN_AS_USER environment variable or use chown to make it the owner of the
jar file, as shown in the following example:
In this case, the default executable script runs the application as the bootapp user.
285
To reduce the chances of the application’s user account being compromised, you
should consider preventing it from using a login shell. For example, you can set the
account’s shell to /usr/sbin/nologin.
You should also take steps to prevent the modification of your application’s jar file. Firstly,
configure its permissions so that it cannot be written and can only be read or executed by its
owner, as shown in the following example:
Second, you should also take steps to limit the damage if your application or the account that’s
running it is compromised. If an attacker does gain access, they could make the jar file writable and
change its contents. One way to protect against this is to make it immutable by using chattr, as
shown in the following example:
This will prevent any user, including root, from modifying the jar.
If root is used to control the application’s service and you use a .conf file to customize its startup,
the .conf file is read and evaluated by the root user. It should be secured accordingly. Use chmod so
that the file can only be read by the owner and use chown to make root the owner, as shown in the
following example:
systemd is the successor of the System V init system and is now being used by many modern Linux
distributions. Although you can continue to use init.d scripts with systemd, it is also possible to
launch Spring Boot applications by using systemd ‘service’ scripts.
Assuming that you have a Spring Boot application installed in /var/myapp, to install a Spring Boot
application as a systemd service, create a script named myapp.service and place it in
/etc/systemd/system directory. The following script offers an example:
286
[Unit]
Description=myapp
After=syslog.target
[Service]
User=myapp
ExecStart=/var/myapp/myapp.jar
SuccessExitStatus=143
[Install]
WantedBy=multi-user.target
Remember to change the Description, User, and ExecStart fields for your
application.
The ExecStart field does not declare the script action command, which means that
the run command is used by default.
Note that, unlike when running as an init.d service, the user that runs the application, the PID file,
and the console log file are managed by systemd itself and therefore must be configured by using
appropriate fields in the ‘service’ script. Consult the service unit configuration man page for more
details.
To flag the application to start automatically on system boot, use the following command:
The default embedded startup script written by the Maven or Gradle plugin can be customized in a
number of ways. For most people, using the default script along with a few customizations is
usually enough. If you find you cannot customize something that you need to, use the
embeddedLaunchScript option to write your own file entirely.
It often makes sense to customize elements of the start script as it is written into the jar file. For
example, init.d scripts can provide a “description”. Since you know the description up front (and it
need not change), you may as well provide it when the jar is generated.
To customize written elements, use the embeddedLaunchScriptProperties option of the Spring Boot
Maven plugin or the properties property of the Spring Boot Gradle plugin’s launchScript.
The following property substitutions are supported with the default script:
287
Name Description Gradle default Maven default
mode The script mode. auto auto
288
Name Description Gradle default Maven default
pidFilen Default value for the name
ame of the PID file in PID_FOLDER.
Only valid for an init.d
service
useStart Whether the start-stop- true true
StopDaem daemon command, when it’s
on
available, should be used to
control the process
stopWait Default value for 60 60
Time STOP_WAIT_TIME in seconds.
Only valid for an init.d
service
For items of the script that need to be customized after the jar has been written, you can use
environment variables or a config file.
The following environment properties are supported with the default script:
Variable Description
MODE The “mode” of operation. The default depends on the way the jar was built but is
usually auto (meaning it tries to guess if it is an init script by checking if it is a
symlink in a directory called init.d). You can explicitly set it to service so that the
stop|start|status|restart commands work or to run if you want to run the script in
the foreground.
RUN_AS_USER The user that will be used to run the application. When not set, the user that owns
the jar file will be used.
USE_START_ST Whether the start-stop-daemon command, when it’s available, should be used to
OP_DAEMON control the process. Defaults to true.
PID_FOLDER The root name of the pid folder (/var/run by default).
LOG_FOLDER The name of the folder in which to put log files (/var/log by default).
CONF_FOLDER The name of the folder from which to read .conf files (same folder as jar-file by
default).
LOG_FILENAME The name of the log file in the LOG_FOLDER (<appname>.log by default).
APP_NAME The name of the app. If the jar is run from a symlink, the script guesses the app
name. If it is not a symlink or you want to explicitly set the app name, this can be
useful.
RUN_ARGS The arguments to pass to the program (the Spring Boot app).
JAVA_HOME The location of the java executable is discovered by using the PATH by default, but
you can set it explicitly if there is an executable file at $JAVA_HOME/bin/java.
289
Variable Description
JAVA_OPTS Options that are passed to the JVM when it is launched.
JARFILE The explicit location of the jar file, in case the script is being used to launch a jar
that it is not actually embedded.
DEBUG If not empty, sets the -x flag on the shell process, allowing you to see the logic in the
script.
STOP_WAIT_TI The time in seconds to wait when stopping the application before forcing a
ME shutdown (60 by default).
The PID_FOLDER, LOG_FOLDER, and LOG_FILENAME variables are only valid for an init.d
service. For systemd, the equivalent customizations are made by using the ‘service’
script. See the service unit configuration man page for more details.
With the exception of JARFILE and APP_NAME, the settings listed in the preceding section can be
configured by using a .conf file. The file is expected to be next to the jar file and have the same
name but suffixed with .conf rather than .jar. For example, a jar named /var/myapp/myapp.jar uses
the configuration file named /var/myapp/myapp.conf, as shown in the following example:
myapp.conf
JAVA_OPTS=-Xmx1024M
LOG_FOLDER=/custom/log/folder
If you do not like having the config file next to the jar file, you can set a CONF_FOLDER
environment variable to customize the location of the config file.
To learn about securing this file appropriately, see the guidelines for securing an init.d service.
A (separately maintained sample) describes step-by-step how you can create a Windows service for
your Spring Boot application.
The next section goes on to cover the Spring Boot CLI, or you can jump ahead to read about build
tool plugins.
290
Chapter 8. Spring Boot CLI
The Spring Boot CLI is a command line tool that you can use if you want to quickly develop a Spring
application. It lets you run Groovy scripts, which means that you have a familiar Java-like syntax
without so much boilerplate code. You can also bootstrap a new project or write your own
command for it.
$ spring
usage: spring [--help] [--version]
<command> [<args>]
You can type spring help to get more details about any of the supported commands, as shown in the
following example:
291
$ spring help run
spring run - Run a spring groovy script
Option Description
------ -----------
--autoconfigure [Boolean] Add autoconfigure compiler
transformations (default: true)
--classpath, -cp Additional classpath entries
--no-guess-dependencies Do not attempt to guess dependencies
--no-guess-imports Do not attempt to guess imports
-q, --quiet Quiet logging
-v, --verbose Verbose logging of dependency
resolution
--watch Watch the specified file for changes
The version command provides a quick way to check which version of Spring Boot you are using, as
follows:
$ spring version
Spring CLI v2.3.12.RELEASE
You can compile and run Groovy source code by using the run command. The Spring Boot CLI is
completely self-contained, so you do not need any external Groovy installation.
The following example shows a “hello world” web application written in Groovy:
hello.groovy
@RestController
class WebApplication {
@RequestMapping("/")
String home() {
"Hello World!"
}
292
To pass command-line arguments to the application, use -- to separate the commands from the
“spring” command arguments, as shown in the following example:
To set JVM command line arguments, you can use the JAVA_OPTS environment variable, as shown in
the following example:
When setting JAVA_OPTS on Microsoft Windows, make sure to quote the entire
instruction, such as set "JAVA_OPTS=-Xms256m -Xmx2048m". Doing so ensures the
values are properly passed to the process.
Standard Groovy includes a @Grab annotation, which lets you declare dependencies on third-party
libraries. This useful technique lets Groovy download jars in the same way as Maven or Gradle
would but without requiring you to use a build tool.
Spring Boot extends this technique further and tries to deduce which libraries to “grab” based on
your code. For example, since the WebApplication code shown previously uses @RestController
annotations, Spring Boot grabs "Tomcat" and "Spring MVC".
Items Grabs
293
Deduced “grab” Coordinates
Spring Boot extends Groovy’s standard @Grab support by letting you specify a dependency without a
group or version (for example, @Grab('freemarker')). Doing so consults Spring Boot’s default
dependency metadata to deduce the artifact’s group and version.
The default metadata is tied to the version of the CLI that you use. It changes only
when you move to a new version of the CLI, putting you in control of when the
versions of your dependencies may change. A table showing the dependencies and
their versions that are included in the default metadata can be found in the
appendix.
To help reduce the size of your Groovy code, several import statements are automatically included.
Notice how the preceding example refers to @Component, @RestController, and @RequestMapping
without needing to use fully-qualified names or import statements.
Many Spring annotations work without using import statements. Try running your
application to see what fails before adding imports.
Unlike the equivalent Java application, you do not need to include a public static void
main(String[] args) method with your Groovy scripts. A SpringApplication is automatically created,
with your compiled code acting as the source.
By default, the CLI uses the dependency management declared in spring-boot-dependencies when
resolving @Grab dependencies. Additional dependency management, which overrides the default
dependency management, can be configured by using the @DependencyManagementBom annotation. The
annotation’s value should specify the coordinates (groupId:artifactId:version) of one or more
Maven BOMs.
@DependencyManagementBom("com.example.custom-bom:1.0.0")
When you specify multiple BOMs, they are applied in the order in which you declare them, as
shown in the following example:
@DependencyManagementBom(["com.example.custom-bom:1.0.0",
"com.example.another-bom:1.0.0"])
294
The preceding example indicates that the dependency management in another-bom overrides the
dependency management in custom-bom.
You can use @DependencyManagementBom anywhere that you can use @Grab. However, to ensure
consistent ordering of the dependency management, you can use @DependencyManagementBom at most
once in your application.
You can use “shell globbing” with all commands that accept file input. Doing so lets you use
multiple files from a single directory, as shown in the following example:
You can use the jar command to package your application into a self-contained executable jar file,
as shown in the following example:
The resulting jar contains the classes produced by compiling the application and all of the
application’s dependencies so that it can then be run by using java -jar. The jar file also contains
entries from the application’s classpath. You can add and remove explicit paths to the jar by using
--include and --exclude. Both are comma-separated, and both accept prefixes, in the form of “+”
and “-”, to signify that they should be removed from the defaults. The default includes are as
follows:
Type spring help jar on the command line for more information.
The init command lets you create a new project by using start.spring.io without leaving the shell,
as shown in the following example:
295
The preceding example creates a my-project directory with a Maven-based project that uses spring-
boot-starter-web and spring-boot-starter-data-jpa. You can list the capabilities of the service by
using the --list flag, as shown in the following example:
Available dependencies:
-----------------------
actuator - Actuator: Production ready features to help you monitor and manage your
application
...
web - Web: Support for full-stack web development, including Tomcat and spring-webmvc
websocket - Websocket: Support for WebSocket development
ws - WS: Support for Spring Web Services
...
The init command supports many options. See the help output for more details. For instance, the
following command creates a Gradle project that uses Java 8 and war packaging:
Spring Boot includes command-line completion scripts for the BASH and zsh shells. If you do not
use either of these shells (perhaps you are a Windows user), you can use the shell command to
launch an integrated shell, as shown in the following example:
$ spring shell
Spring Boot (v2.3.12.RELEASE)
Hit TAB to complete. Type \'help' and hit RETURN for help, and \'exit' to quit.
From inside the embedded shell, you can run other commands directly:
296
$ version
Spring CLI v2.3.12.RELEASE
The embedded shell supports ANSI color output as well as tab completion. If you need to run a
native command, you can use the ! prefix. To exit the embedded shell, press ctrl-c.
You can add extensions to the CLI by using the install command. The command takes one or more
sets of artifact coordinates in the format group:artifact:version, as shown in the following
example:
In addition to installing the artifacts identified by the coordinates you supply, all of the artifacts'
dependencies are also installed.
To uninstall a dependency, use the uninstall command. As with the install command, it takes one
or more sets of artifact coordinates in the format of group:artifact:version, as shown in the
following example:
It uninstalls the artifacts identified by the coordinates you supply and their dependencies.
To uninstall all additional dependencies, you can use the --all option, as shown in the following
example:
297
@Configuration(proxyBeanMethods = false)
class Application implements CommandLineRunner {
@Autowired
SharedService service
@Override
void run(String... args) {
println service.message
}
import my.company.SharedService
beans {
service(SharedService) {
message = "Hello World"
}
}
You can mix class declarations with beans{} in the same file as long as they stay at the top level, or,
if you prefer, you can put the beans DSL in a separate file.
• Offline
• Mirrors
• Servers
• Proxies
• Profiles
◦ Activation
◦ Repositories
• Active profiles
298
If you find that you reach the limit of the CLI tool, you probably want to look at converting your
application to a full Gradle or Maven built “Groovy project”. The next section covers Spring Boot’s
"Build tool plugins", which you can use with Gradle or Maven.
299
Chapter 9. Build Tool Plugins
Spring Boot provides build tool plugins for Maven and Gradle. The plugins offer a variety of
features, including the packaging of executable jars. This section provides more details on both
plugins as well as some help should you need to extend an unsupported build system. If you are
just getting started, you might want to read “Build Systems” from the “Using Spring Boot” section
first.
• API
• API
<project xmlns:ivy="antlib:org.apache.ivy.ant"
xmlns:spring-boot="antlib:org.springframework.boot.ant"
name="myapp" default="build">
...
</project>
You need to remember to start Ant using the -lib option, as shown in the following example:
300
$ ant -lib <directory containing spring-boot-antlib-2.3.12.RELEASE.jar>
The “Using Spring Boot” section includes a more complete example of using
Apache Ant with spring-boot-antlib.
Once the spring-boot-antlib namespace has been declared, the following additional tasks are
available:
You can use the exejar task to create a Spring Boot executable jar. The following attributes are
supported by the task:
Element Description
resources One or more Resource Collections describing a set of Resources that should be
added to the content of the created jar file.
lib One or more Resource Collections that should be added to the set of jar
libraries that make up the runtime dependency classpath of the application.
Examples
301
Specify start-class
<spring-boot:exejar destfile="target/my-application.jar"
classes="target/classes" start-class="com.example.MyApplication">
<resources>
<fileset dir="src/main/resources" />
</resources>
<lib>
<fileset dir="lib" />
</lib>
</spring-boot:exejar>
Detect start-class
The findmainclass task is used internally by exejar to locate a class declaring a main. If necessary,
you can also use this task directly in your build. The following attributes are supported:
Examples
302
Override and set
The Spring Boot Maven and Gradle plugins both make use of spring-boot-loader-tools to actually
generate jars. If you need to, you may use this library directly.
When repackaging an archive, you can include references to dependency files by using the
org.springframework.boot.loader.tools.Libraries interface. We do not provide any concrete
implementations of Libraries here as they are usually build-system-specific.
If you do not use Repackager.setMainClass() to specify a main class, the repackager uses ASM to
read class files and tries to find a suitable class with a public static void main(String[] args)
method. An exception is thrown if more than one candidate is found.
303
Repackager repackager = new Repackager(sourceJarFile);
repackager.setBackupSource(false);
repackager.repackage(new Libraries() {
@Override
public void doWithLibraries(LibraryCallback callback) throws IOException {
// Build system specific implementation, callback for each dependency
// callback.library(new Library(nestedFile, LibraryScope.COMPILE));
}
});
If you have specific build-related questions, you can check out the “how-to” guides.
304
Chapter 10. “How-to” Guides
This section provides answers to some common ‘how do I do that…’ questions that often arise when
using Spring Boot. Its coverage is not exhaustive, but it does cover quite a lot.
If you have a specific problem that we do not cover here, you might want to check out
stackoverflow.com to see if someone has already provided an answer. This is also a great place to
ask new questions (please use the spring-boot tag).
We are also more than happy to extend this section. If you want to add a ‘how-to’, send us a pull
request.
FailureAnalyzer is a great way to intercept an exception on startup and turn it into a human-
readable message, wrapped in a FailureAnalysis. Spring Boot provides such an analyzer for
application-context-related exceptions, JSR-303 validations, and more. You can also create your
own.
org.springframework.boot.diagnostics.FailureAnalyzer=\
com.example.ProjectConstraintViolationFailureAnalyzer
If you need access to the BeanFactory or the Environment, your FailureAnalyzer can
implement BeanFactoryAware or EnvironmentAware respectively.
The Spring Boot auto-configuration tries its best to “do the right thing”, but sometimes things fail,
and it can be hard to tell why.
305
been added) by Spring Boot at runtime.
Many more questions can be answered by looking at the source code and the Javadoc. When
reading the code, remember the following rules of thumb:
• Look for classes called *AutoConfiguration and read their sources. Pay special attention to the
@Conditional* annotations to find out what features they enable and when. Add --debug to the
command line or a System property -Ddebug to get a log on the console of all the auto-
configuration decisions that were made in your app. In a running application with actuator
enabled, look at the conditions endpoint (/actuator/conditions or the JMX equivalent) for the
same information.
• Look for classes that are @ConfigurationProperties (such as ServerProperties) and read from
there the available external configuration options. The @ConfigurationProperties annotation has
a name attribute that acts as a prefix to external properties. Thus, ServerProperties has
prefix="server" and its configuration properties are server.port, server.address, and others. In
a running application with actuator enabled, look at the configprops endpoint.
• Look for uses of the bind method on the Binder to pull configuration values explicitly out of the
Environment in a relaxed manner. It is often used with a prefix.
• Look for @ConditionalOnExpression annotations that switch features on and off in response to
SpEL expressions, normally evaluated with placeholders resolved from the Environment.
The SpringApplication sends some special ApplicationEvents to the listeners (some even before the
context is created) and then registers the listeners for events published by the ApplicationContext as
well. See “Application Events and Listeners” in the ‘Spring Boot features’ section for a complete list.
It is also possible to customize the Environment before the application context is refreshed by using
EnvironmentPostProcessor. Each implementation should be registered in META-INF/spring.factories,
as shown in the following example:
org.springframework.boot.env.EnvironmentPostProcessor=com.example.YourEnvironmentPostP
rocessor
306
The implementation can load arbitrary files and add them to the Environment. For instance, the
following example loads a YAML configuration file from the classpath:
@Override
public void postProcessEnvironment(ConfigurableEnvironment environment,
SpringApplication application) {
Resource path = new ClassPathResource("com/example/myapp/config.yml");
PropertySource<?> propertySource = loadYaml(path);
environment.getPropertySources().addLast(propertySource);
}
The Environment has already been prepared with all the usual property sources
that Spring Boot loads by default. It is therefore possible to get the location of the
file from the environment. The preceding example adds the custom-resource
property source at the end of the list so that a key defined in any of the usual other
locations takes precedence. A custom implementation may define another order.
307
10.1.4. Build an ApplicationContext Hierarchy (Adding a Parent or Root
Context)
You can use the ApplicationBuilder class to create parent/child ApplicationContext hierarchies. See
“Fluent Builder API” in the ‘Spring Boot features’ section for more information.
Not all Spring applications have to be web applications (or web services). If you want to execute
some code in a main method but also bootstrap a Spring application to set up the infrastructure to
use, you can use the SpringApplication features of Spring Boot. A SpringApplication changes its
ApplicationContext class, depending on whether it thinks it needs a web application or not. The first
thing you can do to help it is to leave server-related dependencies (e.g. servlet API) off the classpath.
If you cannot do that (for example, you run two applications from the same code base) then you can
explicitly call setWebApplicationType(WebApplicationType.NONE) on your SpringApplication instance
or set the applicationContextClass property (through the Java API or with external properties).
Application code that you want to run as your business logic can be implemented as a
CommandLineRunner and dropped into the context as a @Bean definition.
Rather than hardcoding some properties that are also specified in your project’s build
configuration, you can automatically expand them by instead using the existing build
configuration. This is possible in both Maven and Gradle.
You can automatically expand properties from the Maven project by using resource filtering. If you
use the spring-boot-starter-parent, you can then refer to your Maven ‘project properties’ with @..@
placeholders, as shown in the following example:
app.encoding=@project.build.sourceEncoding@
app.java.version=@java.version@
Only production configuration is filtered that way (in other words, no filtering is
applied on src/test/resources).
308
If you enable the addResources flag, the spring-boot:run goal can add
src/main/resources directly to the classpath (for hot reloading purposes). Doing so
circumvents the resource filtering and this feature. Instead, you can use the
exec:java goal or customize the plugin’s configuration. See the plugin usage page
for more details.
If you do not use the starter parent, you need to include the following element inside the <build/>
element of your pom.xml:
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<version>2.7</version>
<configuration>
<delimiters>
<delimiter>@</delimiter>
</delimiters>
<useDefaultDelimiters>false</useDefaultDelimiters>
</configuration>
</plugin>
You can automatically expand properties from the Gradle project by configuring the Java plugin’s
processResources task to do so, as shown in the following example:
processResources {
expand(project.properties)
}
You can then refer to your Gradle project’s properties by using placeholders, as shown in the
following example:
309
app.name=${name}
app.description=${description}
A SpringApplication has bean properties (mainly setters), so you can use its Java API as you create
the application to modify its behavior. Alternatively, you can externalize the configuration by
setting properties in spring.main.*. For example, in application.properties, you might have the
following settings:
spring.main.web-application-type=none
spring.main.banner-mode=off
Then the Spring Boot banner is not printed on startup, and the application is not starting an
embedded web server.
Properties defined in external configuration override the values specified with the Java API, with
the notable exception of the sources used to create the ApplicationContext. Consider the following
application:
new SpringApplicationBuilder()
.bannerMode(Banner.Mode.OFF)
.sources(demo.MyApp.class)
.run(args);
spring.main.sources=com.acme.Config,com.acme.ExtraConfig
spring.main.banner-mode=console
The actual application now shows the banner (as overridden by configuration) and uses three
sources for the ApplicationContext (in the following order): demo.MyApp, com.acme.Config, and
com.acme.ExtraConfig.
By default, properties from different sources are added to the Spring Environment in a defined order
(see “Externalized Configuration” in the ‘Spring Boot features’ section for the exact order).
You can also provide the following System properties (or environment variables) to change the
310
behavior:
No matter what you set in the environment, Spring Boot always loads application.properties as
described above. By default, if YAML is used, then files with the ‘.yml’ extension are also added to
the list.
Spring Boot logs the configuration files that are loaded at the DEBUG level and the candidates it has
not found at TRACE level.
Some people like to use (for example) --port=9000 instead of --server.port=9000 to set configuration
properties on the command line. You can enable this behavior by using placeholders in
application.properties, as shown in the following example:
server.port=${port:8080}
If you inherit from the spring-boot-starter-parent POM, the default filter token of
the maven-resources-plugins has been changed from ${*} to @ (that is, @maven.token@
instead of ${maven.token}) to prevent conflicts with Spring-style placeholders. If
you have enabled Maven filtering for the application.properties directly, you may
want to also change the default filter token to use other delimiters.
In this specific case, the port binding works in a PaaS environment such as Heroku
or Cloud Foundry. In those two platforms, the PORT environment variable is set
automatically and Spring can bind to capitalized synonyms for Environment
properties.
YAML is a superset of JSON and, as such, is a convenient syntax for storing external properties in a
hierarchical format, as shown in the following example:
311
spring:
application:
name: cruncher
datasource:
driverClassName: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost/test
server:
port: 9000
Create a file called application.yml and put it in the root of your classpath. Then add snakeyaml to
your dependencies (Maven coordinates org.yaml:snakeyaml, already included if you use the spring-
boot-starter). A YAML file is parsed to a Java Map<String,Object> (like a JSON object), and Spring
Boot flattens the map so that it is one level deep and has period-separated keys, as many people are
used to with Properties files in Java.
spring.application.name=cruncher
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost/test
server.port=9000
See “Using YAML Instead of Properties” in the ‘Spring Boot features’ section for more information
about YAML.
The Spring Environment has an API for this, but you would normally set a System property
(spring.profiles.active) or an OS environment variable (SPRING_PROFILES_ACTIVE). Also, you can
launch your application with a -D argument (remember to put it before the main class or jar
archive), as follows:
In Spring Boot, you can also set the active profile in application.properties, as shown in the
following example:
spring.profiles.active=production
A value set this way is replaced by the System property or environment variable setting but not by
the SpringApplicationBuilder.profiles() method. Thus, the latter Java API can be used to augment
the profiles without changing the defaults.
See “Profiles” in the “Spring Boot features” section for more information.
312
10.2.7. Set the Default Profile Name
The default profile is a profile that is enabled if no profile is active. By default, the name of the
default profile is default, but it could be changed using a System property (spring.profiles.default)
or an OS environment variable (SPRING_PROFILES_DEFAULT).
In Spring Boot, you can also set the default profile name in application.properties, as shown in the
following example:
spring.profiles.default=dev
See “Profiles” in the “Spring Boot features” section for more information.
A YAML file is actually a sequence of documents separated by --- lines, and each document is
parsed separately to a flattened map.
If a YAML document contains a spring.profiles key, then the profiles value (a comma-separated list
of profiles) is fed into the Spring Environment.acceptsProfiles() method. If any of those profiles is
active, that document is included in the final merge (otherwise, it is not), as shown in the following
example:
server:
port: 9000
---
spring:
profiles: development
server:
port: 9001
---
spring:
profiles: production
server:
port: 0
In the preceding example, the default port is 9000. However, if the Spring profile called
‘development’ is active, then the port is 9001. If ‘production’ is active, then the port is 0.
The YAML documents are merged in the order in which they are encountered.
Later values override earlier values.
To do the same thing with properties files, you can use application-${profile}.properties to specify
profile-specific values.
313
10.2.9. Discover Built-in Options for External Properties
Spring Boot binds external properties from application.properties (or .yml files and other places)
into an application at runtime. There is not (and technically cannot be) an exhaustive list of all
supported properties in a single location, because contributions can come from additional jar files
on your classpath.
A running application with the Actuator features has a configprops endpoint that shows all the
bound and bindable properties available through @ConfigurationProperties.
The appendix includes an application.properties example with a list of the most common
properties supported by Spring Boot. The definitive list comes from searching the source code for
@ConfigurationProperties and @Value annotations as well as the occasional use of Binder. For more
about the exact ordering of loading properties, see "Externalized Configuration".
• For servlet stack applications, the spring-boot-starter-web includes Tomcat by including spring-
boot-starter-tomcat, but you can use spring-boot-starter-jetty or spring-boot-starter-
undertow instead.
When switching to a different HTTP server, you need to swap the default dependencies for those
that you need instead. To help with this process, Spring Boot provides a separate starter for each of
the supported HTTP servers.
The following Maven example shows how to exclude Tomcat and include Jetty for Spring MVC:
314
<properties>
<servlet-api.version>3.1.0</servlet-api.version>
</properties>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<!-- Exclude the Tomcat dependency -->
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- Use Jetty instead -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</dependency>
The version of the Servlet API has been overridden as, unlike Tomcat 9 and
Undertow 2.0, Jetty 9.4 does not support Servlet 4.0.
The following Gradle example configures the necessary dependencies and a module replacement to
use Undertow in place of Reactor Netty for Spring WebFlux:
dependencies {
implementation "org.springframework.boot:spring-boot-starter-undertow"
implementation "org.springframework.boot:spring-boot-starter-webflux"
modules {
module("org.springframework.boot:spring-boot-starter-reactor-netty") {
replacedBy("org.springframework.boot:spring-boot-starter-undertow", "Use
Undertow instead of Reactor Netty")
}
}
}
If your classpath contains the necessary bits to start a web server, Spring Boot will automatically
start it. To disable this behavior configure the WebApplicationType in your application.properties, as
shown in the following example:
315
spring.main.web-application-type=none
In a standalone application, the main HTTP port defaults to 8080 but can be set with server.port (for
example, in application.properties or as a System property). Thanks to relaxed binding of
Environment values, you can also use SERVER_PORT (for example, as an OS environment variable).
To switch off the HTTP endpoints completely but still create a WebApplicationContext, use
server.port=-1 (doing so is sometimes useful for testing).
For more details, see “Customizing Embedded Servlet Containers” in the ‘Spring Boot Features’
section, or the ServerProperties source code.
To scan for a free port (using OS natives to prevent clashes) use server.port=0.
You can access the port the server is running on from log output or from the
WebServerApplicationContext through its WebServer. The best way to get that and be sure it has been
initialized is to add a @Bean of type ApplicationListener<WebServerInitializedEvent> and pull the
container out of the event when it is published.
@SpringBootTest(webEnvironment=WebEnvironment.RANDOM_PORT)
public class MyWebIntegrationTests {
@LocalServerPort
int port;
// ...
316
10.3.6. Enable HTTP Response Compression
HTTP response compression is supported by Jetty, Tomcat, and Undertow. It can be enabled in
application.properties, as follows:
server.compression.enabled=true
By default, responses must be at least 2048 bytes in length for compression to be performed. You
can configure this behavior by setting the server.compression.min-response-size property.
By default, responses are compressed only if their content type is one of the following:
• text/html
• text/xml
• text/plain
• text/css
• text/javascript
• application/javascript
• application/json
• application/xml
SSL can be configured declaratively by setting the various server.ssl.* properties, typically in
application.properties or application.yml. The following example shows setting SSL properties in
application.properties:
server.port=8443
server.ssl.key-store=classpath:keystore.jks
server.ssl.key-store-password=secret
server.ssl.key-password=another-secret
Using configuration such as the preceding example means the application no longer supports a
plain HTTP connector at port 8080. Spring Boot does not support the configuration of both an HTTP
connector and an HTTPS connector through application.properties. If you want to have both, you
need to configure one of them programmatically. We recommend using application.properties to
configure HTTPS, as the HTTP connector is the easier of the two to configure programmatically.
You can enable HTTP/2 support in your Spring Boot application with the server.http2.enabled
317
configuration property. This support depends on the chosen web server and the application
environment, since that protocol is not supported out-of-the-box by all JDK8 releases.
Spring Boot does not advise using h2c, the cleartext version of the HTTP/2 protocol.
As a result, the next sections require to configure SSL first. If you still choose to use
h2c, you can check the dedicated section.
Spring Boot ships by default with Tomcat 9.0.x which supports HTTP/2 out of the box when using
JDK 9 or later. Alternatively, HTTP/2 can be used on JDK 8 if the libtcnative library and its
dependencies are installed on the host operating system.
The library directory must be made available, if not already, to the JVM library path. You can do so
with a JVM argument such as -Djava.library.path=/usr/local/opt/tomcat-native/lib. More on this
in the official Tomcat documentation.
Starting Tomcat 9.0.x on JDK 8 without that native support logs the following error:
This error is not fatal, and the application still starts with HTTP/1.1 SSL support.
The spring-boot-webflux-starter is using by default Reactor Netty as a server. Reactor Netty can be
configured for HTTP/2 using the JDK support with JDK 9 or later. For JDK 8 environments, or for
optimal runtime performance, this server also supports HTTP/2 with native libraries. To enable
that, your application needs to have an additional dependency.
Spring Boot manages the version for the io.netty:netty-tcnative-boringssl-static "uber jar",
containing native libraries for all platforms. Developers can choose to import only the required
dependencies using a classifier (see the Netty official documentation).
318
HTTP/2 with Undertow
To enable h2c, you need to leave the server.http2.enabled property set to false, and instead apply a
customizer specific to your choice of server:
@Bean
public TomcatConnectorCustomizer connectorCustomizer() {
return (connector) -> connector.addUpgradeProtocol(new Http2Protocol());
}
@Bean
public JettyServerCustomizer serverCustomizer() {
return (server) -> {
HttpConfiguration configuration = new HttpConfiguration();
configuration.setSendServerVersion(false);
Arrays.stream(server.getConnectors())
.filter(connector -> connector instanceof ServerConnector)
.map(ServerConnector.class::cast)
.forEach(connector -> {
connector.addConnectionFactory(new
HTTP2CServerConnectionFactory(configuration));
});
};
}
@Bean
public NettyServerCustomizer serverCustomizer() {
return (server) -> server.protocol(HttpProtocol.H2C);
}
319
@Bean
public UndertowBuilderCustomizer builderCustomizer() {
return (builder) -> {
builder.setServerOption(ENABLE_HTTP2, true);
};
}
Generally, you should first consider using one of the many available configuration keys and
customize your web server by adding new entries in your application.properties (or
application.yml, or environment, etc. see “Discover Built-in Options for External Properties”). The
server.* namespace is quite useful here, and it includes namespaces like server.tomcat.*,
server.jetty.* and others, for server-specific features. See the list of Common Application
properties.
The previous sections covered already many common use cases, such as compression, SSL or
HTTP/2. However, if a configuration key doesn’t exist for your use case, you should then look at
WebServerFactoryCustomizer. You can declare such a component and get access to the server factory
relevant to your choice: you should select the variant for the chosen Server (Tomcat, Jetty, Reactor
Netty, Undertow) and the chosen web stack (Servlet or Reactive).
The example below is for Tomcat with the spring-boot-starter-web (Servlet stack):
@Component
public class MyTomcatWebServerCustomizer
implements WebServerFactoryCustomizer<TomcatServletWebServerFactory> {
@Override
public void customize(TomcatServletWebServerFactory factory) {
// customize the factory here
}
}
Spring Boot uses that infrastructure internally to auto-configure the server. Auto-
configured WebServerFactoryCustomizer beans have an order of 0 and will be
processed before any user-defined customizers, unless it has an explicit order that
states otherwise.
Once you’ve got access to a WebServerFactory using the customizer, you can use it to configure
specific parts, like connectors, server resources, or the server itself - all using server-specific APIs.
320
Server Servlet stack Reactive stack
As a last resort, you can also declare your own WebServerFactory bean, which will override the one
provided by Spring Boot. When you do so, auto-configured customizers are still applied on your
custom factory, so use that option carefully.
In a servlet stack application, i.e. with the spring-boot-starter-web, there are two ways to add
Servlet, Filter, ServletContextListener, and the other listeners supported by the Servlet API to your
application:
To add a Servlet, Filter, or Servlet *Listener by using a Spring bean, you must provide a @Bean
definition for it. Doing so can be very useful when you want to inject configuration or
dependencies. However, you must be very careful that they do not cause eager initialization of too
many other beans, because they have to be installed in the container very early in the application
lifecycle. (For example, it is not a good idea to have them depend on your DataSource or JPA
configuration.) You can work around such restrictions by initializing the beans lazily when first
used instead of on initialization.
In the case of Filters and Servlets, you can also add mappings and init parameters by adding a
FilterRegistrationBean or a ServletRegistrationBean instead of or in addition to the underlying
component.
Like any other Spring bean, you can define the order of Servlet filter beans; please make sure to
check the “Registering Servlets, Filters, and Listeners as Spring Beans” section.
As described earlier, any Servlet or Filter beans are registered with the servlet container
automatically. To disable registration of a particular Filter or Servlet bean, create a registration
bean for it and mark it as disabled, as shown in the following example:
321
@Bean
public FilterRegistrationBean registration(MyFilter filter) {
FilterRegistrationBean registration = new FilterRegistrationBean(filter);
registration.setEnabled(false);
return registration;
}
@WebServlet, @WebFilter, and @WebListener annotated classes can be automatically registered with an
embedded servlet container by annotating a @Configuration class with @ServletComponentScan and
specifying the package(s) containing the components that you want to register. By default,
@ServletComponentScan scans from the package of the annotated class.
Access logs can be configured for Tomcat, Undertow, and Jetty through their respective
namespaces.
For instance, the following settings log access on Tomcat with a custom pattern.
server.tomcat.basedir=my-tomcat
server.tomcat.accesslog.enabled=true
server.tomcat.accesslog.pattern=%t %a "%r" %s (%D ms)
The default location for logs is a logs directory relative to the Tomcat base
directory. By default, the logs directory is a temporary directory, so you may want
to fix Tomcat’s base directory or use an absolute path for the logs. In the preceding
example, the logs are available in my-tomcat/logs relative to the working directory
of the application.
Access logging for Undertow can be configured in a similar fashion, as shown in the following
example:
server.undertow.accesslog.enabled=true
server.undertow.accesslog.pattern=%t %a "%r" %s (%D ms)
Logs are stored in a logs directory relative to the working directory of the application. You can
customize this location by setting the server.undertow.accesslog.dir property.
server.jetty.accesslog.enabled=true
server.jetty.accesslog.filename=/var/log/jetty-access.log
322
By default, logs are redirected to System.err. For more details, see the Jetty documentation.
If your application is running behind a proxy, a load-balancer or in the cloud, the request
information (like the host, port, scheme…) might change along the way. Your application may be
running on 10.10.10.10:8080, but HTTP clients should only see example.org.
RFC7239 "Forwarded Headers" defines the Forwarded HTTP header; proxies can use this header to
provide information about the original request. You can configure your application to read those
headers and automatically use that information when creating links and sending them to clients in
HTTP 302 responses, JSON documents or HTML pages. There are also non-standard headers, like X-
Forwarded-Host, X-Forwarded-Port, X-Forwarded-Proto, X-Forwarded-Ssl, and X-Forwarded-Prefix.
If the proxy adds the commonly used X-Forwarded-For and X-Forwarded-Proto headers, setting
server.forward-headers-strategy to NATIVE is enough to support those. With this option, the Web
servers themselves natively support this feature; you can check their specific documentation to
learn about specific behavior.
If this is not enough, Spring Framework provides a ForwardedHeaderFilter. You can register it as a
Servlet Filter in your application by setting server.forward-headers-strategy is set to FRAMEWORK.
If you are using Tomcat and terminating SSL at the proxy, server.tomcat.redirect-
context-root should be set to false. This allows the X-Forwarded-Proto header to be
honored before any redirects are performed.
If you use Tomcat, you can additionally configure the names of the headers used to carry
“forwarded” information, as shown in the following example:
server.tomcat.remoteip.remote-ip-header=x-your-remote-ip-header
server.tomcat.remoteip.protocol-header=x-your-protocol-header
Tomcat is also configured with a default regular expression that matches internal proxies that are
to be trusted. By default, IP addresses in 10/8, 192.168/16, 169.254/16 and 127/8 are trusted. You can
customize the valve’s configuration by adding an entry to application.properties, as shown in the
following example:
server.tomcat.remoteip.internal-proxies=192\\.168\\.\\d{1,3}\\.\\d{1,3}
323
The double backslashes are required only when you use a properties file for
configuration. If you use YAML, single backslashes are sufficient, and a value
equivalent to that shown in the preceding example would be
192\.168\.\d{1,3}\.\d{1,3}.
You can trust all proxies by setting the internal-proxies to empty (but do not do so
in production).
You can take complete control of the configuration of Tomcat’s RemoteIpValve by switching the
automatic one off (to do so, set server.forward-headers-strategy=NONE) and adding a new valve
instance using a WebServerFactoryCustomizer bean.
@Bean
public WebServerFactoryCustomizer<TomcatServletWebServerFactory>
sslConnectorCustomizer() {
return (tomcat) -> tomcat.addAdditionalTomcatConnectors(createSslConnector());
}
324
10.3.14. Use Tomcat’s LegacyCookieProcessor
By default, the embedded Tomcat used by Spring Boot does not support "Version 0" of the Cookie
format, so you may see the following error:
If at all possible, you should consider updating your code to only store values compliant with later
Cookie specifications. If, however, you cannot change the way that cookies are written, you can
instead configure Tomcat to use a LegacyCookieProcessor. To switch to the LegacyCookieProcessor,
use an WebServerFactoryCustomizer bean that adds a TomcatContextCustomizer, as shown in the
following example:
@Bean
public WebServerFactoryCustomizer<TomcatServletWebServerFactory>
cookieProcessorCustomizer() {
return (factory) -> factory
.addContextCustomizers((context) -> context.setCookieProcessor(new
LegacyCookieProcessor()));
}
Embedded Tomcat’s MBean registry is disabled by default. This minimizes Tomcat’s memory
footprint. If you want to use Tomcat’s MBeans, for example so that they can be used to expose
metrics via Micrometer, you must use the server.tomcat.mbeanregistry.enabled property to do so, as
shown in the following example:
server.tomcat.mbeanregistry.enabled=true
325
@Bean
public WebServerFactoryCustomizer<UndertowServletWebServerFactory>
undertowListenerCustomizer() {
return (factory) -> {
factory.addBuilderCustomizers(new UndertowBuilderCustomizer() {
@Override
public void customize(Builder builder) {
builder.addHttpListener(8080, "0.0.0.0");
}
});
};
}
If you want to use @ServerEndpoint in a Spring Boot application that used an embedded container,
you must declare a single ServerEndpointExporter @Bean, as shown in the following example:
@Bean
public ServerEndpointExporter serverEndpointExporter() {
return new ServerEndpointExporter();
}
The bean shown in the preceding example registers any @ServerEndpoint annotated beans with the
underlying WebSocket container. When deployed to a standalone servlet container, this role is
performed by a servlet container initializer, and the ServerEndpointExporter bean is not required.
Any Spring @RestController in a Spring Boot application should render JSON response by default as
long as Jackson2 is on the classpath, as shown in the following example:
326
@RestController
public class MyController {
@RequestMapping("/thing")
public MyThing thing() {
return new MyThing();
}
As long as MyThing can be serialized by Jackson2 (true for a normal POJO or Groovy object), then
localhost:8080/thing serves a JSON representation of it by default. Note that, in a browser, you
might sometimes see XML responses, because browsers tend to send accept headers that prefer
XML.
If you have the Jackson XML extension (jackson-dataformat-xml) on the classpath, you can use it to
render XML responses. The previous example that we used for JSON would work. To use the
Jackson XML renderer, add the following dependency to your project:
<dependency>
<groupId>com.fasterxml.jackson.dataformat</groupId>
<artifactId>jackson-dataformat-xml</artifactId>
</dependency>
If Jackson’s XML extension is not available and JAXB is available, XML can be rendered with the
additional requirement of having MyThing annotated as @XmlRootElement, as shown in the following
example:
@XmlRootElement
public class MyThing {
private String name;
// .. getters and setters
}
JAXB is only available out of the box with Java 8. If you’re using a more recent Java generation, add
the following dependency to your project:
<dependency>
<groupId>org.glassfish.jaxb</groupId>
<artifactId>jaxb-runtime</artifactId>
</dependency>
327
To get the server to render XML instead of JSON, you might have to send an
Accept: text/xml header (or use a browser).
Spring MVC (client and server side) uses HttpMessageConverters to negotiate content conversion in
an HTTP exchange. If Jackson is on the classpath, you already get the default converter(s) provided
by Jackson2ObjectMapperBuilder, an instance of which is auto-configured for you.
The ObjectMapper (or XmlMapper for Jackson XML converter) instance (created by default) has the
following customized properties:
• MapperFeature.DEFAULT_VIEW_INCLUSION is disabled
• DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES is disabled
• SerializationFeature.WRITE_DATES_AS_TIMESTAMPS is disabled
Spring Boot also has some features to make it easier to customize this behavior.
You can configure the ObjectMapper and XmlMapper instances by using the environment. Jackson
provides an extensive suite of on/off features that can be used to configure various aspects of its
processing. These features are described in six enums (in Jackson) that map onto properties in the
environment:
328
customizer has an order of 0), letting additional customization be applied both before and after
Boot’s customization.
If you want to replace the default ObjectMapper completely, either define a @Bean of that type and
mark it as @Primary or, if you prefer the builder-based approach, define a
Jackson2ObjectMapperBuilder @Bean. Note that, in either case, doing so disables all auto-configuration
of the ObjectMapper.
If you provide any @Beans of type MappingJackson2HttpMessageConverter, they replace the default
value in the MVC configuration. Also, a convenience bean of type HttpMessageConverters is provided
(and is always available if you use the default MVC configuration). It has some useful methods to
access the default and user-enhanced message converters.
See the “Customize the @ResponseBody Rendering” section and the WebMvcAutoConfiguration source
code for more details.
Spring uses HttpMessageConverters to render @ResponseBody (or responses from @RestController). You
can contribute additional converters by adding beans of the appropriate type in a Spring Boot
context. If a bean you add is of a type that would have been included by default anyway (such as
MappingJackson2HttpMessageConverter for JSON conversions), it replaces the default value. A
convenience bean of type HttpMessageConverters is provided and is always available if you use the
default MVC configuration. It has some useful methods to access the default and user-enhanced
message converters (For example, it can be useful if you want to manually inject them into a
custom RestTemplate).
As in normal MVC usage, any WebMvcConfigurer beans that you provide can also contribute
converters by overriding the configureMessageConverters method. However, unlike with normal
MVC, you can supply only additional converters that you need (because Spring Boot uses the same
mechanism to contribute its defaults). Finally, if you opt out of the Spring Boot default MVC
configuration by providing your own @EnableWebMvc configuration, you can take control completely
and do everything manually by using getMessageConverters from WebMvcConfigurationSupport.
Spring Boot embraces the Servlet 3 javax.servlet.http.Part API to support uploading files. By
default, Spring Boot configures Spring MVC with a maximum size of 1MB per file and a maximum
of 10MB of file data in a single request. You may override these values, the location to which
intermediate data is stored (for example, to the /tmp directory), and the threshold past which data is
flushed to disk by using the properties exposed in the MultipartProperties class. For example, if you
want to specify that files be unlimited, set the spring.servlet.multipart.max-file-size property to
329
-1.
The multipart support is helpful when you want to receive multipart encoded file data as a
@RequestParam-annotated parameter of type MultipartFile in a Spring MVC controller handler
method.
By default, all content is served from the root of your application (/). If you would rather map to a
different path, you can configure one as follows:
spring.mvc.servlet.path=/acme
If you have additional servlets you can declare a @Bean of type Servlet or ServletRegistrationBean
for each and Spring Boot will register them transparently to the container. Because servlets are
registered that way, they can be mapped to a sub-context of the DispatcherServlet without invoking
it.
Configuring the DispatcherServlet yourself is unusual but if you really need to do it, a @Bean of type
DispatcherServletPath must be provided as well to provide the path of your custom
DispatcherServlet.
The easiest way to take complete control over MVC configuration is to provide your own
@Configuration with the @EnableWebMvc annotation. Doing so leaves all MVC configuration in your
hands.
A ViewResolver is a core component of Spring MVC, translating view names in @Controller to actual
View implementations. Note that ViewResolvers are mainly used in UI applications, rather than
REST-style services (a View is not used to render a @ResponseBody). There are many implementations
of ViewResolver to choose from, and Spring on its own is not opinionated about which ones you
should use. Spring Boot, on the other hand, installs one or two for you, depending on what it finds
on the classpath and in the application context. The DispatcherServlet uses all the resolvers it finds
in the application context, trying each one in turn until it gets a result. If you add your own, you
have to be aware of the order and in which position your resolver is added.
330
resources that can be rendered by using the DefaultServlet (including static resources and JSP
pages, if you use those). It applies a prefix and a suffix to the view name and then looks for a
physical resource with that path in the servlet context (the defaults are both empty but are
accessible for external configuration through spring.mvc.view.prefix and
spring.mvc.view.suffix). You can override it by providing a bean of the same type.
• If you use Groovy templates (actually, if groovy-templates is on your classpath), you also have a
GroovyMarkupViewResolver named ‘groovyMarkupViewResolver’. It looks for resources in a
loader path by surrounding the view name with a prefix and suffix (externalized to
spring.groovy.template.prefix and spring.groovy.template.suffix). The prefix and suffix have
default values of ‘classpath:/templates/’ and ‘.tpl’, respectively. You can override
GroovyMarkupViewResolver by providing a bean of the same name.
• WebMvcAutoConfiguration
• ThymeleafAutoConfiguration
• FreeMarkerAutoConfiguration
• GroovyTemplateAutoConfiguration
331
10.5. Testing With Spring Security
Spring Security provides support for running tests as a specific user. For example, the test in the
snippet below will run with an authenticated user that has the ADMIN role.
@Test
@WithMockUser(roles="ADMIN")
public void requestProtectedUrlWithUser() throws Exception {
mvc
.perform(get("/"))
...
}
Spring Security provides comprehensive integration with Spring MVC Test and this can also be used
when testing controllers using the @WebMvcTest slice and MockMvc.
For additional details on Spring Security’s testing support, refer to Spring Security’s reference
documentation).
10.6. Jersey
10.6.1. Secure Jersey endpoints with Spring Security
Spring Security can be used to secure a Jersey-based web application in much the same way as it
can be used to secure a Spring MVC-based web application. However, if you want to use Spring
Security’s method-level security with Jersey, you must configure Jersey to use setStatus(int) rather
sendError(int). This prevents Jersey from committing the response before Spring Security has had
an opportunity to report an authentication or authorization failure to the client.
@Component
public class JerseyConfig extends ResourceConfig {
public JerseyConfig() {
register(Endpoint.class);
setProperties(Collections.singletonMap("jersey.config.server.response.setStatusOverSen
dError", true));
}
332
10.6.2. Use Jersey Alongside Another Web Framework
To use Jersey alongside another web framework, such as Spring MVC, it should be configured so
that it will allow the other framework to handle requests that it cannot handle. First, configure
Jersey to use a Filter rather than a Servlet by configuring the spring.jersey.type application
property with a value of filter. Second, configure your ResourceConfig to forward requests that
would have resulted in a 404, as shown in the following example.
@Component
public class JerseyConfig extends ResourceConfig {
public JerseyConfig() {
register(Endpoint.class);
property(ServletProperties.FILTER_FORWARD_ON_404, true);
}
The exact details of the proxy configuration depend on the underlying client request factory that is
being used. The following example configures HttpComponentsClientRequestFactory with an
HttpClient that uses a proxy for all hosts except 192.168.0.5:
333
static class ProxyCustomizer implements RestTemplateCustomizer {
@Override
public void customize(RestTemplate restTemplate) {
HttpHost proxy = new HttpHost("proxy.example.com");
HttpClient httpClient = HttpClientBuilder.create().setRoutePlanner(new
DefaultProxyRoutePlanner(proxy) {
@Override
public HttpHost determineProxy(HttpHost target, HttpRequest request,
HttpContext context)
throws HttpException {
if (target.getHostName().equals("192.168.0.5")) {
return null;
}
return super.determineProxy(target, request, context);
}
}).build();
restTemplate.setRequestFactory(new
HttpComponentsClientHttpRequestFactory(httpClient));
}
@Bean
ClientHttpConnector clientHttpConnector(ReactorResourceFactory resourceFactory) {
TcpClient tcpClient = TcpClient.create(resourceFactory.getConnectionProvider())
.runOn(resourceFactory.getLoopResources()).option(ChannelOption.CONNECT_TIMEOUT_MILLIS
, 60000)
.doOnConnected((connection) -> connection.addHandlerLast(new
ReadTimeoutHandler(60)));
return new ReactorClientHttpConnector(HttpClient.from(tcpClient));
}
Note the use of ReactorResourceFactory for the connection provider and event loop
resources. This ensures efficient sharing of resources for the server receiving
requests and the client making requests.
334
10.8. Logging
Spring Boot has no mandatory logging dependency, except for the Commons Logging API, which is
typically provided by Spring Framework’s spring-jcl module. To use Logback, you need to include
it and spring-jcl on the classpath. The recommended way to do that is through the starters, which
all depend on spring-boot-starter-logging. For a web application, you need only spring-boot-
starter-web, since it depends transitively on the logging starter. If you use Maven, the following
dependency adds logging for you:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
Spring Boot has a LoggingSystem abstraction that attempts to configure logging based on the content
of the classpath. If Logback is available, it is the first choice.
If the only change you need to make to logging is to set the levels of various loggers, you can do so
in application.properties by using the "logging.level" prefix, as shown in the following example:
logging.level.org.springframework.web=DEBUG
logging.level.org.hibernate=ERROR
You can also set the location of a file to which to write the log (in addition to the console) by using
"logging.file.name".
To configure the more fine-grained settings of a logging system, you need to use the native
configuration format supported by the LoggingSystem in question. By default, Spring Boot picks up
the native configuration from its default location for the system (such as classpath:logback.xml for
Logback), but you can set the location of the config file by using the logging.config property.
If you need to apply customizations to logback beyond those that can be achieved with
application.properties, you’ll need to add a standard logback configuration file. You can add a
logback.xml file to the root of your classpath for logback to find. You can also use logback-spring.xml
if you want to use the Spring Boot Logback extensions.
Spring Boot provides a number of logback configurations that be included from your own
configuration. These includes are designed to allow certain common Spring Boot conventions to be
re-applied.
335
• defaults.xml - Provides conversion rules, pattern properties and common logger configurations.
In addition, a legacy base.xml file is provided for compatibility with earlier versions of Spring Boot.
Your logback configuration file can also make use of System properties that the LoggingSystem takes
care of creating for you:
• ${LOG_PATH}: Whether logging.file.path (representing a directory for log files to live in) was set
in Boot’s external configuration.
Spring Boot also provides some nice ANSI color terminal output on a console (but not in a log file)
by using a custom Logback converter. See the CONSOLE_LOG_PATTERN in the defaults.xml configuration
for an example.
If Groovy is on the classpath, you should be able to configure Logback with logback.groovy as well.
If present, this setting is given preference.
Spring extensions are not supported with Groovy configuration. Any logback-
spring.groovy files will not be detected.
If you want to disable console logging and write output only to a file, you need a custom logback-
spring.xml that imports file-appender.xml but not console-appender.xml, as shown in the following
336
example:
You also need to add logging.file.name to your application.properties, as shown in the following
example:
logging.file.name=myapplication.log
Spring Boot supports Log4j 2 for logging configuration if it is on the classpath. If you use the starters
for assembling dependencies, you have to exclude Logback and then include log4j 2 instead. If you
do not use the starters, you need to provide (at least) spring-jcl in addition to Log4j 2.
The recommended path is through the starters, even though it requires some jiggling. The following
example shows how to set up the starters in Maven:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
Gradle provides a few different ways to set up the starters. One way is to use a module
337
replacement. To do so, declare a dependency on the Log4j 2 starter and tell Gradle that any
occurrences of the default logging starter should be replaced by the Log4j 2 starter, as shown in the
following example:
dependencies {
implementation "org.springframework.boot:spring-boot-starter-log4j2"
modules {
module("org.springframework.boot:spring-boot-starter-logging") {
replacedBy("org.springframework.boot:spring-boot-starter-log4j2", "Use
Log4j2 instead of Logback")
}
}
}
The Log4j starters gather together the dependencies for common logging
requirements (such as having Tomcat use java.util.logging but configuring the
output using Log4j 2).
In addition to its default XML configuration format, Log4j 2 also supports YAML and JSON
configuration files. To configure Log4j 2 to use an alternative configuration file format, add the
appropriate dependencies to the classpath and name your configuration files to match your chosen
file format, as shown in the following example:
To configure your own DataSource, define a @Bean of that type in your configuration. Spring Boot
reuses your DataSource anywhere one is required, including database initialization. If you need to
338
externalize some settings, you can bind your DataSource to the environment (see “Third-party
Configuration”).
@Bean
@ConfigurationProperties(prefix="app.datasource")
public DataSource dataSource() {
return new FancyDataSource();
}
The following example shows how to define a data source by setting properties:
app.datasource.url=jdbc:h2:mem:mydb
app.datasource.username=sa
app.datasource.pool-size=30
Assuming that your FancyDataSource has regular JavaBean properties for the URL, the username,
and the pool size, these settings are bound automatically before the DataSource is made available to
other components. The regular database initialization also happens (so the relevant sub-set of
spring.datasource.* can still be used with your custom configuration).
Spring Boot also provides a utility builder class, called DataSourceBuilder, that can be used to create
one of the standard data sources (if it is on the classpath). The builder can detect the one to use
based on what’s available on the classpath. It also auto-detects the driver based on the JDBC URL.
The following example shows how to create a data source by using a DataSourceBuilder:
@Bean
@ConfigurationProperties("app.datasource")
public DataSource dataSource() {
return DataSourceBuilder.create().build();
}
To run an app with that DataSource, all you need is the connection information. Pool-specific
settings can also be provided. Check the implementation that is going to be used at runtime for
more details.
The following example shows how to define a JDBC data source by setting properties:
app.datasource.url=jdbc:mysql://localhost/test
app.datasource.username=dbuser
app.datasource.password=dbpass
app.datasource.pool-size=30
However, there is a catch. Because the actual type of the connection pool is not exposed, no keys are
339
generated in the metadata for your custom DataSource and no completion is available in your IDE
(because the DataSource interface exposes no properties). Also, if you happen to have Hikari on the
classpath, this basic setup does not work, because Hikari has no url property (but does have a
jdbcUrl property). In that case, you must rewrite your configuration as follows:
app.datasource.jdbc-url=jdbc:mysql://localhost/test
app.datasource.username=dbuser
app.datasource.password=dbpass
app.datasource.maximum-pool-size=30
You can fix that by forcing the connection pool to use and return a dedicated implementation
rather than DataSource. You cannot change the implementation at runtime, but the list of options
will be explicit.
@Bean
@ConfigurationProperties("app.datasource")
public HikariDataSource dataSource() {
return DataSourceBuilder.create().type(HikariDataSource.class).build();
}
You can even go further by leveraging what DataSourceProperties does for you — that is, by
providing a default embedded database with a sensible username and password if no URL is
provided. You can easily initialize a DataSourceBuilder from the state of any DataSourceProperties
object, so you could also inject the DataSource that Spring Boot creates automatically. However, that
would split your configuration into two namespaces: url, username, password, type, and driver on
spring.datasource and the rest on your custom namespace (app.datasource). To avoid that, you can
redefine a custom DataSourceProperties on your custom namespace, as shown in the following
example:
@Bean
@Primary
@ConfigurationProperties("app.datasource")
public DataSourceProperties dataSourceProperties() {
return new DataSourceProperties();
}
@Bean
@ConfigurationProperties("app.datasource.configuration")
public HikariDataSource dataSource(DataSourceProperties properties) {
return
properties.initializeDataSourceBuilder().type(HikariDataSource.class).build();
}
This setup puts you in sync with what Spring Boot does for you by default, except that a dedicated
connection pool is chosen (in code) and its settings are exposed in the app.datasource.configuration
340
sub namespace. Because DataSourceProperties is taking care of the url/jdbcUrl translation for you,
you can configure it as follows:
app.datasource.url=jdbc:mysql://localhost/test
app.datasource.username=dbuser
app.datasource.password=dbpass
app.datasource.configuration.maximum-pool-size=30
See “Configure a DataSource” in the “Spring Boot features” section and the
DataSourceAutoConfiguration class for more details.
If you need to configure multiple data sources, you can apply the same tricks that are described in
the previous section. You must, however, mark one of the DataSource instances as @Primary, because
various auto-configurations down the road expect to be able to get one by type.
If you create your own DataSource, the auto-configuration backs off. In the following example, we
provide the exact same feature set as the auto-configuration provides on the primary data source:
341
@Bean
@Primary
@ConfigurationProperties("app.datasource.first")
public DataSourceProperties firstDataSourceProperties() {
return new DataSourceProperties();
}
@Bean
@Primary
@ConfigurationProperties("app.datasource.first.configuration")
public HikariDataSource firstDataSource() {
return
firstDataSourceProperties().initializeDataSourceBuilder().type(HikariDataSource.class)
.build();
}
@Bean
@ConfigurationProperties("app.datasource.second")
public BasicDataSource secondDataSource() {
return DataSourceBuilder.create().type(BasicDataSource.class).build();
}
Both data sources are also bound for advanced customizations. For instance, you could configure
them as follows:
app.datasource.first.url=jdbc:mysql://localhost/first
app.datasource.first.username=dbuser
app.datasource.first.password=dbpass
app.datasource.first.configuration.maximum-pool-size=30
app.datasource.second.url=jdbc:mysql://localhost/second
app.datasource.second.username=dbuser
app.datasource.second.password=dbpass
app.datasource.second.max-total=30
You can apply the same concept to the secondary DataSource as well, as shown in the following
example:
342
@Bean
@Primary
@ConfigurationProperties("app.datasource.first")
public DataSourceProperties firstDataSourceProperties() {
return new DataSourceProperties();
}
@Bean
@Primary
@ConfigurationProperties("app.datasource.first.configuration")
public HikariDataSource firstDataSource() {
return
firstDataSourceProperties().initializeDataSourceBuilder().type(HikariDataSource.class)
.build();
}
@Bean
@ConfigurationProperties("app.datasource.second")
public DataSourceProperties secondDataSourceProperties() {
return new DataSourceProperties();
}
@Bean
@ConfigurationProperties("app.datasource.second.configuration")
public BasicDataSource secondDataSource() {
return
secondDataSourceProperties().initializeDataSourceBuilder().type(BasicDataSource.class)
.build();
}
The preceding example configures two data sources on custom namespaces with the same logic as
Spring Boot would use in auto-configuration. Note that each configuration sub namespace provides
advanced settings based on the chosen implementation.
Spring Data can create implementations of @Repository interfaces of various flavors. Spring Boot
handles all of that for you, as long as those @Repositories are included in the same package (or a
sub-package) of your @EnableAutoConfiguration class.
For many applications, all you need is to put the right Spring Data dependencies on your classpath.
There is a spring-boot-starter-data-jpa for JPA, spring-boot-starter-data-mongodb for Mongodb,
etc. To get started, create some repository interfaces to handle your @Entity objects.
Spring Boot tries to guess the location of your @Repository definitions, based on the
@EnableAutoConfiguration it finds. To get more control, use the @EnableJpaRepositories annotation
(from Spring Data JPA).
For more about Spring Data, see the Spring Data project page.
343
10.9.4. Separate @Entity Definitions from Spring Configuration
Spring Boot tries to guess the location of your @Entity definitions, based on the
@EnableAutoConfiguration it finds. To get more control, you can use the @EntityScan annotation, as
shown in the following example:
@Configuration(proxyBeanMethods = false)
@EnableAutoConfiguration
@EntityScan(basePackageClasses=City.class)
public class Application {
//...
Spring Data JPA already provides some vendor-independent configuration options (such as those
for SQL logging), and Spring Boot exposes those options and a few more for Hibernate as external
configuration properties. Some of them are automatically detected according to the context so you
should not have to set them.
The dialect to use is detected by the JPA provider. If you prefer to set the dialect yourself, set the
spring.jpa.database-platform property.
The most common options to set are shown in the following example:
spring.jpa.hibernate.naming.physical-strategy=com.example.MyPhysicalNamingStrategy
spring.jpa.show-sql=true
In addition, all properties in spring.jpa.properties.* are passed through as normal JPA properties
(with the prefix stripped) when the local EntityManagerFactory is created.
344
If you need to apply advanced customization to Hibernate properties, consider
registering a HibernatePropertiesCustomizer bean that will be invoked prior to
creating the EntityManagerFactory. This takes precedence to anything that is
applied by the auto-configuration.
Hibernate uses two different naming strategies to map names from the object model to the
corresponding database names. The fully qualified class name of the physical and the implicit
strategy implementations can be configured by setting the spring.jpa.hibernate.naming.physical-
strategy and spring.jpa.hibernate.naming.implicit-strategy properties, respectively. Alternatively,
if ImplicitNamingStrategy or PhysicalNamingStrategy beans are available in the application context,
Hibernate will be automatically configured to use them.
By default, Spring Boot configures the physical naming strategy with SpringPhysicalNamingStrategy.
This implementation provides the same table structure as Hibernate 4: all dots are replaced by
underscores and camel casing is replaced by underscores as well. Additionally, by default, all table
names are generated in lower case. For example, a TelephoneNumber entity is mapped to the
telephone_number table. If your schema requires mixed-case identifiers, define a custom
SpringPhysicalNamingStrategy bean, as shown in the following example:
@Bean
SpringPhysicalNamingStrategy caseSensitivePhysicalNamingStrategy() {
return new SpringPhysicalNamingStrategy() {
@Override
protected boolean isCaseInsensitive(JdbcEnvironment jdbcEnvironment) {
return false;
}
};
}
If you prefer to use Hibernate 5’s default instead, set the following property:
spring.jpa.hibernate.naming.physical-
strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
@Bean
public PhysicalNamingStrategy physicalNamingStrategy() {
return new PhysicalNamingStrategyStandardImpl();
}
345
10.9.7. Configure Hibernate Second-Level Caching
Hibernate second-level cache can be configured for a range of cache providers. Rather than
configuring Hibernate to lookup the cache provider again, it is better to provide the one that is
available in the context whenever possible.
To do this with JCache, first make sure that org.hibernate:hibernate-jcache is available on the
classpath. Then, add a HibernatePropertiesCustomizer bean as shown in the following example:
@Configuration(proxyBeanMethods = false)
public class HibernateSecondLevelCacheExample {
@Bean
public HibernatePropertiesCustomizer
hibernateSecondLevelCacheCustomizer(JCacheCacheManager cacheManager) {
return (properties) -> properties.put(ConfigSettings.CACHE_MANAGER,
cacheManager.getCacheManager());
}
This customizer will configure Hibernate to use the same CacheManager as the one that the
application uses. It is also possible to use separate CacheManager instances. For details, refer to the
Hibernate user guide.
By default, Spring Boot registers a BeanContainer implementation that uses the BeanFactory so that
converters and entity listeners can use regular dependency injection.
You can disable or tune this behaviour by registering a HibernatePropertiesCustomizer that removes
or changes the hibernate.resource.beans.container property.
To take full control of the configuration of the EntityManagerFactory, you need to add a @Bean named
‘entityManagerFactory’. Spring Boot auto-configuration switches off its entity manager in the
presence of a bean of that type.
If you need to use JPA against multiple data sources, you likely need one EntityManagerFactory per
data source. The LocalContainerEntityManagerFactoryBean from Spring ORM allows you to configure
an EntityManagerFactory for your needs. You can also reuse JpaProperties to bind settings for each
EntityManagerFactory, as shown in the following example:
346
@Bean
@ConfigurationProperties("app.jpa.first")
public JpaProperties firstJpaProperties() {
return new JpaProperties();
}
@Bean
public LocalContainerEntityManagerFactoryBean firstEntityManagerFactory(DataSource
firstDataSource,
JpaProperties firstJpaProperties) {
EntityManagerFactoryBuilder builder =
createEntityManagerFactoryBuilder(firstJpaProperties);
return
builder.dataSource(firstDataSource).packages(Order.class).persistenceUnit("firstDs").b
uild();
}
You should provide a similar configuration for any additional data sources for which you need JPA
access. To complete the picture, you need to configure a JpaTransactionManager for each
EntityManagerFactory as well. Alternatively, you might be able to use a JTA transaction manager that
spans both.
If you use Spring Data, you need to configure @EnableJpaRepositories accordingly, as shown in the
347
following example:
@Configuration(proxyBeanMethods = false)
@EnableJpaRepositories(basePackageClasses = Order.class,
entityManagerFactoryRef = "firstEntityManagerFactory")
public class OrderConfiguration {
...
}
@Configuration(proxyBeanMethods = false)
@EnableJpaRepositories(basePackageClasses = Customer.class,
entityManagerFactoryRef = "secondEntityManagerFactory")
public class CustomerConfiguration {
...
}
Spring Boot will not search for or use a META-INF/persistence.xml by default. If you prefer to use a
traditional persistence.xml, you need to define your own @Bean of type
LocalEntityManagerFactoryBean (with an ID of ‘entityManagerFactory’) and set the persistence unit
name there.
Spring Data JPA and Spring Data Mongo can both automatically create Repository implementations
for you. If they are both present on the classpath, you might have to do some extra configuration to
tell Spring Boot which repositories to create. The most explicit way to do that is to use the standard
Spring Data @EnableJpaRepositories and @EnableMongoRepositories annotations and provide the
location of your Repository interfaces.
The same obstacle and the same features exist for other auto-configured Spring Data repository
types (Elasticsearch, Solr, and others). To work with them, change the names of the annotations and
flags accordingly.
Spring Data provides web support that simplifies the use of Spring Data repositories in a web
application. Spring Boot provides properties in the spring.data.web namespace for customizing its
configuration. Note that if you are using Spring Data REST, you must use the properties in the
spring.data.rest namespace instead.
348
10.9.14. Expose Spring Data Repositories as REST Endpoint
Spring Data REST can expose the Repository implementations as REST endpoints for you, provided
Spring MVC has been enabled for the application.
Spring Boot exposes a set of useful properties (from the spring.data.rest namespace) that
customize the RepositoryRestConfiguration. If you need to provide additional customization, you
should use a RepositoryRestConfigurer bean.
If you want to configure a component that JPA uses, then you need to ensure that the component is
initialized before JPA. When the component is auto-configured, Spring Boot takes care of this for
you. For example, when Flyway is auto-configured, Hibernate is configured to depend upon Flyway
so that Flyway has a chance to initialize the database before Hibernate tries to use it.
/**
* {@link EntityManagerFactoryDependsOnPostProcessor} that ensures that
* {@link EntityManagerFactory} beans depend on the {@code elasticsearchClient} bean.
*/
@Component
static class ElasticsearchEntityManagerFactoryDependsOnPostProcessor
extends EntityManagerFactoryDependsOnPostProcessor {
ElasticsearchEntityManagerFactoryDependsOnPostProcessor() {
super("elasticsearchClient");
}
If you need to use jOOQ with multiple data sources, you should create your own DSLContext for each
one. Refer to JooqAutoConfiguration for more details.
349
10.10. Database Initialization
An SQL database can be initialized in different ways depending on what your stack is. Of course,
you can also do it manually, provided the database is a separate process. It is recommended to use a
single mechanism for schema generation.
JPA has features for DDL generation, and these can be set up to run on startup against the database.
This is controlled through two external properties:
• spring.jpa.generate-ddl (boolean) switches the feature on and off and is vendor independent.
You can set spring.jpa.hibernate.ddl-auto explicitly and the standard Hibernate property values
are none, validate, update, create, and create-drop. Spring Boot chooses a default value for you
based on whether it thinks your database is embedded. It defaults to create-drop if no schema
manager has been detected or none in all other cases. An embedded database is detected by looking
at the Connection type. hsqldb, h2, and derby are embedded, and others are not. Be careful when
switching from in-memory to a ‘real’ database that you do not make assumptions about the
existence of the tables and data in the new platform. You either have to set ddl-auto explicitly or
use one of the other mechanisms to initialize the database.
You can output the schema creation by enabling the org.hibernate.SQL logger. This
is done for you automatically if you enable the debug mode.
In addition, a file named import.sql in the root of the classpath is executed on startup if Hibernate
creates the schema from scratch (that is, if the ddl-auto property is set to create or create-drop).
This can be useful for demos and for testing if you are careful but is probably not something you
want to be on the classpath in production. It is a Hibernate feature (and has nothing to do with
Spring).
Spring Boot can automatically create the schema (DDL scripts) of your DataSource and initialize it
(DML scripts). It loads SQL from the standard root classpath locations: schema.sql and data.sql,
respectively. In addition, Spring Boot processes the schema-${platform}.sql and data-
${platform}.sql files (if present), where platform is the value of spring.datasource.platform. This
allows you to switch to database-specific scripts if necessary. For example, you might choose to set it
to the vendor name of the database (hsqldb, h2, oracle, mysql, postgresql, and so on).
350
When only basic SQL scripts are used, Spring Boot automatically creates the
schema of an embedded DataSource. This behavior can be customized by using the
spring.datasource.initialization-mode property. For instance, if you want to
always initialize the DataSource regardless of its type:
spring.datasource.initialization-mode=always
In a JPA-based app, you can choose to let Hibernate create the schema or use
schema.sql, but you cannot do both.
spring.jpa.hibernate.ddl-auto if you use schema.sql.
Make sure to disable
spring.jpa.hibernate.ddl-auto=none
If you are using a Higher-level Database Migration Tool, like Flyway or Liquibase,
you should use them alone to create and initialize the schema. Using the basic
schema.sql and data.sql scripts alongside Flyway or Liquibase is not recommended
and support will be removed in a future release.
By default, Spring Boot enables the fail-fast feature of the Spring JDBC initializer. This means that, if
the scripts cause exceptions, the application fails to start. You can tune that behavior by setting
spring.datasource.continue-on-error.
If you are using R2DBC, the regular DataSource auto-configuration backs off so none of the options
described above can be used.
If you are using Spring Data R2DBC, you can initialize the database on startup using SQL scripts as
shown in the following example:
@Configuration(proxyBeanMethods = false)
static class DatabaseInitializationConfiguration {
@Autowired
void initializeDatabase(ConnectionFactory connectionFactory) {
ResourceLoader resourceLoader = new DefaultResourceLoader();
Resource[] scripts = new Resource[] {
resourceLoader.getResource("classpath:schema.sql"),
resourceLoader.getResource("classpath:data.sql") };
new ResourceDatabasePopulator(scripts).execute(connectionFactory).block();
}
Alternatively, you can configure either Flyway or Liquibase to configure a DataSource for you for
the duration of the migration. Both these libraries offer properties to set the url, username and
351
password of the database to migrate.
If you use Spring Batch, it comes pre-packaged with SQL initialization scripts for most popular
database platforms. Spring Boot can detect your database type and execute those scripts on startup.
If you use an embedded database, this happens by default. You can also enable it for any database
type, as shown in the following example:
spring.batch.initialize-schema=always
You can also switch off the initialization explicitly by setting spring.batch.initialize-schema=never.
Spring Boot supports two higher-level migration tools: Flyway and Liquibase.
Typically, migrations are scripts in the form V<VERSION>__<NAME>.sql (with <VERSION> an underscore-
separated version, such as ‘1’ or ‘2_1’). By default, they are in a directory called
classpath:db/migration, but you can modify that location by setting spring.flyway.locations. This is
a comma-separated list of one or more classpath: or filesystem: locations. For example, the
following configuration would search for scripts in both the default classpath location and the
/opt/migration directory:
spring.flyway.locations=classpath:db/migration,filesystem:/opt/migration
You can also add a special {vendor} placeholder to use vendor-specific scripts. Assume the
following:
spring.flyway.locations=classpath:db/migration/{vendor}
Rather than using db/migration, the preceding configuration sets the directory to use according to
the type of the database (such as db/migration/mysql for MySQL). The list of supported databases is
available in DatabaseDriver.
Migrations can also be written in Java. Flyway will be auto-configured with any beans that
implement JavaMigration.
352
FlywayProperties provides most of Flyway’s settings and a small set of additional properties that can
be used to disable the migrations or switch off the location checking. If you need more control over
the configuration, consider registering a FlywayConfigurationCustomizer bean.
Spring Boot calls Flyway.migrate() to perform the database migration. If you would like more
control, provide a @Bean that implements FlywayMigrationStrategy.
Flyway supports SQL and Java callbacks. To use SQL-based callbacks, place the callback scripts in
the classpath:db/migration directory. To use Java-based callbacks, create one or more beans that
implement Callback. Any such beans are automatically registered with Flyway. They can be ordered
by using @Order or by implementing Ordered. Beans that implement the deprecated FlywayCallback
interface can also be detected, however they cannot be used alongside Callback beans.
By default, Flyway autowires the (@Primary) DataSource in your context and uses that for migrations.
If you like to use a different DataSource, you can create one and mark its @Bean as @FlywayDataSource.
If you do so and want two data sources, remember to create another one and mark it as @Primary.
Alternatively, you can use Flyway’s native DataSource by setting spring.flyway.[url,user,password]
in external properties. Setting either spring.flyway.url or spring.flyway.user is sufficient to cause
Flyway to use its own DataSource. If any of the three properties has not been set, the value of its
equivalent spring.datasource property will be used.
You can also use Flyway to provide data for specific scenarios. For example, you can place test-
specific migrations in src/test/resources and they are run only when your application starts for
testing. Also, you can use profile-specific configuration to customize spring.flyway.locations so that
certain migrations run only when a particular profile is active. For example, in application-
dev.properties, you might specify the following setting:
spring.flyway.locations=classpath:/db/migration,classpath:/dev/db/migration
With that setup, migrations in dev/db/migration run only when the dev profile is active.
By default, the master change log is read from db/changelog/db.changelog-master.yaml, but you can
change the location by setting spring.liquibase.change-log. In addition to YAML, Liquibase also
supports JSON, XML, and SQL change log formats.
By default, Liquibase autowires the (@Primary) DataSource in your context and uses that for
353
migrations. If you need to use a different DataSource, you can create one and mark its @Bean as
@LiquibaseDataSource. If you do so and you want two data sources, remember to create another one
and mark it as @Primary. Alternatively, you can use Liquibase’s native DataSource by setting
spring.liquibase.[url,user,password] in external properties. Setting either spring.liquibase.url or
spring.liquibase.user is sufficient to cause Liquibase to use its own DataSource. If any of the three
properties has not been set, the value of its equivalent spring.datasource property will be used.
See LiquibaseProperties for details about available settings such as contexts, the default schema,
and others.
10.11. Messaging
Spring Boot offers a number of starters that include messaging. This section answers questions that
arise from using messaging with Spring Boot.
If your JMS broker does not support transacted sessions, you have to disable the support of
transactions altogether. If you create your own JmsListenerContainerFactory, there is nothing to do,
since, by default it cannot be transacted. If you want to use the
DefaultJmsListenerContainerFactoryConfigurer to reuse Spring Boot’s default, you can disable
transacted sessions, as follows:
@Bean
public DefaultJmsListenerContainerFactory jmsListenerContainerFactory(
ConnectionFactory connectionFactory,
DefaultJmsListenerContainerFactoryConfigurer configurer) {
DefaultJmsListenerContainerFactory listenerFactory =
new DefaultJmsListenerContainerFactory();
configurer.configure(listenerFactory, connectionFactory);
listenerFactory.setTransactionManager(null);
listenerFactory.setSessionTransacted(false);
return listenerFactory;
}
The preceding example overrides the default factory, and it should be applied to any other factory
that your application defines, if any.
By default, batch applications require a DataSource to store job details. Spring Batch expects a single
DataSource by default. To have it use a DataSource other than the application’s main DataSource,
354
declare a DataSource bean, annotating its @Bean method with @BatchDataSource. If you do so and want
two data sources, remember to mark the other one @Primary. To take greater control, implement
BatchConfigurer. See The Javadoc of @EnableBatchProcessing for more details.
For more info about Spring Batch, see the Spring Batch project page.
Spring Boot converts any command line argument starting with -- to a property to add to the
Environment, see accessing command line properties. This should not be used to pass arguments to
batch jobs. To specify batch arguments on the command line, use the regular format (i.e. without --
), as shown in the following example:
If you specify a property of the Environment on the command line, it is ignored by the job. Consider
the following command:
Spring Batch requires a data store for the Job repository. If you use Spring Boot, you must use an
actual database. Note that it can be an in-memory database, see Configuring a Job Repository.
10.13. Actuator
Spring Boot includes the Spring Boot Actuator. This section answers questions that often arise from
its use.
In a standalone application, the Actuator HTTP port defaults to the same as the main HTTP port. To
make the application listen on a different port, set the external property: management.server.port. To
355
listen on a completely different network address (such as when you have an internal network for
management and an external one for user applications), you can also set management.server.address
to a valid IP address to which the server is able to bind.
For more detail, see the ManagementServerProperties source code and “Customizing the Management
Server Port” in the “Production-ready features” section.
Spring Boot installs a ‘whitelabel’ error page that you see in a browser client if you encounter a
server error (machine clients consuming JSON and other media types should see a sensible
response with the right error code).
Overriding the error page with your own depends on the templating technology that you use. For
example, if you use Thymeleaf, you can add an error.html template. If you use FreeMarker, you can
add an error.ftlh template. In general, you need a View that resolves with a name of error or a
@Controller that handles the /error path. Unless you replaced some of the default configuration,
you should find a BeanNameViewResolver in your ApplicationContext, so a @Bean named error would
be one way of doing that. See ErrorMvcAutoConfiguration for more options.
See also the section on “Error Handling” for details of how to register handlers in the servlet
container.
Information returned by the env and configprops endpoints can be somewhat sensitive so keys
matching a certain pattern are sanitized by default (i.e. their values are replaced by ******).
Spring Boot uses sensible defaults for such keys: any key ending with the word "password", "secret",
"key", "token", "vcap_services", "sun.java.command" is entirely sanitized. Additionally, any key that
holds the word credentials as part of the key is sanitized (configured as a regular expression, i.e.
*credentials.*).
Furthermore, Spring Boot only sanitizes the sensitive portion of URIs for keys which end with "uri",
"uris", "address", or "addresses". The sensitive portion of the URI is identified using the format
<scheme>://<username>:<password>@<host>:<port>/. For example, for the property
myclient.uri=http://user1:password1@localhost:8081, the resulting sanitized value is
http://user1:******@localhost:8081.
356
10.13.4. Map Health Indicators to Micrometer Metrics
Spring Boot health indicators return a Status type to indicate the overall system health. If you want
to monitor or alert on levels of health for a particular application, you can export these statuses as
metrics via Micrometer. By default, the status codes “UP”, “DOWN”, “OUT_OF_SERVICE” and
“UNKNOWN” are used by Spring Boot. To export these, you’ll need to convert these states to some
set of numbers so that they can be used with a Micrometer Gauge.
@Configuration
public class HealthMetricsConfiguration {
10.14. Security
This section addresses questions about security when working with Spring Boot, including
questions that arise from using Spring Security with Spring Boot.
For more about Spring Security, see the Spring Security project page.
357
10.14.2. Change the UserDetailsService and Add User Accounts
The easiest way to add user accounts is to provide your own UserDetailsService bean.
Ensuring that all your main endpoints are only available over HTTPS is an important chore for any
application. If you use Tomcat as a servlet container, then Spring Boot adds Tomcat’s own
RemoteIpValve automatically if it detects some environment settings, and you should be able to rely
on the HttpServletRequest to report whether it is secure or not (even downstream of a proxy server
that handles the real SSL termination). The standard behavior is determined by the presence or
absence of certain request headers (x-forwarded-for and x-forwarded-proto), whose names are
conventional, so it should work with most front-end proxies. You can switch on the valve by adding
some entries to application.properties, as shown in the following example:
server.tomcat.remoteip.remote-ip-header=x-forwarded-for
server.tomcat.remoteip.protocol-header=x-forwarded-proto
(The presence of either of those properties switches on the valve. Alternatively, you can add the
RemoteIpValve by customizing the TomcatServletWebServerFactory using a WebServerFactoryCustomizer
bean.)
To configure Spring Security to require a secure channel for all (or some) requests, consider adding
your own WebSecurityConfigurerAdapter that adds the following HttpSecurity configuration:
@Configuration(proxyBeanMethods = false)
public class SslWebSecurityConfigurerAdapter extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
// Customize the application security
http.requiresChannel().anyRequest().requiresSecure();
}
There are several options for hot reloading. The recommended approach is to use spring-boot-
358
devtools, as it provides additional development-time features, such as support for fast application
restarts and LiveReload as well as sensible development-time configuration (such as template
caching). Devtools works by monitoring the classpath for changes. This means that static resource
changes must be "built" for the change to take effect. By default, this happens automatically in
Eclipse when you save your changes. In IntelliJ IDEA, the Make Project command triggers the
necessary build. Due to the default restart exclusions, changes to static resources do not trigger a
restart of your application. They do, however, trigger a live reload.
Alternatively, running in an IDE (especially with debugging on) is a good way to do development
(all modern IDEs allow reloading of static resources and usually also allow hot-swapping of Java
class changes).
Finally, the Maven and Gradle plugins can be configured (see the addResources property) to support
running from the command line with reloading of static files directly from source. You can use that
with an external css/js compiler process if you are writing that code with higher-level tools.
Most of the templating technologies supported by Spring Boot include a configuration option to
disable caching (described later in this document). If you use the spring-boot-devtools module,
these properties are automatically configured for you at development time.
Thymeleaf Templates
If you use Thymeleaf, set spring.thymeleaf.cache to false. See ThymeleafAutoConfiguration for other
Thymeleaf customization options.
FreeMarker Templates
Groovy Templates
The spring-boot-devtools module includes support for automatic application restarts. While not as
fast as technologies such as JRebel it is usually significantly faster than a “cold start”. You should
probably give it a try before investigating some of the more complex reload options discussed later
in this document.
Many modern IDEs (Eclipse, IDEA, and others) support hot swapping of bytecode. Consequently, if
you make a change that does not affect class or method signatures, it should reload cleanly with no
359
side effects.
10.16. Build
Spring Boot includes build plugins for Maven and Gradle. This section answers common questions
about these plugins.
Both the Maven plugin and the Gradle plugin allow generating build information containing the
coordinates, name, and version of the project. The plugins can also be configured to add additional
properties through configuration. When such a file is present, Spring Boot auto-configures a
BuildProperties bean.
To generate build information with Maven, add an execution for the build-info goal, as shown in
the following example:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.3.12.RELEASE</version>
<executions>
<execution>
<goals>
<goal>build-info</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
See the Spring Boot Maven Plugin documentation for more details.
springBoot {
buildInfo()
}
See the Spring Boot Gradle Plugin documentation for more details.
360
10.16.2. Generate Git Information
Both Maven and Gradle allow generating a git.properties file containing information about the
state of your git source code repository when the project was built.
For Maven users, the spring-boot-starter-parent POM includes a pre-configured plugin to generate
a git.properties file. To use it, add the following declaration to your POM:
<build>
<plugins>
<plugin>
<groupId>pl.project13.maven</groupId>
<artifactId>git-commit-id-plugin</artifactId>
</plugin>
</plugins>
</build>
Gradle users can achieve the same result by using the gradle-git-properties plugin, as shown in the
following example:
plugins {
id "com.gorylenko.gradle-git-properties" version "2.2.4"
}
Both the Maven and Gradle plugins allow the properties that are included in git.properties to be
configured.
The spring-boot-dependencies POM manages the versions of common dependencies. The Spring
Boot plugins for Maven and Gradle allow these managed dependency versions to be customized
using build properties.
Each Spring Boot release is designed and tested against this specific set of third-
party dependencies. Overriding versions may cause compatibility issues.
To override dependency versions with Maven, see this section of the Maven plugin’s
documentation.
To override dependency versions in Gradle, see this section of the Gradle plugin’s documentation.
361
10.16.4. Create an Executable JAR with Maven
The spring-boot-maven-plugin can be used to create an executable “fat” JAR. If you use the spring-
boot-starter-parent POM, you can declare the plugin and your jars are repackaged as follows:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
If you do not use the parent POM, you can still use the plugin. However, you must additionally add
an <executions> section, as follows:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.3.12.RELEASE</version>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
Like a war file, a Spring Boot application is not intended to be used as a dependency. If your
application contains classes that you want to share with other projects, the recommended approach
is to move that code into a separate module. The separate module can then be depended upon by
your application and other projects.
If you cannot rearrange your code as recommended above, Spring Boot’s Maven and Gradle plugins
must be configured to produce a separate artifact that is suitable for use as a dependency. The
executable archive cannot be used as a dependency as the executable jar format packages
application classes in BOOT-INF/classes. This means that they cannot be found when the executable
jar is used as a dependency.
362
To produce the two artifacts, one that can be used as a dependency and one that is executable, a
classifier must be specified. This classifier is applied to the name of the executable archive, leaving
the default archive for use as a dependency.
To configure a classifier of exec in Maven, you can use the following configuration:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<classifier>exec</classifier>
</configuration>
</plugin>
</plugins>
</build>
Most nested libraries in an executable jar do not need to be unpacked in order to run. However,
certain libraries can have problems. For example, JRuby includes its own nested jar support, which
assumes that the jruby-complete.jar is always directly available as a file in its own right.
To deal with any problematic libraries, you can flag that specific nested jars should be
automatically unpacked when the executable jar first runs. Such nested jars are written beneath
the temporary directory identified by the java.io.tmpdir system property.
Care should be taken to ensure that your operating system is configured so that it
will not delete the jars that have been unpacked to the temporary directory while
the application is still running.
For example, to indicate that JRuby should be flagged for unpacking by using the Maven Plugin, you
would add the following configuration:
363
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<requiresUnpack>
<dependency>
<groupId>org.jruby</groupId>
<artifactId>jruby-complete</artifactId>
</dependency>
</requiresUnpack>
</configuration>
</plugin>
</plugins>
</build>
Often, if you have an executable and a non-executable jar as two separate build products, the
executable version has additional configuration files that are not needed in a library jar. For
example, the application.yml configuration file might be excluded from the non-executable JAR.
In Maven, the executable jar must be the main artifact and you can add a classified jar for the
library, as follows:
364
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<plugin>
<artifactId>maven-jar-plugin</artifactId>
<executions>
<execution>
<id>lib</id>
<phase>package</phase>
<goals>
<goal>jar</goal>
</goals>
<configuration>
<classifier>lib</classifier>
<excludes>
<exclude>application.yml</exclude>
</excludes>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
To attach a remote debugger to a Spring Boot application that was started with Maven, you can use
the jvmArguments property of the maven plugin.
To build with Ant, you need to grab dependencies, compile, and then create a jar or war archive. To
make it executable, you can either use the spring-boot-antlib module or you can follow these
instructions:
1. If you are building a jar, package the application’s classes and resources in a nested BOOT-
INF/classes directory. If you are building a war, package the application’s classes in a nested
WEB-INF/classes directory as usual.
2. Add the runtime dependencies in a nested BOOT-INF/lib directory for a jar or WEB-INF/lib for a
war. Remember not to compress the entries in the archive.
3. Add the provided (embedded container) dependencies in a nested BOOT-INF/lib directory for a
jar or WEB-INF/lib-provided for a war. Remember not to compress the entries in the archive.
365
4. Add the spring-boot-loader classes at the root of the archive (so that the Main-Class is available).
5. Use the appropriate launcher (such as JarLauncher for a jar file) as a Main-Class attribute in the
manifest and specify the other properties it needs as manifest entries — principally, by setting a
Start-Class property.
The following example shows how to build an executable archive with Ant:
Because Spring WebFlux does not strictly depend on the Servlet API and
applications are deployed by default on an embedded Reactor Netty server, War
deployment is not supported for WebFlux applications.
366
as shown in the following example:
@SpringBootApplication
public class Application extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application)
{
return application.sources(Application.class);
}
The next step is to update your build configuration such that your project produces a war file
rather than a jar file. If you use Maven and spring-boot-starter-parent (which configures Maven’s
war plugin for you), all you need to do is to modify pom.xml to change the packaging to war, as
follows:
<packaging>war</packaging>
If you use Gradle, you need to modify build.gradle to apply the war plugin to the project, as follows:
The final step in the process is to ensure that the embedded servlet container does not interfere
with the servlet container to which the war file is deployed. To do so, you need to mark the
embedded servlet container dependency as being provided.
If you use Maven, the following example marks the servlet container (Tomcat, in this case) as being
provided:
<dependencies>
<!-- … -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<!-- … -->
</dependencies>
If you use Gradle, the following example marks the servlet container (Tomcat, in this case) as being
367
provided:
dependencies {
// …
providedRuntime 'org.springframework.boot:spring-boot-starter-tomcat'
// …
}
If you use the Spring Boot build tools, marking the embedded servlet container dependency as
provided produces an executable war file with the provided dependencies packaged in a lib-
provided directory. This means that, in addition to being deployable to a servlet container, you can
also run your application by using java -jar on the command line.
To convert an existing non-web Spring application to a Spring Boot application, replace the code
that creates your ApplicationContext and replace it with calls to SpringApplication or
SpringApplicationBuilder. Spring MVC web applications are generally amenable to first creating a
deployable war application and then migrating it later to an executable war or jar. See the Getting
Started Guide on Converting a jar to a war.
@SpringBootApplication
public class Application extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application)
{
// Customize the application or call application.sources(...) to add sources
// Since our example is itself a @Configuration class (via
@SpringBootApplication)
// we actually don't need to override this method.
return application;
}
Remember that, whatever you put in the sources is merely a Spring ApplicationContext. Normally,
anything that already works should work here. There might be some beans you can remove later
and let Spring Boot provide its own defaults for them, but it should be possible to get something
368
working before you need to do that.
Static resources can be moved to /public (or /static or /resources or /META-INF/resources) in the
classpath root. The same applies to messages.properties (which Spring Boot automatically detects in
the root of the classpath).
Vanilla usage of Spring DispatcherServlet and Spring Security should require no further changes. If
you have other features in your application (for instance, using other servlets or filters), you may
need to add some configuration to your Application context, by replacing those elements from the
web.xml, as follows:
• A @Bean of type Filter or FilterRegistrationBean behaves similarly (as a <filter/> and <filter-
mapping/>).
Once the war file is working, you can make it executable by adding a main method to your
Application, as shown in the following example:
369
If you intend to start your application as a war or as an executable application, you
need to share the customizations of the builder in a method that is both available
to the SpringBootServletInitializer callback and in the main method in a class
similar to the following:
@SpringBootApplication
public class Application extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder
configure(SpringApplicationBuilder builder) {
return configureApplication(builder);
}
All of these should be amenable to translation, but each might require slightly different techniques.
Servlet 3.0+ applications might translate pretty easily if they already use the Spring Servlet 3.0+
initializer support classes. Normally, all the code from an existing WebApplicationInitializer can be
moved into a SpringBootServletInitializer. If your existing application has more than one
ApplicationContext (for example, if it uses AbstractDispatcherServletInitializer) then you might be
able to combine all your context sources into a single SpringApplication. The main complication you
might encounter is if combining does not work and you need to maintain the context hierarchy. See
the entry on building a hierarchy for examples. An existing parent context that contains web-
specific features usually needs to be broken up so that all the ServletContextAware components are
in the child context.
Applications that are not already Spring applications might be convertible to Spring Boot
applications, and the previously mentioned guidance may help. However, you may yet encounter
370
problems. In that case, we suggest asking questions on Stack Overflow with a tag of spring-boot.
To deploy a Spring Boot application to WebLogic, you must ensure that your servlet initializer
directly implements WebApplicationInitializer (even if you extend from a base class that already
implements it).
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;
import org.springframework.web.WebApplicationInitializer;
@SpringBootApplication
public class MyApplication extends SpringBootServletInitializer implements
WebApplicationInitializer {
If you use Logback, you also need to tell WebLogic to prefer the packaged version rather than the
version that was pre-installed with the server. You can do so by adding a WEB-INF/weblogic.xml file
with the following contents:
By default, the Spring Boot starter (spring-boot-starter-data-redis) uses Lettuce. You need to
exclude that dependency and include the Jedis one instead. Spring Boot manages both of these
dependencies so you can switch to Jedis without specifying a version.
371
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<exclusions>
<exclusion>
<groupId>io.lettuce</groupId>
<artifactId>lettuce-core</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
</dependency>
dependencies {
implementation('org.springframework.boot:spring-boot-starter-data-redis') {
exclude group: 'io.lettuce', module: 'lettuce-core'
}
implementation 'redis.clients:jedis'
// ...
}
The Testcontainers library provides a way to manage services running inside Docker containers. It
integrates with JUnit, allowing you to write a test class that can start up a container before any of
the tests run. Testcontainers is especially useful for writing integration tests that talk to a real
backend service such as MySQL, MongoDB, Cassandra etc. Testcontainers can be used in a Spring
Boot test as follows:
@SpringBootTest
@Testcontainers
class ExampleIntegrationTests {
@Container
static Neo4jContainer<?> neo4j = new Neo4jContainer<>();
This will start up a docker container running Neo4j (if Docker is running locally) before any of the
tests are run. In most cases, you will need to configure the application using details from the
running container, such as container IP or port.
This can be done with a static @DynamicPropertySource method that allows adding dynamic property
372
values to the Spring Environment.
@SpringBootTest
@Testcontainers
class ExampleIntegrationTests {
@Container
static Neo4jContainer<?> neo4j = new Neo4jContainer<>();
@DynamicPropertySource
static void neo4jProperties(DynamicPropertyRegistry registry) {
registry.add("spring.data.neo4j.uri", neo4j::getBoltUrl);
}
The above configuration allows Neo4j-related beans in the application to communicate with Neo4j
running inside the Testcontainers-managed Docker container.
373
Chapter 11. Appendices
Appendix A: Common Application properties
Various properties can be specified inside your application.properties file, inside your
application.yml file, or as command line switches. This appendix provides a list of common Spring
Boot properties and references to the underlying classes that consume them.
Property contributions can come from additional jar files on your classpath, so you
should not consider this an exhaustive list. Also, you can define your own
properties.
374
Key Default Value Description
logging.level.* Log levels severity mapping. For instance,
`logging.level.org.springframework=DEBUG`.
logging.pattern.consol %clr(%d{${LOG_DATEFORM Appender pattern for output to the console.
e AT_PATTERN:-yyyy-MM-dd Supported only with the default Logback setup.
HH:mm:ss.SSS}}){faint}
%clr(${LOG_LEVEL_PATTE
RN:-%5p}) %clr(${PID:-
}){magenta} %clr(---
){faint}
%clr([%15.15t]){faint}
%clr(%-
40.40logger{39}){cyan}
%clr(:){faint}
%m%n${LOG_EXCEPTION_CO
NVERSION_WORD:-%wEx}
logging.pattern.datefo yyyy-MM-dd Appender pattern for log date format. Supported
rmat HH:mm:ss.SSS only with the default Logback setup.
logging.pattern.file %d{${LOG_DATEFORMAT_PA Appender pattern for output to a file. Supported
TTERN:-yyyy-MM-dd only with the default Logback setup.
HH:mm:ss.SSS}}
${LOG_LEVEL_PATTERN:-
%5p} ${PID:- } ---
[%t] %-40.40logger{39}
:
%m%n${LOG_EXCEPTION_CO
NVERSION_WORD:-%wEx}
logging.pattern.level %5p Appender pattern for log level. Supported only
with the default Logback setup.
logging.pattern.rollin ${LOG_FILE}.%d{yyyy- Pattern for rolled-over log file names. Supported
g-file-name MM-dd}.%i.gz only with the default Logback setup.
logging.register- false Register a shutdown hook for the logging system
shutdown-hook when it is initialized.
spring.aop.auto true Add @EnableAspectJAutoProxy.
spring.aop.proxy- true Whether subclass-based (CGLIB) proxies are to
target-class be created (true), as opposed to standard Java
interface-based proxies (false).
spring.application.adm false Whether to enable admin features for the
in.enabled application.
spring.application.adm org.springframework.bo JMX name of the application admin MBean.
in.jmx-name ot:type=Admin,name=Spr
ingApplication
spring.application.nam Application name.
e
spring.autoconfigure.e Auto-configuration classes to exclude.
xclude
spring.banner.charset UTF-8 Banner file encoding.
375
Key Default Value Description
spring.banner.image.bi 4 Bit depth to use for ANSI colors. Supported
tdepth values are 4 (16 color) or 8 (256 color).
spring.banner.image.he Height of the banner image in chars (default
ight based on image height).
spring.banner.image.in false Whether images should be inverted for dark
vert terminal themes.
spring.banner.image.lo classpath:banner.gif Banner image file location (jpg or png can also
cation be used).
spring.banner.image.ma 2 Left hand image margin in chars.
rgin
spring.banner.image.pi TEXT Pixel mode to use when rendering the image.
xelmode
spring.banner.image.wi 76 Width of the banner image in chars.
dth
spring.banner.location classpath:banner.txt Banner text resource location.
spring.beaninfo.ignore true Whether to skip search of BeanInfo classes.
spring.codec.log- false Whether to log form data at DEBUG level, and
request-details headers at TRACE level.
spring.codec.max-in- Limit on the number of bytes that can be
memory-size buffered whenever the input stream needs to be
aggregated. This applies only to the auto-
configured WebFlux server and WebClient
instances. By default this is not set, in which case
individual codec defaults apply. Most codecs are
limited to 256K by default.
spring.config.addition Config file locations used in addition to the
al-location defaults.
spring.config.location Config file locations that replace the defaults.
spring.config.name application Config file name.
spring.info.build.enco UTF-8 File encoding.
ding
spring.info.build.loca classpath:META- Location of the generated build-info.properties
tion INF/build- file.
info.properties
spring.info.git.encodi UTF-8 File encoding.
ng
spring.info.git.locati classpath:git.properti Location of the generated git.properties file.
on es
spring.jmx.default- JMX domain name.
domain
spring.jmx.enabled false Expose management beans to the JMX domain.
376
Key Default Value Description
spring.jmx.server mbeanServer MBeanServer bean name.
spring.jmx.unique- false Whether unique runtime object names should
names be ensured.
spring.lifecycle.timeo 30s Timeout for the shutdown of any phase (group
ut-per-shutdown-phase of SmartLifecycle beans with the same 'phase'
value).
spring.main.allow- false Whether bean definition overriding, by
bean-definition- registering a definition with the same name as
overriding
an existing definition, is allowed.
spring.main.banner- console Mode used to display the banner when the
mode application runs.
spring.main.cloud- Override the Cloud Platform auto-detection.
platform
spring.main.lazy- false Whether initialization should be performed
initialization lazily.
spring.main.log- true Whether to log information about the
startup-info application when it starts.
spring.main.register- true Whether the application should have a
shutdown-hook shutdown hook registered.
spring.main.sources Sources (class names, package names, or XML
resource locations) to include in the
ApplicationContext.
spring.main.web- Flag to explicitly request a specific type of web
application-type application. If not set, auto-detected based on
the classpath.
spring.mandatory-file- Expected character encoding the application
encoding must use.
spring.messages.always false Whether to always apply the MessageFormat
-use-message-format rules, parsing even messages without
arguments.
spring.messages.basena messages Comma-separated list of basenames (essentially
me a fully-qualified classpath location), each
following the ResourceBundle convention with
relaxed support for slash based locations. If it
doesn't contain a package qualifier (such as
"org.mypackage"), it will be resolved from the
classpath root.
spring.messages.cache- Loaded resource bundle files cache duration.
duration When not set, bundles are cached forever. If a
duration suffix is not specified, seconds will be
used.
377
Key Default Value Description
spring.messages.encodi UTF-8 Message bundles encoding.
ng
spring.messages.fallba true Whether to fall back to the system Locale if no
ck-to-system-locale files for a specific Locale have been found. if this
is turned off, the only fallback will be the default
file (e.g. "messages.properties" for basename
"messages").
spring.messages.use- false Whether to use the message code as the default
code-as-default- message instead of throwing a
message
"NoSuchMessageException". Recommended
during development only.
spring.output.ansi.ena detect Configures the ANSI output.
bled
spring.pid.fail-on- Fails if ApplicationPidFileWriter is used but it
write-error cannot write the PID file.
spring.pid.file Location of the PID file to write (if
ApplicationPidFileWriter is used).
spring.profiles Comma-separated list of profile expressions that
at least one should match for the document to be
included.
spring.profiles.active Comma-separated list of active profiles. Can be
overridden by a command line switch.
spring.profiles.defaul default Name of the profile to enable if no profile is
t active.
spring.profiles.includ Unconditionally activate the specified comma-
e separated list of profiles (or list of profiles if
using YAML).
spring.quartz.auto- true Whether to automatically start the scheduler
startup after initialization.
spring.quartz.jdbc.com [#, --] Prefixes for single-line comments in SQL
ment-prefix initialization scripts.
spring.quartz.jdbc.ini embedded Database schema initialization mode.
tialize-schema
spring.quartz.jdbc.sch classpath:org/quartz/i Path to the SQL file to use to initialize the
ema mpl/jdbcjobstore/table database schema.
s_@@platform@@.sql
spring.quartz.job- memory Quartz job store type.
store-type
spring.quartz.overwrit false Whether configured jobs should overwrite
e-existing-jobs existing job definitions.
spring.quartz.properti Additional Quartz Scheduler properties.
es.*
378
Key Default Value Description
spring.quartz.schedule quartzScheduler Name of the scheduler.
r-name
spring.quartz.startup- 0s Delay after which the scheduler is started once
delay initialization completes. Setting this property
makes sense if no jobs should be run before the
entire application has started up.
spring.quartz.wait- false Whether to wait for running jobs to complete on
for-jobs-to-complete- shutdown.
on-shutdown
spring.reactor.debug- true Whether the Reactor Debug Agent should be
agent.enabled enabled when reactor-tools is present.
spring.task.execution. true Whether core threads are allowed to time out.
pool.allow-core- This enables dynamic growing and shrinking of
thread-timeout
the pool.
spring.task.execution. 8 Core number of threads.
pool.core-size
spring.task.execution. 60s Time limit for which threads may remain idle
pool.keep-alive before being terminated.
spring.task.execution. Maximum allowed number of threads. If tasks
pool.max-size are filling up the queue, the pool can expand up
to that size to accommodate the load. Ignored if
the queue is unbounded.
spring.task.execution. Queue capacity. An unbounded capacity does
pool.queue-capacity not increase the pool and therefore ignores the
"max-size" property.
spring.task.execution. false Whether the executor should wait for scheduled
shutdown.await- tasks to complete on shutdown.
termination
spring.task.execution. Maximum time the executor should wait for
shutdown.await- remaining tasks to complete.
termination-period
spring.task.execution. task- Prefix to use for the names of newly created
thread-name-prefix threads.
spring.task.scheduling 1 Maximum allowed number of threads.
.pool.size
spring.task.scheduling false Whether the executor should wait for scheduled
.shutdown.await- tasks to complete on shutdown.
termination
spring.task.scheduling Maximum time the executor should wait for
.shutdown.await- remaining tasks to complete.
termination-period
spring.task.scheduling scheduling- Prefix to use for the names of newly created
.thread-name-prefix threads.
379
Key Default Value Description
trace false Enable trace logs.
380
Key Default Value Description
spring.mail.default- UTF-8 Default MimeMessage encoding.
encoding
spring.mail.host SMTP server host. For instance,
`smtp.example.com`.
spring.mail.jndi-name Session JNDI name. When set, takes precedence
over other Session settings.
spring.mail.password Login password of the SMTP server.
spring.mail.port SMTP server port.
spring.mail.properties Additional JavaMail Session properties.
.*
spring.mail.protocol smtp Protocol used by the SMTP server.
spring.mail.test- false Whether to test that the mail server is available
connection on startup.
spring.mail.username Login user of the SMTP server.
spring.sendgrid.api- SendGrid API key.
key
spring.sendgrid.proxy. SendGrid proxy host.
host
spring.sendgrid.proxy. SendGrid proxy port.
port
381
Key Default Value Description
spring.gson.lenient Whether to be lenient about parsing JSON that
doesn't conform to RFC 4627.
spring.gson.long- Serialization policy for Long and long types.
serialization-policy
spring.gson.pretty- Whether to output serialized JSON that fits in a
printing page for pretty printing.
spring.gson.serialize- Whether to serialize null fields.
nulls
spring.jackson.date- Date format string or a fully-qualified date
format format class name. For instance, `yyyy-MM-dd
HH:mm:ss`.
spring.jackson.default Controls the inclusion of properties during
-property-inclusion serialization. Configured with one of the values
in Jackson's JsonInclude.Include enumeration.
spring.jackson.deseria Jackson on/off features that affect the way Java
lization.* objects are deserialized.
spring.jackson.generat Jackson on/off features for generators.
or.*
spring.jackson.locale Locale used for formatting.
spring.jackson.mapper. Jackson general purpose on/off features.
*
spring.jackson.parser. Jackson on/off features for parsers.
*
spring.jackson.propert One of the constants on Jackson's
y-naming-strategy PropertyNamingStrategy. Can also be a fully-
qualified class name of a
PropertyNamingStrategy subclass.
spring.jackson.seriali Jackson on/off features that affect the way Java
zation.* objects are serialized.
spring.jackson.time- Time zone used when formatting dates. For
zone instance, "America/Los_Angeles" or "GMT+10".
spring.jackson.visibil Jackson visibility thresholds that can be used to
ity.* limit which methods (and fields) are auto-
detected.
382
Key Default Value Description
spring.couchbase.env.i 4500ms Length of time an HTTP connection may remain
o.idle-http- idle before it is closed and removed from the
connection-timeout
pool.
spring.couchbase.env.i 12 Maximum number of sockets per node.
o.max-endpoints
spring.couchbase.env.i 1 Minimum number of sockets per node.
o.min-endpoints
spring.couchbase.env.s Whether to enable SSL support. Enabled
sl.enabled automatically if a "keyStore" is provided unless
specified otherwise.
spring.couchbase.env.s Path to the JVM key store that holds the
sl.key-store certificates.
spring.couchbase.env.s Password used to access the key store.
sl.key-store-password
spring.couchbase.env.t 75s Timeout for the analytics service.
imeouts.analytics
spring.couchbase.env.t 10s Bucket connect timeout.
imeouts.connect
spring.couchbase.env.t 10s Bucket disconnect timeout.
imeouts.disconnect
spring.couchbase.env.t 2500ms Timeout for operations on a specific key-value.
imeouts.key-value
spring.couchbase.env.t 10s Timeout for operations on a specific key-value
imeouts.key-value- with a durability level.
durable
spring.couchbase.env.t 75s Timeout for the management operations.
imeouts.management
spring.couchbase.env.t 75s N1QL query operations timeout.
imeouts.query
spring.couchbase.env.t 75s Timeout for the search service.
imeouts.search
spring.couchbase.env.t 75s Regular and geospatial view operations timeout.
imeouts.view
spring.couchbase.passw Cluster password.
ord
spring.couchbase.usern Cluster username.
ame
spring.dao.exceptiontr true Whether to enable the
anslation.enabled PersistenceExceptionTranslationPostProcessor.
spring.data.cassandra. none Compression supported by the Cassandra binary
compression protocol.
spring.data.cassandra. 5s Timeout to use when establishing driver
connection.connect- connections.
timeout
383
Key Default Value Description
spring.data.cassandra. 500ms Timeout to use for internal queries that run as
connection.init-query- part of the initialization process, just after a
timeout
connection is opened.
spring.data.cassandra. [127.0.0.1:9042] Cluster node addresses in the form 'host:port', or
contact-points a simple 'host' to use the configured port.
spring.data.cassandra. Keyspace name to use.
keyspace-name
spring.data.cassandra. Datacenter that is considered "local". Contact
local-datacenter points should be from this datacenter.
spring.data.cassandra. Login password of the server.
password
spring.data.cassandra. 30s Heartbeat interval after which a message is sent
pool.heartbeat- on an idle connection to make sure it's still alive.
interval
spring.data.cassandra. 120s Idle timeout before an idle connection is
pool.idle-timeout removed.
spring.data.cassandra. 9042 Port to use if a contact point does not specify
port one.
spring.data.cassandra. auto Type of Cassandra repositories to enable.
repositories.type
spring.data.cassandra. Queries consistency level.
request.consistency
spring.data.cassandra. 5000 How many rows will be retrieved
request.page-size simultaneously in a single network roundtrip.
spring.data.cassandra. Queries serial consistency level.
request.serial-
consistency
spring.data.cassandra. 10ms How often the throttler attempts to dequeue
request.throttler.drai requests. Set this high enough that each attempt
n-interval
will process multiple entries in the queue, but
not delay requests too much.
spring.data.cassandra. 10000 Maximum number of requests that are allowed
request.throttler.max- to execute in parallel.
concurrent-requests
spring.data.cassandra. 10000 Maximum number of requests that can be
request.throttler.max- enqueued when the throttling threshold is
queue-size
exceeded.
spring.data.cassandra. 10000 Maximum allowed request rate.
request.throttler.max-
requests-per-second
spring.data.cassandra. none Request throttling type.
request.throttler.type
384
Key Default Value Description
spring.data.cassandra. 2s How long the driver waits for a request to
request.timeout complete.
spring.data.cassandra. none Schema action to take at startup.
schema-action
spring.data.cassandra. Name of the Cassandra session.
session-name
spring.data.cassandra. false Enable SSL support.
ssl
spring.data.cassandra. Login user of the server.
username
spring.data.couchbase. false Automatically create views and indexes. Use the
auto-index meta-data provided by "@ViewIndexed",
"@N1qlPrimaryIndexed" and
"@N1qlSecondaryIndexed".
spring.data.couchbase. Name of the bucket to connect to.
bucket-name
spring.data.couchbase. Fully qualified name of the FieldNamingStrategy
field-naming-strategy to use.
spring.data.couchbase. auto Type of Couchbase repositories to enable.
repositories.type
spring.data.couchbase. Name of the scope used for all collection access.
scope-name
spring.data.couchbase. _class Name of the field that stores the type
type-key information for complex types when using
"MappingCouchbaseConverter".
spring.data.elasticsea Connection timeout.
rch.client.reactive.co
nnection-timeout
spring.data.elasticsea Comma-separated list of the Elasticsearch
rch.client.reactive.en endpoints to connect to.
dpoints
spring.data.elasticsea Limit on the number of bytes that can be
rch.client.reactive.ma buffered whenever the input stream needs to be
x-in-memory-size
aggregated.
spring.data.elasticsea Credentials password.
rch.client.reactive.pa
ssword
spring.data.elasticsea Read and Write Socket timeout.
rch.client.reactive.so
cket-timeout
spring.data.elasticsea false Whether the client should use SSL to connect to
rch.client.reactive.us the endpoints.
e-ssl
385
Key Default Value Description
spring.data.elasticsea Credentials username.
rch.client.reactive.us
ername
spring.data.elasticsea true Whether to enable Elasticsearch repositories.
rch.repositories.enabl
ed
spring.data.jdbc.repos true Whether to enable JDBC repositories.
itories.enabled
spring.data.jpa.reposi default Bootstrap mode for JPA repositories.
tories.bootstrap-mode
spring.data.jpa.reposi true Whether to enable JPA repositories.
tories.enabled
spring.data.ldap.repos true Whether to enable LDAP repositories.
itories.enabled
spring.data.mongodb.au Authentication database name.
thentication-database
spring.data.mongodb.au Whether to enable auto-index creation.
to-index-creation
spring.data.mongodb.da Database name.
tabase
spring.data.mongodb.fi Fully qualified name of the FieldNamingStrategy
eld-naming-strategy to use.
spring.data.mongodb.gr GridFS database name.
id-fs-database
spring.data.mongodb.ho Mongo server host. Cannot be set with URI.
st
spring.data.mongodb.pa Login password of the mongo server. Cannot be
ssword set with URI.
spring.data.mongodb.po Mongo server port. Cannot be set with URI.
rt
spring.data.mongodb.re Required replica set name for the cluster.
plica-set-name Cannot be set with URI.
spring.data.mongodb.re auto Type of Mongo repositories to enable.
positories.type
spring.data.mongodb.ur mongodb://localhost/te Mongo database URI. Cannot be set with host,
i st port, credentials and replica set name.
spring.data.mongodb.us Login user of the mongo server. Cannot be set
ername with URI.
spring.data.mongodb.uu java-legacy Representation to use when converting a UUID
id-representation to a BSON binary value.
spring.data.neo4j.auto none Auto index mode.
-index
spring.data.neo4j.embe true Whether to enable embedded mode if the
dded.enabled embedded driver is available.
386
Key Default Value Description
spring.data.neo4j.open false Register OpenSessionInViewInterceptor that
-in-view binds a Neo4j Session to the thread for the entire
processing of the request.
spring.data.neo4j.pass Login password of the server.
word
spring.data.neo4j.repo true Whether to enable Neo4j repositories.
sitories.enabled
spring.data.neo4j.uri URI used by the driver. Auto-detected by default.
spring.data.neo4j.use- false Whether to use Neo4j native types wherever
native-types possible.
spring.data.neo4j.user Login user of the server.
name
spring.data.r2dbc.repo true Whether to enable R2DBC repositories.
sitories.enabled
spring.data.redis.repo true Whether to enable Redis repositories.
sitories.enabled
spring.data.rest.base- Base path to be used by Spring Data REST to
path expose repository resources.
spring.data.rest.defau Content type to use as a default when none is
lt-media-type specified.
spring.data.rest.defau Default size of pages.
lt-page-size
spring.data.rest.detec default Strategy to use to determine which repositories
tion-strategy get exposed.
spring.data.rest.enabl Whether to enable enum value translation
e-enum-translation through the Spring Data REST default resource
bundle.
spring.data.rest.limit Name of the URL query string parameter that
-param-name indicates how many results to return at once.
spring.data.rest.max- Maximum size of pages.
page-size
spring.data.rest.page- Name of the URL query string parameter that
param-name indicates what page to return.
spring.data.rest.retur Whether to return a response body after
n-body-on-create creating an entity.
spring.data.rest.retur Whether to return a response body after
n-body-on-update updating an entity.
spring.data.rest.sort- Name of the URL query string parameter that
param-name indicates what direction to sort results.
spring.data.solr.host http://127.0.0.1:8983/ Solr host. Ignored if "zk-host" is set.
solr
387
Key Default Value Description
spring.data.solr.zk- ZooKeeper host address in the form HOST:PORT.
host
spring.data.web.pageab 20 Default page size.
le.default-page-size
spring.data.web.pageab 2000 Maximum page size to be accepted.
le.max-page-size
spring.data.web.pageab false Whether to expose and assume 1-based page
le.one-indexed- number indexes. Defaults to "false", meaning a
parameters
page number of 0 in the request equals the first
page.
spring.data.web.pageab page Page index parameter name.
le.page-parameter
spring.data.web.pageab General prefix to be prepended to the page
le.prefix number and page size parameters.
spring.data.web.pageab _ Delimiter to be used between the qualifier and
le.qualifier-delimiter the actual page number and size properties.
spring.data.web.pageab size Page size parameter name.
le.size-parameter
spring.data.web.sort.s sort Sort parameter name.
ort-parameter
spring.datasource.cont false Whether to stop if an error occurs while
inue-on-error initializing the database.
spring.datasource.data Data (DML) script resource references.
spring.datasource.data Password of the database to execute DML scripts
-password (if different).
spring.datasource.data Username of the database to execute DML
-username scripts (if different).
388
Key Default Value Description
spring.datasource.dbcp Commons DBCP2 specific settings bound to an
2.abandoned-usage- instance of DBCP2's BasicDataSource
tracking
spring.datasource.dbcp
2.access-to-
underlying-connection-
allowed
spring.datasource.dbcp
2.auto-commit-on-
return
spring.datasource.dbcp
2.cache-state
spring.datasource.dbcp
2.connection-factory-
class-name
spring.datasource.dbcp
2.connection-init-sqls
spring.datasource.dbcp
2.default-auto-commit
spring.datasource.dbcp
2.default-catalog
spring.datasource.dbcp
2.default-query-
timeout
spring.datasource.dbcp
2.default-read-only
spring.datasource.dbcp
2.default-schema
spring.datasource.dbcp
2.default-transaction-
isolation
spring.datasource.dbcp
2.disconnection-sql-
codes
spring.datasource.dbcp
2.driver
spring.datasource.dbcp
2.driver-class-name
spring.datasource.dbcp
2.eviction-policy-
class-name
spring.datasource.dbcp
2.fast-fail-validation
spring.datasource.dbcp
2.initial-size
spring.datasource.dbcp
2.jmx-name
spring.datasource.dbcp
2.lifo
389
Key Default Value Description
spring.datasource.driv Fully qualified name of the JDBC driver. Auto-
er-class-name detected based on the URL by default.
spring.datasource.gene true Whether to generate a random datasource
rate-unique-name name.
390
Key Default Value Description
spring.datasource.hika Hikari specific settings bound to an instance of
ri.allow-pool- Hikari's HikariDataSource
suspension
spring.datasource.hika
ri.auto-commit
spring.datasource.hika
ri.catalog
spring.datasource.hika
ri.connection-init-sql
spring.datasource.hika
ri.connection-test-
query
spring.datasource.hika
ri.connection-timeout
spring.datasource.hika
ri.data-source-class-
name
spring.datasource.hika
ri.data-source-j-n-d-i
spring.datasource.hika
ri.data-source-
properties
spring.datasource.hika
ri.driver-class-name
spring.datasource.hika
ri.exception-override-
class-name
spring.datasource.hika
ri.health-check-
properties
spring.datasource.hika
ri.health-check-
registry
spring.datasource.hika
ri.idle-timeout
spring.datasource.hika
ri.initialization-
fail-timeout
spring.datasource.hika
ri.isolate-internal-
queries
spring.datasource.hika
ri.jdbc-url
spring.datasource.hika
ri.leak-detection-
threshold
spring.datasource.hika
ri.login-timeout
spring.datasource.hika
ri.max-lifetime
391
Key Default Value Description
spring.datasource.init embedded Mode to apply when determining if DataSource
ialization-mode initialization should be performed using the
available DDL and DML scripts.
spring.datasource.jndi JNDI location of the datasource. Class, url,
-name username and password are ignored when set.
spring.datasource.name Name of the datasource. Default to "testdb"
when using an embedded database.
spring.datasource.pass Login password of the database.
word
spring.datasource.plat all Platform to use in the DDL or DML scripts (such
form as schema-${platform}.sql or data-
${platform}.sql).
spring.datasource.sche Schema (DDL) script resource references.
ma
spring.datasource.sche Password of the database to execute DDL scripts
ma-password (if different).
spring.datasource.sche Username of the database to execute DDL scripts
ma-username (if different).
spring.datasource.sepa ; Statement separator in SQL initialization scripts.
rator
spring.datasource.sql- SQL scripts encoding.
script-encoding
392
Key Default Value Description
spring.datasource.tomc Tomcat datasource specific settings bound to an
at.abandon-when- instance of Tomcat JDBC's DataSource
percentage-full
spring.datasource.tomc
at.access-to-
underlying-connection-
allowed
spring.datasource.tomc
at.alternate-username-
allowed
spring.datasource.tomc
at.commit-on-return
spring.datasource.tomc
at.connection-
properties
spring.datasource.tomc
at.data-source
spring.datasource.tomc
at.data-source-j-n-d-i
spring.datasource.tomc
at.db-properties
spring.datasource.tomc
at.default-auto-commit
spring.datasource.tomc
at.default-catalog
spring.datasource.tomc
at.default-read-only
spring.datasource.tomc
at.default-
transaction-isolation
spring.datasource.tomc
at.driver-class-name
spring.datasource.tomc
at.fair-queue
spring.datasource.tomc
at.ignore-exception-
on-pre-load
spring.datasource.tomc
at.init-s-q-l
spring.datasource.tomc
at.initial-size
spring.datasource.tomc
at.jdbc-interceptors
spring.datasource.tomc
at.jmx-enabled
spring.datasource.tomc
at.log-abandoned
spring.datasource.tomc
at.log-validation-
393
Key Default Value Description
spring.datasource.type Fully qualified name of the connection pool
implementation to use. By default, it is auto-
detected from the classpath.
spring.datasource.url JDBC URL of the database.
spring.datasource.user Login username of the database.
name
spring.datasource.xa.d XA datasource fully qualified name.
ata-source-class-name
spring.datasource.xa.p Properties to pass to the XA data source.
roperties.*
spring.elasticsearch.r 1s Connection timeout.
est.connection-timeout
spring.elasticsearch.r Credentials password.
est.password
spring.elasticsearch.r 30s Read timeout.
est.read-timeout
spring.elasticsearch.r [http://localhost:9200 Comma-separated list of the Elasticsearch
est.uris ] instances to use.
spring.elasticsearch.r Credentials username.
est.username
spring.h2.console.enab false Whether to enable the console.
led
spring.h2.console.path /h2-console Path at which the console is available.
spring.h2.console.sett false Whether to enable trace output.
ings.trace
spring.h2.console.sett false Whether to enable remote access.
ings.web-allow-others
spring.influx.password Login password.
spring.influx.url URL of the InfluxDB instance to which to
connect.
spring.influx.user Login user.
spring.jdbc.template.f -1 Number of rows that should be fetched from the
etch-size database when more rows are needed. Use -1 to
use the JDBC driver's default configuration.
spring.jdbc.template.m -1 Maximum number of rows. Use -1 to use the
ax-rows JDBC driver's default configuration.
spring.jdbc.template.q Query timeout. Default is to use the JDBC
uery-timeout driver's default configuration. If a duration
suffix is not specified, seconds will be used.
spring.jooq.sql- SQL dialect to use. Auto-detected by default.
dialect
394
Key Default Value Description
spring.jpa.database Target database to operate on, auto-detected by
default. Can be alternatively set using the
"databasePlatform" property.
spring.jpa.database- Name of the target database to operate on, auto-
platform detected by default. Can be alternatively set
using the "Database" enum.
spring.jpa.generate- false Whether to initialize the schema on startup.
ddl
spring.jpa.hibernate.d DDL mode. This is actually a shortcut for the
dl-auto "hibernate.hbm2ddl.auto" property. Defaults to
"create-drop" when using an embedded
database and no schema manager was detected.
Otherwise, defaults to "none".
spring.jpa.hibernate.n Fully qualified name of the implicit naming
aming.implicit- strategy.
strategy
spring.jpa.hibernate.n Fully qualified name of the physical naming
aming.physical- strategy.
strategy
spring.jpa.hibernate.u Whether to use Hibernate's newer
se-new-id-generator- IdentifierGenerator for AUTO, TABLE and
mappings
SEQUENCE. This is actually a shortcut for the
"hibernate.id.new_generator_mappings"
property. When not specified will default to
"true".
spring.jpa.mapping- Mapping resources (equivalent to "mapping-file"
resources entries in persistence.xml).
spring.jpa.open-in- true Register OpenEntityManagerInViewInterceptor.
view Binds a JPA EntityManager to the thread for the
entire processing of the request.
spring.jpa.properties. Additional native properties to set on the JPA
* provider.
spring.jpa.show-sql false Whether to enable logging of SQL statements.
spring.ldap.anonymous- Whether read-only operations should use an
read-only anonymous environment. Disabled by default
unless a username is set.
spring.ldap.base Base suffix from which all operations should
originate.
spring.ldap.base- LDAP specification settings.
environment.*
spring.ldap.embedded.b List of base DNs.
ase-dn
395
Key Default Value Description
spring.ldap.embedded.c Embedded LDAP password.
redential.password
spring.ldap.embedded.c Embedded LDAP username.
redential.username
spring.ldap.embedded.l classpath:schema.ldif Schema (LDIF) script resource reference.
dif
spring.ldap.embedded.p 0 Embedded LDAP port.
ort
spring.ldap.embedded.v true Whether to enable LDAP schema validation.
alidation.enabled
spring.ldap.embedded.v Path to the custom schema.
alidation.schema
spring.ldap.password Login password of the server.
spring.ldap.urls LDAP URLs of the server.
spring.ldap.username Login username of the server.
spring.mongodb.embedde [sync_delay] Comma-separated list of features to enable. Uses
d.features the defaults of the configured version by default.
spring.mongodb.embedde Directory used for data storage.
d.storage.database-dir
spring.mongodb.embedde Maximum size of the oplog.
d.storage.oplog-size
spring.mongodb.embedde Name of the replica set.
d.storage.repl-set-
name
spring.mongodb.embedde 3.5.5 Version of Mongo to use.
d.version
spring.r2dbc.generate- false Whether to generate a random database name.
unique-name Ignore any configured name when enabled.
spring.r2dbc.name Database name. Set if no name is specified in the
url. Default to "testdb" when using an embedded
database.
spring.r2dbc.password Login password of the database. Set if no
password is specified in the url.
spring.r2dbc.pool.enab Whether pooling is enabled. Enabled
led automatically if "r2dbc-pool" is on the classpath.
spring.r2dbc.pool.init 10 Initial connection pool size.
ial-size
spring.r2dbc.pool.max- 30m Maximum amount of time that a connection is
idle-time allowed to sit idle in the pool.
spring.r2dbc.pool.max- 10 Maximal connection pool size.
size
spring.r2dbc.pool.vali Validation query.
dation-query
396
Key Default Value Description
spring.r2dbc.propertie Additional R2DBC options.
s.*
spring.r2dbc.url R2DBC URL of the database. database name,
username, password and pooling options
specified in the url take precedence over
individual options.
spring.r2dbc.username Login username of the database. Set if no
username is specified in the url.
spring.redis.client- Client name to be set on connections with
name CLIENT SETNAME.
spring.redis.cluster.m Maximum number of redirects to follow when
ax-redirects executing commands across the cluster.
spring.redis.cluster.n Comma-separated list of "host:port" pairs to
odes bootstrap from. This represents an "initial" list of
cluster nodes and is required to have at least
one entry.
spring.redis.database 0 Database index used by the connection factory.
spring.redis.host localhost Redis server host.
spring.redis.jedis.poo 8 Maximum number of connections that can be
l.max-active allocated by the pool at a given time. Use a
negative value for no limit.
spring.redis.jedis.poo 8 Maximum number of "idle" connections in the
l.max-idle pool. Use a negative value to indicate an
unlimited number of idle connections.
spring.redis.jedis.poo -1ms Maximum amount of time a connection
l.max-wait allocation should block before throwing an
exception when the pool is exhausted. Use a
negative value to block indefinitely.
spring.redis.jedis.poo 0 Target for the minimum number of idle
l.min-idle connections to maintain in the pool. This setting
only has an effect if both it and time between
eviction runs are positive.
spring.redis.jedis.poo Time between runs of the idle object evictor
l.time-between- thread. When positive, the idle object evictor
eviction-runs
thread starts, otherwise no idle object eviction is
performed.
spring.redis.lettuce.c false Whether adaptive topology refreshing using all
luster.refresh.adaptiv available refresh triggers should be used.
e
spring.redis.lettuce.c Cluster topology refresh period.
luster.refresh.period
397
Key Default Value Description
spring.redis.lettuce.p 8 Maximum number of connections that can be
ool.max-active allocated by the pool at a given time. Use a
negative value for no limit.
spring.redis.lettuce.p 8 Maximum number of "idle" connections in the
ool.max-idle pool. Use a negative value to indicate an
unlimited number of idle connections.
spring.redis.lettuce.p -1ms Maximum amount of time a connection
ool.max-wait allocation should block before throwing an
exception when the pool is exhausted. Use a
negative value to block indefinitely.
spring.redis.lettuce.p 0 Target for the minimum number of idle
ool.min-idle connections to maintain in the pool. This setting
only has an effect if both it and time between
eviction runs are positive.
spring.redis.lettuce.p Time between runs of the idle object evictor
ool.time-between- thread. When positive, the idle object evictor
eviction-runs
thread starts, otherwise no idle object eviction is
performed.
spring.redis.lettuce.s 100ms Shutdown timeout.
hutdown-timeout
spring.redis.password Login password of the redis server.
spring.redis.port 6379 Redis server port.
spring.redis.sentinel. Name of the Redis server.
master
spring.redis.sentinel. Comma-separated list of "host:port" pairs.
nodes
spring.redis.sentinel. Password for authenticating with sentinel(s).
password
spring.redis.ssl false Whether to enable SSL support.
spring.redis.timeout Connection timeout.
spring.redis.url Connection URL. Overrides host, port, and
password. User is ignored. Example:
redis://user:password@example.com:6379
398
Key Default Value Description
spring.jta.atomikos.co true Whether to ignore the transacted flag when
nnectionfactory.ignore creating session.
-session-transacted
-flag
spring.jta.atomikos.co false Whether local transactions are desired.
nnectionfactory.local-
transaction-mode
spring.jta.atomikos.co 60 Time, in seconds, between runs of the pool's
nnectionfactory.mainte maintenance thread.
nance-interval
spring.jta.atomikos.co 60 Time, in seconds, after which connections are
nnectionfactory.max- cleaned up from the pool.
idle-time
spring.jta.atomikos.co 0 Time, in seconds, that a connection can be
nnectionfactory.max- pooled for before being destroyed. 0 denotes no
lifetime
limit.
spring.jta.atomikos.co 1 Maximum size of the pool.
nnectionfactory.max-
pool-size
spring.jta.atomikos.co 1 Minimum size of the pool.
nnectionfactory.min-
pool-size
spring.jta.atomikos.co 0 Reap timeout, in seconds, for borrowed
nnectionfactory.reap- connections. 0 denotes no limit.
timeout
spring.jta.atomikos.co jmsConnectionFactory Unique name used to identify the resource
nnectionfactory.unique during recovery.
-resource-name
spring.jta.atomikos.co Vendor-specific implementation of
nnectionfactory.xa- XAConnectionFactory.
connection-factory-
class-name
spring.jta.atomikos.co Vendor-specific XA properties.
nnectionfactory.xa-
properties
spring.jta.atomikos.da 30 Timeout, in seconds, for borrowing connections
tasource.borrow- from the pool.
connection-timeout
spring.jta.atomikos.da true Whether to use concurrent connection
tasource.concurrent- validation.
connection-validation
spring.jta.atomikos.da Default isolation level of connections provided
tasource.default- by the pool.
isolation-level
spring.jta.atomikos.da 0 Timeout, in seconds, for establishing a database
tasource.login-timeout connection.
399
Key Default Value Description
spring.jta.atomikos.da 60 Time, in seconds, between runs of the pool's
tasource.maintenance- maintenance thread.
interval
spring.jta.atomikos.da 60 Time, in seconds, after which connections are
tasource.max-idle-time cleaned up from the pool.
spring.jta.atomikos.da 0 Time, in seconds, that a connection can be
tasource.max-lifetime pooled for before being destroyed. 0 denotes no
limit.
spring.jta.atomikos.da 1 Maximum size of the pool.
tasource.max-pool-size
spring.jta.atomikos.da 1 Minimum size of the pool.
tasource.min-pool-size
spring.jta.atomikos.da 0 Reap timeout, in seconds, for borrowed
tasource.reap-timeout connections. 0 denotes no limit.
spring.jta.atomikos.da SQL query or statement used to validate a
tasource.test-query connection before returning it.
spring.jta.atomikos.da dataSource Unique name used to identify the resource
tasource.unique- during recovery.
resource-name
spring.jta.atomikos.da Vendor-specific implementation of
tasource.xa-data- XAConnectionFactory.
source-class-name
spring.jta.atomikos.da Vendor-specific XA properties.
tasource.xa-properties
spring.jta.atomikos.pr true Specify whether sub-transactions are allowed.
operties.allow-sub-
transactions
spring.jta.atomikos.pr 500 Interval between checkpoints, expressed as the
operties.checkpoint- number of log writes between two checkpoints.
interval
A checkpoint reduces the log file size at the
expense of adding some overhead in the
runtime.
spring.jta.atomikos.pr 10000ms Default timeout for JTA transactions.
operties.default-jta-
timeout
spring.jta.atomikos.pr How long should normal shutdown (no-force)
operties.default-max- wait for transactions to complete.
wait-time-on-shutdown
spring.jta.atomikos.pr true Whether to enable disk logging.
operties.enable-
logging
spring.jta.atomikos.pr false Whether a VM shutdown should trigger forced
operties.force- shutdown of the transaction core.
shutdown-on-vm-exit
400
Key Default Value Description
spring.jta.atomikos.pr Directory in which the log files should be stored.
operties.log-base-dir Defaults to the current working directory.
spring.jta.atomikos.pr tmlog Transactions log file base name.
operties.log-base-name
spring.jta.atomikos.pr 50 Maximum number of active transactions.
operties.max-actives
spring.jta.atomikos.pr 300000ms Maximum timeout that can be allowed for
operties.max-timeout transactions.
spring.jta.atomikos.pr 10000ms Delay between two recovery scans.
operties.recovery.dela
y
spring.jta.atomikos.pr 86400000ms Delay after which recovery can cleanup pending
operties.recovery.forg ('orphaned') log entries.
et-orphaned-log-
entries-delay
spring.jta.atomikos.pr 5 Number of retry attempts to commit the
operties.recovery.max- transaction before throwing an exception.
retries
spring.jta.atomikos.pr 10000ms Delay between retry attempts.
operties.recovery.retr
y-interval
spring.jta.atomikos.pr true Whether sub-transactions should be joined
operties.serial-jta- when possible.
transactions
spring.jta.atomikos.pr Transaction manager implementation that
operties.service should be started.
spring.jta.atomikos.pr false Whether to use different (and concurrent)
operties.threaded-two- threads for two-phase commit on the
phase-commit
participating resources.
spring.jta.atomikos.pr The transaction manager's unique name.
operties.transaction- Defaults to the machine's IP address. If you plan
manager-unique-name
to run more than one transaction manager
against one database you must set this property
to a unique value.
spring.jta.bitronix.co 1 Number of connections to create when growing
nnectionfactory.acquir the pool.
e-increment
spring.jta.bitronix.co 1 Time, in seconds, to wait before trying to
nnectionfactory.acquis acquire a connection again after an invalid
ition-interval
connection was acquired.
spring.jta.bitronix.co 30 Timeout, in seconds, for acquiring connections
nnectionfactory.acquis from the pool.
ition-timeout
401
Key Default Value Description
spring.jta.bitronix.co false Whether the transaction manager should allow
nnectionfactory.allow- mixing XA and non-XA transactions.
local-transactions
spring.jta.bitronix.co false Whether the transaction timeout should be set
nnectionfactory.apply- on the XAResource when it is enlisted.
transaction-timeout
spring.jta.bitronix.co true Whether resources should be enlisted and
nnectionfactory.automa delisted automatically.
tic-enlisting-enabled
spring.jta.bitronix.co true Whether producers and consumers should be
nnectionfactory.cache- cached.
producers-consumers
spring.jta.bitronix.co Underlying implementation class name of the
nnectionfactory.class- XA resource.
name
spring.jta.bitronix.co true Whether the provider can run many
nnectionfactory.defer- transactions on the same connection and
connection-release
supports transaction interleaving.
spring.jta.bitronix.co false Whether this resource is disabled, meaning it's
nnectionfactory.disabl temporarily forbidden to acquire a connection
ed
from its pool.
spring.jta.bitronix.co Properties that should be set on the underlying
nnectionfactory.driver implementation.
-properties
spring.jta.bitronix.co
nnectionfactory.failed
spring.jta.bitronix.co false Whether recovery failures should be ignored.
nnectionfactory.ignore
-recovery-failures
spring.jta.bitronix.co 60 Time, in seconds, after which connections are
nnectionfactory.max- cleaned up from the pool.
idle-time
spring.jta.bitronix.co 0 Maximum size of the pool. 0 denotes no limit.
nnectionfactory.max-
pool-size
spring.jta.bitronix.co 0 Minimum size of the pool.
nnectionfactory.min-
pool-size
spring.jta.bitronix.co Password to use to connect to the JMS provider.
nnectionfactory.passwo
rd
spring.jta.bitronix.co false Whether connections in the ACCESSIBLE state
nnectionfactory.share- can be shared within the context of a
transaction-
connections transaction.
402
Key Default Value Description
spring.jta.bitronix.co 1 Position that this resource should take during
nnectionfactory.two- two-phase commit (always first is
pc-ordering-position
Integer.MIN_VALUE, always last is
Integer.MAX_VALUE).
spring.jta.bitronix.co jmsConnectionFactory Unique name used to identify the resource
nnectionfactory.unique during recovery.
-name
spring.jta.bitronix.co true Whether TMJOIN should be used when starting
nnectionfactory.use- XAResources.
tm-join
spring.jta.bitronix.co User to use to connect to the JMS provider.
nnectionfactory.user
spring.jta.bitronix.da 1 Number of connections to create when growing
tasource.acquire- the pool.
increment
spring.jta.bitronix.da 1 Time, in seconds, to wait before trying to
tasource.acquisition- acquire a connection again after an invalid
interval
connection was acquired.
spring.jta.bitronix.da 30 Timeout, in seconds, for acquiring connections
tasource.acquisition- from the pool.
timeout
spring.jta.bitronix.da false Whether the transaction manager should allow
tasource.allow-local- mixing XA and non-XA transactions.
transactions
spring.jta.bitronix.da false Whether the transaction timeout should be set
tasource.apply- on the XAResource when it is enlisted.
transaction-timeout
spring.jta.bitronix.da true Whether resources should be enlisted and
tasource.automatic- delisted automatically.
enlisting-enabled
spring.jta.bitronix.da Underlying implementation class name of the
tasource.class-name XA resource.
spring.jta.bitronix.da Default cursor holdability for connections.
tasource.cursor-
holdability
spring.jta.bitronix.da true Whether the database can run many
tasource.defer- transactions on the same connection and
connection-release
supports transaction interleaving.
spring.jta.bitronix.da false Whether this resource is disabled, meaning it's
tasource.disabled temporarily forbidden to acquire a connection
from its pool.
spring.jta.bitronix.da Properties that should be set on the underlying
tasource.driver- implementation.
properties
403
Key Default Value Description
spring.jta.bitronix.da false Whether Connection.isValid() is called when
tasource.enable-jdbc4- acquiring a connection from the pool.
connection-test
spring.jta.bitronix.da
tasource.failed
spring.jta.bitronix.da false Whether recovery failures should be ignored.
tasource.ignore-
recovery-failures
spring.jta.bitronix.da Default isolation level for connections.
tasource.isolation-
level
spring.jta.bitronix.da Default auto-commit mode for local
tasource.local-auto- transactions.
commit
spring.jta.bitronix.da Timeout, in seconds, for establishing a database
tasource.login-timeout connection.
spring.jta.bitronix.da 60 Time, in seconds, after which connections are
tasource.max-idle-time cleaned up from the pool.
spring.jta.bitronix.da 0 Maximum size of the pool. 0 denotes no limit.
tasource.max-pool-size
spring.jta.bitronix.da 0 Minimum size of the pool.
tasource.min-pool-size
spring.jta.bitronix.da 0 Target size of the prepared statement cache. 0
tasource.prepared- disables the cache.
statement-cache-size
spring.jta.bitronix.da false Whether connections in the ACCESSIBLE state
tasource.share- can be shared within the context of a
transaction-
connections transaction.
404
Key Default Value Description
spring.transaction.def Default transaction timeout. If a duration suffix
ault-timeout is not specified, seconds will be used.
spring.transaction.rol Whether to roll back on commit failures.
lback-on-commit-
failure
405
Key Default Value Description
spring.flyway.ignore- false Whether to ignore missing migrations when
missing-migrations reading the schema history table.
spring.flyway.ignore- false Whether to ignore pending migrations when
pending-migrations reading the schema history table.
spring.flyway.init- SQL statements to execute to initialize a
sqls connection immediately after obtaining it.
spring.flyway.installe Username recorded in the schema history table
d-by as having applied the migration.
spring.flyway.license- Licence key for Flyway Pro or Flyway
key Enterprise.
spring.flyway.location [classpath:db/migratio Locations of migrations scripts. Can contain the
s n] special "{vendor}" placeholder to use vendor-
specific locations.
spring.flyway.mixed false Whether to allow mixing transactional and non-
transactional statements within the same
migration.
spring.flyway.oracle- Whether to enable support for Oracle SQL*Plus
sqlplus commands. Requires Flyway Pro or Flyway
Enterprise.
spring.flyway.oracle- Whether to issue a warning rather than an error
sqlplus-warn when a not-yet-supported Oracle SQL*Plus
statement is encountered. Requires Flyway Pro
or Flyway Enterprise.
spring.flyway.out-of- false Whether to allow migrations to be run out of
order order.
spring.flyway.password Login password of the database to migrate.
spring.flyway.placehol ${ Prefix of placeholders in migration scripts.
der-prefix
spring.flyway.placehol true Perform placeholder replacement in migration
der-replacement scripts.
spring.flyway.placehol } Suffix of placeholders in migration scripts.
der-suffix
spring.flyway.placehol Placeholders and their replacements to apply to
ders.* sql migration scripts.
spring.flyway.repeatab R File name prefix for repeatable SQL migrations.
le-sql-migration-
prefix
spring.flyway.schemas Scheme names managed by Flyway (case-
sensitive).
spring.flyway.skip- false Whether to skip default callbacks. If true, only
default-callbacks custom callbacks are used.
406
Key Default Value Description
spring.flyway.skip- false Whether to skip default resolvers. If true, only
default-resolvers custom resolvers are used.
spring.flyway.sql- V File name prefix for SQL migrations.
migration-prefix
spring.flyway.sql- __ File name separator for SQL migrations.
migration-separator
spring.flyway.sql- [.sql] File name suffix for SQL migrations.
migration-suffixes
spring.flyway.stream Whether to stream SQL migrations when
executing them. Requires Flyway Pro or Flyway
Enterprise.
spring.flyway.table flyway_schema_history Name of the schema history table that will be
used by Flyway.
spring.flyway.tablespa Tablespace in which the schema history table is
ce created. Ignored when using a database that
does not support tablespaces. Defaults to the
default tablespace of the connection used by
Flyway.
spring.flyway.target Target version up to which migrations should be
considered.
spring.flyway.url JDBC url of the database to migrate. If not set,
the primary configured data source is used.
spring.flyway.user Login user of the database to migrate.
spring.flyway.validate false Whether to validate migrations and callbacks
-migration-naming whose scripts do not obey the correct naming
convention.
spring.flyway.validate true Whether to automatically call validate when
-on-migrate performing a migration.
spring.liquibase.chang classpath:/db/changelo Change log configuration path.
e-log g/db.changelog-
master.yaml
spring.liquibase.clear false Whether to clear all checksums in the current
-checksums changelog, so they will be recalculated upon the
next update.
spring.liquibase.conte Comma-separated list of runtime contexts to use.
xts
spring.liquibase.datab DATABASECHANGELOGLOCK Name of table to use for tracking concurrent
ase-change-log-lock- Liquibase usage.
table
spring.liquibase.datab DATABASECHANGELOG Name of table to use for tracking change history.
ase-change-log-table
spring.liquibase.defau Default database schema.
lt-schema
407
Key Default Value Description
spring.liquibase.drop- false Whether to first drop the database schema.
first
spring.liquibase.enabl true Whether to enable Liquibase support.
ed
spring.liquibase.label Comma-separated list of runtime labels to use.
s
spring.liquibase.liqui Schema to use for Liquibase objects.
base-schema
spring.liquibase.liqui Tablespace to use for Liquibase objects.
base-tablespace
spring.liquibase.param Change log parameters.
eters.*
spring.liquibase.passw Login password of the database to migrate.
ord
spring.liquibase.rollb File to which rollback SQL is written when an
ack-file update is performed.
spring.liquibase.tag Tag name to use when applying database
changes. Can also be used with "rollbackFile" to
generate a rollback script for all existing
changes associated with that tag.
spring.liquibase.test- false Whether rollback should be tested before
rollback-on-update update is performed.
spring.liquibase.url JDBC URL of the database to migrate. If not set,
the primary configured data source is used.
spring.liquibase.user Login user of the database to migrate.
408
Key Default Value Description
spring.activemq.packag Comma-separated list of specific packages to
es.trusted trust (when not trusting all packages).
spring.activemq.passwo Login password of the broker.
rd
spring.activemq.pool.b true Whether to block when a connection is
lock-if-full requested and the pool is full. Set it to false to
throw a "JMSException" instead.
spring.activemq.pool.b -1ms Blocking period before throwing an exception if
lock-if-full-timeout the pool is still full.
spring.activemq.pool.e false Whether a JmsPoolConnectionFactory should be
nabled created, instead of a regular ConnectionFactory.
spring.activemq.pool.i 30s Connection idle timeout.
dle-timeout
spring.activemq.pool.m 1 Maximum number of pooled connections.
ax-connections
spring.activemq.pool.m 500 Maximum number of pooled sessions per
ax-sessions-per- connection in the pool.
connection
spring.activemq.pool.t -1ms Time to sleep between runs of the idle
ime-between- connection eviction thread. When negative, no
expiration-check
idle connection eviction thread runs.
spring.activemq.pool.u true Whether to use only one anonymous
se-anonymous-producers "MessageProducer" instance. Set it to false to
create one "MessageProducer" every time one is
required.
spring.activemq.send- 0ms Time to wait on message sends for a response.
timeout Set it to 0 to wait forever.
spring.activemq.user Login user of the broker.
spring.artemis.embedde Cluster password. Randomly generated on
d.cluster-password startup by default.
spring.artemis.embedde Journal file directory. Not necessary if
d.data-directory persistence is turned off.
spring.artemis.embedde true Whether to enable embedded mode if the
d.enabled Artemis server APIs are available.
spring.artemis.embedde false Whether to enable persistent store.
d.persistent
spring.artemis.embedde [] Comma-separated list of queues to create on
d.queues startup.
spring.artemis.embedde 0 Server ID. By default, an auto-incremented
d.server-id counter is used.
409
Key Default Value Description
spring.artemis.embedde [] Comma-separated list of topics to create on
d.topics startup.
spring.artemis.host localhost Artemis broker host.
spring.artemis.mode Artemis deployment mode, auto-detected by
default.
spring.artemis.passwor Login password of the broker.
d
spring.artemis.pool.bl true Whether to block when a connection is
ock-if-full requested and the pool is full. Set it to false to
throw a "JMSException" instead.
spring.artemis.pool.bl -1ms Blocking period before throwing an exception if
ock-if-full-timeout the pool is still full.
spring.artemis.pool.en false Whether a JmsPoolConnectionFactory should be
abled created, instead of a regular ConnectionFactory.
spring.artemis.pool.id 30s Connection idle timeout.
le-timeout
spring.artemis.pool.ma 1 Maximum number of pooled connections.
x-connections
spring.artemis.pool.ma 500 Maximum number of pooled sessions per
x-sessions-per- connection in the pool.
connection
spring.artemis.pool.ti -1ms Time to sleep between runs of the idle
me-between-expiration- connection eviction thread. When negative, no
check
idle connection eviction thread runs.
spring.artemis.pool.us true Whether to use only one anonymous
e-anonymous-producers "MessageProducer" instance. Set it to false to
create one "MessageProducer" every time one is
required.
spring.artemis.port 61616 Artemis broker port.
spring.artemis.user Login user of the broker.
spring.batch.initializ embedded Database schema initialization mode.
e-schema
spring.batch.job.enabl true Execute all Spring Batch jobs in the context on
ed startup.
spring.batch.job.names Comma-separated list of job names to execute on
startup (for instance, `job1,job2`). By default, all
Jobs found in the context are executed.
spring.batch.schema classpath:org/springfr Path to the SQL file to use to initialize the
amework/batch/core/sch database schema.
ema-@@platform@@.sql
spring.batch.table- Table prefix for all the batch meta-data tables.
prefix
410
Key Default Value Description
spring.hazelcast.confi The location of the configuration file to use to
g initialize Hazelcast.
spring.integration.jdb embedded Database schema initialization mode.
c.initialize-schema
spring.integration.jdb classpath:org/springfr Path to the SQL file to use to initialize the
c.schema amework/integration/jd database schema.
bc/schema-
@@platform@@.sql
spring.integration.rso TCP RSocket server host to connect to.
cket.client.host
spring.integration.rso TCP RSocket server port to connect to.
cket.client.port
spring.integration.rso WebSocket RSocket server uri to connect to.
cket.client.uri
spring.integration.rso false Whether to handle message mapping for
cket.server.message- RSocket via Spring Integration.
mapping-enabled
spring.jms.cache.consu false Whether to cache message consumers.
mers
spring.jms.cache.enabl true Whether to cache sessions.
ed
spring.jms.cache.produ true Whether to cache message producers.
cers
spring.jms.cache.sessi 1 Size of the session cache (per JMS Session type).
on-cache-size
spring.jms.jndi-name Connection factory JNDI name. When set, takes
precedence to others connection factory auto-
configurations.
spring.jms.listener.ac Acknowledge mode of the container. By default,
knowledge-mode the listener is transacted with automatic
acknowledgment.
spring.jms.listener.au true Start the container automatically on startup.
to-startup
spring.jms.listener.co Minimum number of concurrent consumers.
ncurrency
spring.jms.listener.ma Maximum number of concurrent consumers.
x-concurrency
spring.jms.listener.re 1s Timeout to use for receive calls. Use -1 for a no-
ceive-timeout wait receive or 0 for no timeout at all. The latter
is only feasible if not running within a
transaction manager and is generally
discouraged since it prevents clean shutdown.
spring.jms.pub-sub- false Whether the default destination type is topic.
domain
411
Key Default Value Description
spring.jms.template.de Default destination to use on send and receive
fault-destination operations that do not have a destination
parameter.
spring.jms.template.de Delivery delay to use for send calls.
livery-delay
spring.jms.template.de Delivery mode. Enables QoS (Quality of Service)
livery-mode when set.
spring.jms.template.pr Priority of a message when sending. Enables
iority QoS (Quality of Service) when set.
spring.jms.template.qo Whether to enable explicit QoS (Quality of
s-enabled Service) when sending a message. When
enabled, the delivery mode, priority and time-to-
live properties will be used when sending a
message. QoS is automatically enabled when at
least one of those settings is customized.
spring.jms.template.re Timeout to use for receive calls.
ceive-timeout
spring.jms.template.ti Time-to-live of a message when sending. Enables
me-to-live QoS (Quality of Service) when set.
spring.kafka.admin.cli ID to pass to the server when making requests.
ent-id Used for server-side logging.
spring.kafka.admin.fai false Whether to fail fast if the broker is not available
l-fast on startup.
spring.kafka.admin.pro Additional admin-specific properties used to
perties.* configure the client.
spring.kafka.admin.sec Security protocol used to communicate with
urity.protocol brokers.
spring.kafka.admin.ssl Password of the private key in the key store file.
.key-password
spring.kafka.admin.ssl Location of the key store file.
.key-store-location
spring.kafka.admin.ssl Store password for the key store file.
.key-store-password
spring.kafka.admin.ssl Type of the key store.
.key-store-type
spring.kafka.admin.ssl SSL protocol to use.
.protocol
spring.kafka.admin.ssl Location of the trust store file.
.trust-store-location
spring.kafka.admin.ssl Store password for the trust store file.
.trust-store-password
spring.kafka.admin.ssl Type of the trust store.
.trust-store-type
412
Key Default Value Description
spring.kafka.bootstrap Comma-delimited list of host:port pairs to use
-servers for establishing the initial connections to the
Kafka cluster. Applies to all components unless
overridden.
spring.kafka.client-id ID to pass to the server when making requests.
Used for server-side logging.
spring.kafka.consumer. Frequency with which the consumer offsets are
auto-commit-interval auto-committed to Kafka if 'enable.auto.commit'
is set to true.
spring.kafka.consumer. What to do when there is no initial offset in
auto-offset-reset Kafka or if the current offset no longer exists on
the server.
spring.kafka.consumer. Comma-delimited list of host:port pairs to use
bootstrap-servers for establishing the initial connections to the
Kafka cluster. Overrides the global property, for
consumers.
spring.kafka.consumer. ID to pass to the server when making requests.
client-id Used for server-side logging.
spring.kafka.consumer. Whether the consumer's offset is periodically
enable-auto-commit committed in the background.
spring.kafka.consumer. Maximum amount of time the server blocks
fetch-max-wait before answering the fetch request if there isn't
sufficient data to immediately satisfy the
requirement given by "fetch-min-size".
spring.kafka.consumer. Minimum amount of data the server should
fetch-min-size return for a fetch request.
spring.kafka.consumer. Unique string that identifies the consumer group
group-id to which this consumer belongs.
spring.kafka.consumer. Expected time between heartbeats to the
heartbeat-interval consumer coordinator.
spring.kafka.consumer. read-uncommitted Isolation level for reading messages that have
isolation-level been written transactionally.
spring.kafka.consumer. Deserializer class for keys.
key-deserializer
spring.kafka.consumer. Maximum number of records returned in a
max-poll-records single call to poll().
spring.kafka.consumer. Additional consumer-specific properties used to
properties.* configure the client.
spring.kafka.consumer. Security protocol used to communicate with
security.protocol brokers.
413
Key Default Value Description
spring.kafka.consumer. Password of the private key in the key store file.
ssl.key-password
spring.kafka.consumer. Location of the key store file.
ssl.key-store-location
spring.kafka.consumer. Store password for the key store file.
ssl.key-store-password
spring.kafka.consumer. Type of the key store.
ssl.key-store-type
spring.kafka.consumer. SSL protocol to use.
ssl.protocol
spring.kafka.consumer. Location of the trust store file.
ssl.trust-store-
location
spring.kafka.consumer. Store password for the trust store file.
ssl.trust-store-
password
spring.kafka.consumer. Type of the trust store.
ssl.trust-store-type
spring.kafka.consumer. Deserializer class for values.
value-deserializer
spring.kafka.jaas.cont required Control flag for login configuration.
rol-flag
spring.kafka.jaas.enab false Whether to enable JAAS configuration.
led
spring.kafka.jaas.logi com.sun.security.auth. Login module.
n-module module.Krb5LoginModule
spring.kafka.jaas.opti Additional JAAS options.
ons.*
spring.kafka.listener. Number of records between offset commits
ack-count when ackMode is "COUNT" or "COUNT_TIME".
spring.kafka.listener. Listener AckMode. See the spring-kafka
ack-mode documentation.
spring.kafka.listener. Time between offset commits when ackMode is
ack-time "TIME" or "COUNT_TIME".
spring.kafka.listener. Prefix for the listener's consumer client.id
client-id property.
spring.kafka.listener. Number of threads to run in the listener
concurrency containers.
spring.kafka.listener. Time between publishing idle consumer events
idle-event-interval (no data received).
spring.kafka.listener. Whether to log the container configuration
log-container-config during initialization (INFO level).
414
Key Default Value Description
spring.kafka.listener. false Whether the container should fail to start if at
missing-topics-fatal least one of the configured topics are not present
on the broker.
spring.kafka.listener. Time between checks for non-responsive
monitor-interval consumers. If a duration suffix is not specified,
seconds will be used.
spring.kafka.listener. Multiplier applied to "pollTimeout" to determine
no-poll-threshold if a consumer is non-responsive.
spring.kafka.listener. Timeout to use when polling the consumer.
poll-timeout
spring.kafka.listener. single Listener type.
type
spring.kafka.producer. Number of acknowledgments the producer
acks requires the leader to have received before
considering a request complete.
spring.kafka.producer. Default batch size. A small batch size will make
batch-size batching less common and may reduce
throughput (a batch size of zero disables
batching entirely).
spring.kafka.producer. Comma-delimited list of host:port pairs to use
bootstrap-servers for establishing the initial connections to the
Kafka cluster. Overrides the global property, for
producers.
spring.kafka.producer. Total memory size the producer can use to
buffer-memory buffer records waiting to be sent to the server.
spring.kafka.producer. ID to pass to the server when making requests.
client-id Used for server-side logging.
spring.kafka.producer. Compression type for all data generated by the
compression-type producer.
spring.kafka.producer. Serializer class for keys.
key-serializer
spring.kafka.producer. Additional producer-specific properties used to
properties.* configure the client.
spring.kafka.producer. When greater than zero, enables retrying of
retries failed sends.
spring.kafka.producer. Security protocol used to communicate with
security.protocol brokers.
spring.kafka.producer. Password of the private key in the key store file.
ssl.key-password
spring.kafka.producer. Location of the key store file.
ssl.key-store-location
415
Key Default Value Description
spring.kafka.producer. Store password for the key store file.
ssl.key-store-password
spring.kafka.producer. Type of the key store.
ssl.key-store-type
spring.kafka.producer. SSL protocol to use.
ssl.protocol
spring.kafka.producer. Location of the trust store file.
ssl.trust-store-
location
spring.kafka.producer. Store password for the trust store file.
ssl.trust-store-
password
spring.kafka.producer. Type of the trust store.
ssl.trust-store-type
spring.kafka.producer. When non empty, enables transaction support
transaction-id-prefix for producer.
spring.kafka.producer. Serializer class for values.
value-serializer
spring.kafka.propertie Additional properties, common to producers and
s.* consumers, used to configure the client.
spring.kafka.security. Security protocol used to communicate with
protocol brokers.
spring.kafka.ssl.key- Password of the private key in the key store file.
password
spring.kafka.ssl.key- Location of the key store file.
store-location
spring.kafka.ssl.key- Store password for the key store file.
store-password
spring.kafka.ssl.key- Type of the key store.
store-type
spring.kafka.ssl.proto SSL protocol to use.
col
spring.kafka.ssl.trust Location of the trust store file.
-store-location
spring.kafka.ssl.trust Store password for the trust store file.
-store-password
spring.kafka.ssl.trust Type of the trust store.
-store-type
spring.kafka.streams.a Kafka streams application.id property; default
pplication-id spring.application.name.
spring.kafka.streams.a true Whether or not to auto-start the streams factory
uto-startup bean.
416
Key Default Value Description
spring.kafka.streams.b Comma-delimited list of host:port pairs to use
ootstrap-servers for establishing the initial connections to the
Kafka cluster. Overrides the global property, for
streams.
spring.kafka.streams.c Maximum memory size to be used for buffering
ache-max-size- across all threads.
buffering
spring.kafka.streams.c ID to pass to the server when making requests.
lient-id Used for server-side logging.
spring.kafka.streams.p Additional Kafka properties used to configure
roperties.* the streams.
spring.kafka.streams.r The replication factor for change log topics and
eplication-factor repartition topics created by the stream
processing application.
spring.kafka.streams.s Security protocol used to communicate with
ecurity.protocol brokers.
spring.kafka.streams.s Password of the private key in the key store file.
sl.key-password
spring.kafka.streams.s Location of the key store file.
sl.key-store-location
spring.kafka.streams.s Store password for the key store file.
sl.key-store-password
spring.kafka.streams.s Type of the key store.
sl.key-store-type
spring.kafka.streams.s SSL protocol to use.
sl.protocol
spring.kafka.streams.s Location of the trust store file.
sl.trust-store-
location
spring.kafka.streams.s Store password for the trust store file.
sl.trust-store-
password
spring.kafka.streams.s Type of the trust store.
sl.trust-store-type
spring.kafka.streams.s Directory location for the state store.
tate-dir
spring.kafka.template. Default topic to which messages are sent.
default-topic
spring.rabbitmq.addres Comma-separated list of addresses to which the
ses client should connect. When set, the host and
port are ignored.
spring.rabbitmq.cache. Duration to wait to obtain a channel if the cache
channel.checkout- size has been reached. If 0, always create a new
timeout
channel.
417
Key Default Value Description
spring.rabbitmq.cache. Number of channels to retain in the cache.
channel.size When "check-timeout" > 0, max channels per
connection.
spring.rabbitmq.cache. channel Connection factory cache mode.
connection.mode
spring.rabbitmq.cache. Number of connections to cache. Only applies
connection.size when mode is CONNECTION.
spring.rabbitmq.connec Connection timeout. Set it to zero to wait
tion-timeout forever.
spring.rabbitmq.dynami true Whether to create an AmqpAdmin bean.
c
spring.rabbitmq.host localhost RabbitMQ host. Ignored if an address is set.
spring.rabbitmq.listen Acknowledge mode of container.
er.direct.acknowledge-
mode
spring.rabbitmq.listen true Whether to start the container automatically on
er.direct.auto-startup startup.
spring.rabbitmq.listen Number of consumers per queue.
er.direct.consumers-
per-queue
spring.rabbitmq.listen Whether rejected deliveries are re-queued by
er.direct.default- default.
requeue-rejected
spring.rabbitmq.listen How often idle container events should be
er.direct.idle-event- published.
interval
spring.rabbitmq.listen false Whether to fail if the queues declared by the
er.direct.missing- container are not available on the broker.
queues-fatal
spring.rabbitmq.listen Maximum number of unacknowledged
er.direct.prefetch messages that can be outstanding at each
consumer.
spring.rabbitmq.listen false Whether publishing retries are enabled.
er.direct.retry.enable
d
spring.rabbitmq.listen 1000ms Duration between the first and second attempt
er.direct.retry.initia to deliver a message.
l-interval
spring.rabbitmq.listen 3 Maximum number of attempts to deliver a
er.direct.retry.max- message.
attempts
spring.rabbitmq.listen 10000ms Maximum duration between attempts.
er.direct.retry.max-
interval
418
Key Default Value Description
spring.rabbitmq.listen 1 Multiplier to apply to the previous retry interval.
er.direct.retry.multip
lier
spring.rabbitmq.listen true Whether retries are stateless or stateful.
er.direct.retry.statel
ess
spring.rabbitmq.listen Acknowledge mode of container.
er.simple.acknowledge-
mode
spring.rabbitmq.listen true Whether to start the container automatically on
er.simple.auto-startup startup.
spring.rabbitmq.listen Batch size, expressed as the number of physical
er.simple.batch-size messages, to be used by the container.
spring.rabbitmq.listen Minimum number of listener invoker threads.
er.simple.concurrency
spring.rabbitmq.listen Whether rejected deliveries are re-queued by
er.simple.default- default.
requeue-rejected
spring.rabbitmq.listen How often idle container events should be
er.simple.idle-event- published.
interval
spring.rabbitmq.listen Maximum number of listener invoker threads.
er.simple.max-
concurrency
spring.rabbitmq.listen true Whether to fail if the queues declared by the
er.simple.missing- container are not available on the broker and/or
queues-fatal
whether to stop the container if one or more
queues are deleted at runtime.
spring.rabbitmq.listen Maximum number of unacknowledged
er.simple.prefetch messages that can be outstanding at each
consumer.
spring.rabbitmq.listen false Whether publishing retries are enabled.
er.simple.retry.enable
d
spring.rabbitmq.listen 1000ms Duration between the first and second attempt
er.simple.retry.initia to deliver a message.
l-interval
spring.rabbitmq.listen 3 Maximum number of attempts to deliver a
er.simple.retry.max- message.
attempts
spring.rabbitmq.listen 10000ms Maximum duration between attempts.
er.simple.retry.max-
interval
spring.rabbitmq.listen 1 Multiplier to apply to the previous retry interval.
er.simple.retry.multip
lier
419
Key Default Value Description
spring.rabbitmq.listen true Whether retries are stateless or stateful.
er.simple.retry.statel
ess
spring.rabbitmq.listen simple Listener container type.
er.type
spring.rabbitmq.passwo guest Login to authenticate against the broker.
rd
spring.rabbitmq.port RabbitMQ port. Ignored if an address is set.
Default to 5672, or 5671 if SSL is enabled.
spring.rabbitmq.publis Type of publisher confirms to use.
her-confirm-type
spring.rabbitmq.publis false Whether to enable publisher returns.
her-returns
spring.rabbitmq.reques 2047 Number of channels per connection requested
ted-channel-max by the client. Use 0 for unlimited.
spring.rabbitmq.reques Requested heartbeat timeout; zero for none. If a
ted-heartbeat duration suffix is not specified, seconds will be
used.
spring.rabbitmq.ssl.al SSL algorithm to use. By default, configured by
gorithm the Rabbit client library.
spring.rabbitmq.ssl.en Whether to enable SSL support. Determined
abled automatically if an address is provided with the
protocol (amqp:// vs. amqps://).
spring.rabbitmq.ssl.ke Path to the key store that holds the SSL
y-store certificate.
spring.rabbitmq.ssl.ke Password used to access the key store.
y-store-password
spring.rabbitmq.ssl.ke PKCS12 Key store type.
y-store-type
spring.rabbitmq.ssl.tr Trust store that holds SSL certificates.
ust-store
spring.rabbitmq.ssl.tr Password used to access the trust store.
ust-store-password
spring.rabbitmq.ssl.tr JKS Trust store type.
ust-store-type
spring.rabbitmq.ssl.va true Whether to enable server side certificate
lidate-server- validation.
certificate
spring.rabbitmq.ssl.ve true Whether to enable hostname verification.
rify-hostname
spring.rabbitmq.templa Name of the default queue to receive messages
te.default-receive- from when none is specified explicitly.
queue
420
Key Default Value Description
spring.rabbitmq.templa Name of the default exchange to use for send
te.exchange operations.
spring.rabbitmq.templa Whether to enable mandatory messages.
te.mandatory
spring.rabbitmq.templa Timeout for `receive()` operations.
te.receive-timeout
spring.rabbitmq.templa Timeout for `sendAndReceive()` operations.
te.reply-timeout
spring.rabbitmq.templa false Whether publishing retries are enabled.
te.retry.enabled
spring.rabbitmq.templa 1000ms Duration between the first and second attempt
te.retry.initial- to deliver a message.
interval
spring.rabbitmq.templa 3 Maximum number of attempts to deliver a
te.retry.max-attempts message.
spring.rabbitmq.templa 10000ms Maximum duration between attempts.
te.retry.max-interval
spring.rabbitmq.templa 1 Multiplier to apply to the previous retry interval.
te.retry.multiplier
spring.rabbitmq.templa Value of a default routing key to use for send
te.routing-key operations.
spring.rabbitmq.userna guest Login user to authenticate to the broker.
me
spring.rabbitmq.virtua Virtual host to use when connecting to the
l-host broker.
spring.webservices.pat /services Path that serves as the base URI for the services.
h
spring.webservices.ser Servlet init parameters to pass to Spring Web
vlet.init.* Services.
spring.webservices.ser -1 Load on startup priority of the Spring Web
vlet.load-on-startup Services servlet.
spring.webservices.wsd Comma-separated list of locations of WSDLs and
l-locations accompanying XSDs to be exposed as beans.
421
Key Default Value Description
spring.jersey.filter.o 0 Jersey filter chain order.
rder
spring.jersey.init.* Init parameters to pass to Jersey through the
servlet or filter.
spring.jersey.servlet. -1 Load on startup priority of the Jersey servlet.
load-on-startup
spring.jersey.type servlet Jersey integration type.
spring.mvc.async.reque Amount of time before asynchronous request
st-timeout handling times out. If this value is not set, the
default timeout of the underlying
implementation is used.
spring.mvc.contentnego false Whether a request parameter ("format" by
tiation.favor- default) should be used to determine the
parameter
requested media type.
spring.mvc.contentnego Map file extensions to media types for content
tiation.media-types.* negotiation. For instance, yml to text/yaml.
spring.mvc.contentnego Query parameter name to use when "favor-
tiation.parameter-name parameter" is enabled.
spring.mvc.converters. Preferred JSON mapper to use for HTTP message
preferred-json-mapper conversion. By default, auto-detected according
to the environment.
spring.mvc.dispatch- true Whether to dispatch OPTIONS requests to the
options-request FrameworkServlet doService method.
spring.mvc.dispatch- false Whether to dispatch TRACE requests to the
trace-request FrameworkServlet doService method.
spring.mvc.format.date Date format to use, for example `dd/MM/yyyy`.
spring.mvc.format.date Date-time format to use, for example `yyyy-MM-
-time dd HH:mm:ss`.
spring.mvc.format.time Time format to use, for example `HH:mm:ss`.
spring.mvc.formcontent true Whether to enable Spring's FormContentFilter.
.filter.enabled
spring.mvc.hiddenmetho false Whether to enable Spring's
d.filter.enabled HiddenHttpMethodFilter.
spring.mvc.ignore- true Whether the content of the "default" model
default-model-on- should be ignored during redirect scenarios.
redirect
spring.mvc.locale Locale to use. By default, this locale is
overridden by the "Accept-Language" header.
spring.mvc.locale- accept-header Define how the locale should be resolved.
resolver
422
Key Default Value Description
spring.mvc.log- false Whether logging of (potentially sensitive)
request-details request details at DEBUG and TRACE level is
allowed.
spring.mvc.log- false Whether to enable warn logging of exceptions
resolved-exception resolved by a "HandlerExceptionResolver",
except for "DefaultHandlerExceptionResolver".
spring.mvc.message- Formatting strategy for message codes. For
codes-resolver-format instance, `PREFIX_ERROR_CODE`.
spring.mvc.publish- true Whether to publish a
request-handled-events ServletRequestHandledEvent at the end of each
request.
spring.mvc.servlet.loa -1 Load on startup priority of the dispatcher
d-on-startup servlet.
spring.mvc.servlet.pat / Path of the dispatcher servlet.
h
spring.mvc.static- /** Path pattern used for static resources.
path-pattern
spring.mvc.throw- false Whether a "NoHandlerFoundException" should
exception-if-no- be thrown if no Handler was found to process a
handler-found
request.
spring.mvc.view.prefix Spring MVC view prefix.
spring.mvc.view.suffix Spring MVC view suffix.
spring.resources.add- true Whether to enable default resource handling.
mappings
spring.resources.cache Indicate that the response message is intended
.cachecontrol.cache- for a single user and must not be stored by a
private
shared cache.
spring.resources.cache Indicate that any cache may store the response.
.cachecontrol.cache-
public
spring.resources.cache Maximum time the response should be cached,
.cachecontrol.max-age in seconds if no duration suffix is not specified.
spring.resources.cache Indicate that once it has become stale, a cache
.cachecontrol.must- must not use the response without re-validating
revalidate
it with the server.
spring.resources.cache Indicate that the cached response can be reused
.cachecontrol.no-cache only if re-validated with the server.
spring.resources.cache Indicate to not cache the response in any case.
.cachecontrol.no-store
spring.resources.cache Indicate intermediaries (caches and others) that
.cachecontrol.no- they should not transform the response content.
transform
423
Key Default Value Description
spring.resources.cache Same meaning as the "must-revalidate"
.cachecontrol.proxy- directive, except that it does not apply to private
revalidate
caches.
spring.resources.cache Maximum time the response should be cached
.cachecontrol.s-max- by shared caches, in seconds if no duration
age
suffix is not specified.
spring.resources.cache Maximum time the response may be used when
.cachecontrol.stale- errors are encountered, in seconds if no
if-error
duration suffix is not specified.
spring.resources.cache Maximum time the response can be served after
.cachecontrol.stale- it becomes stale, in seconds if no duration suffix
while-revalidate
is not specified.
spring.resources.cache Cache period for the resources served by the
.period resource handler. If a duration suffix is not
specified, seconds will be used. Can be
overridden by the
'spring.resources.cache.cachecontrol' properties.
spring.resources.chain true Whether to enable caching in the Resource
.cache chain.
spring.resources.chain false Whether to enable resolution of already
.compressed compressed resources (gzip, brotli). Checks for a
resource name with the '.gz' or '.br' file
extensions.
spring.resources.chain Whether to enable the Spring Resource
.enabled Handling chain. By default, disabled unless at
least one strategy has been enabled.
spring.resources.chain false Whether to enable HTML5 application cache
.html-application- manifest rewriting.
cache
spring.resources.chain false Whether to enable the content Version Strategy.
.strategy.content.enab
led
spring.resources.chain [/**] Comma-separated list of patterns to apply to the
.strategy.content.path content Version Strategy.
s
spring.resources.chain false Whether to enable the fixed Version Strategy.
.strategy.fixed.enable
d
spring.resources.chain [/**] Comma-separated list of patterns to apply to the
.strategy.fixed.paths fixed Version Strategy.
spring.resources.chain Version string to use for the fixed Version
.strategy.fixed.versio Strategy.
n
424
Key Default Value Description
spring.resources.stati [classpath:/META- Locations of static resources. Defaults to
c-locations INF/resources/, classpath:[/META-INF/resources/, /resources/,
classpath:/resources/,
classpath:/static/, /static/, /public/].
classpath:/public/]
spring.servlet.multipa true Whether to enable support of multipart uploads.
rt.enabled
spring.servlet.multipa 0B Threshold after which files are written to disk.
rt.file-size-threshold
spring.servlet.multipa Intermediate location of uploaded files.
rt.location
spring.servlet.multipa 1MB Max file size.
rt.max-file-size
spring.servlet.multipa 10MB Max request size.
rt.max-request-size
spring.servlet.multipa false Whether to resolve the multipart request lazily
rt.resolve-lazily at the time of file or parameter access.
spring.session.hazelca on-save Sessions flush mode. Determines when session
st.flush-mode changes are written to the session store.
spring.session.hazelca spring:session:session Name of the map used to store sessions.
st.map-name s
spring.session.hazelca on-set-attribute Sessions save mode. Determines how session
st.save-mode changes are tracked and saved to the session
store.
spring.session.jdbc.cl 0 * * * * * Cron expression for expired session cleanup job.
eanup-cron
spring.session.jdbc.fl on-save Sessions flush mode. Determines when session
ush-mode changes are written to the session store.
spring.session.jdbc.in embedded Database schema initialization mode.
itialize-schema
spring.session.jdbc.sa on-set-attribute Sessions save mode. Determines how session
ve-mode changes are tracked and saved to the session
store.
spring.session.jdbc.sc classpath:org/springfr Path to the SQL file to use to initialize the
hema amework/session/jdbc/s database schema.
chema-@@platform@@.sql
spring.session.jdbc.ta SPRING_SESSION Name of the database table used to store
ble-name sessions.
spring.session.mongodb sessions Collection name used to store sessions.
.collection-name
spring.session.redis.c 0 * * * * * Cron expression for expired session cleanup job.
leanup-cron
spring.session.redis.c notify-keyspace-events The configure action to apply when no user
onfigure-action defined ConfigureRedisAction bean is present.
425
Key Default Value Description
spring.session.redis.f on-save Sessions flush mode. Determines when session
lush-mode changes are written to the session store.
spring.session.redis.n spring:session Namespace for keys used to store sessions.
amespace
spring.session.redis.s on-set-attribute Sessions save mode. Determines how session
ave-mode changes are tracked and saved to the session
store.
spring.session.servlet [async, error, Session repository filter dispatcher types.
.filter-dispatcher- request]
types
spring.session.servlet Session repository filter order.
.filter-order
spring.session.store- Session store type.
type
spring.session.timeout Session timeout. If a duration suffix is not
specified, seconds will be used.
spring.webflux.base- Base path for all web handlers.
path
spring.webflux.format. Date format to use, for example `dd/MM/yyyy`.
date
spring.webflux.format. Date-time format to use, for example `yyyy-MM-
date-time dd HH:mm:ss`.
spring.webflux.format. Time format to use, for example `HH:mm:ss`.
time
spring.webflux.hiddenm false Whether to enable Spring's
ethod.filter.enabled HiddenHttpMethodFilter.
spring.webflux.static- /** Path pattern used for static resources.
path-pattern
426
Key Default Value Description
spring.freemarker.chec true Whether to check that the templates location
k-template-location exists.
spring.freemarker.cont text/html Content-Type value.
ent-type
spring.freemarker.enab true Whether to enable MVC view resolution for this
led technology.
spring.freemarker.expo false Whether all request attributes should be added
se-request-attributes to the model prior to merging with the template.
spring.freemarker.expo false Whether all HttpSession attributes should be
se-session-attributes added to the model prior to merging with the
template.
spring.freemarker.expo true Whether to expose a RequestContext for use by
se-spring-macro- Spring's macro library, under the name
helpers
"springMacroRequestContext".
spring.freemarker.pref true Whether to prefer file system access for
er-file-system-access template loading. File system access enables hot
detection of template changes.
spring.freemarker.pref Prefix that gets prepended to view names when
ix building a URL.
spring.freemarker.requ Name of the RequestContext attribute for all
est-context-attribute views.
spring.freemarker.sett Well-known FreeMarker keys which are passed
ings.* to FreeMarker's Configuration.
spring.freemarker.suff .ftlh Suffix that gets appended to view names when
ix building a URL.
spring.freemarker.temp [classpath:/templates/ Comma-separated list of template paths.
late-loader-path ]
spring.freemarker.view View names that can be resolved.
-names
spring.groovy.template false Whether HttpServletRequest attributes are
.allow-request- allowed to override (hide) controller generated
override
model attributes of the same name.
spring.groovy.template false Whether HttpSession attributes are allowed to
.allow-session- override (hide) controller generated model
override
attributes of the same name.
spring.groovy.template false Whether to enable template caching.
.cache
spring.groovy.template UTF-8 Template encoding.
.charset
spring.groovy.template true Whether to check that the templates location
.check-template- exists.
location
427
Key Default Value Description
spring.groovy.template See GroovyMarkupConfigurer
.configuration.auto-
escape
spring.groovy.template
.configuration.auto-
indent
spring.groovy.template
.configuration.auto-
indent-string
spring.groovy.template
.configuration.auto-
new-line
spring.groovy.template
.configuration.base-
template-class
spring.groovy.template
.configuration.cache-
templates
spring.groovy.template
.configuration.declara
tion-encoding
spring.groovy.template
.configuration.expand-
empty-elements
spring.groovy.template
.configuration.locale
spring.groovy.template
.configuration.new-
line-string
spring.groovy.template
.configuration.resourc
e-loader-path
spring.groovy.template
.configuration.use-
double-quotes
spring.groovy.template text/html Content-Type value.
.content-type
spring.groovy.template true Whether to enable MVC view resolution for this
.enabled technology.
spring.groovy.template false Whether all request attributes should be added
.expose-request- to the model prior to merging with the template.
attributes
spring.groovy.template false Whether all HttpSession attributes should be
.expose-session- added to the model prior to merging with the
attributes
template.
428
Key Default Value Description
spring.groovy.template true Whether to expose a RequestContext for use by
.expose-spring-macro- Spring's macro library, under the name
helpers
"springMacroRequestContext".
spring.groovy.template Prefix that gets prepended to view names when
.prefix building a URL.
spring.groovy.template Name of the RequestContext attribute for all
.request-context- views.
attribute
spring.groovy.template classpath:/templates/ Template path.
.resource-loader-path
spring.groovy.template .tpl Suffix that gets appended to view names when
.suffix building a URL.
spring.groovy.template View names that can be resolved.
.view-names
spring.mustache.allow- false Whether HttpServletRequest attributes are
request-override allowed to override (hide) controller generated
model attributes of the same name.
spring.mustache.allow- false Whether HttpSession attributes are allowed to
session-override override (hide) controller generated model
attributes of the same name.
spring.mustache.cache false Whether to enable template caching.
spring.mustache.charse UTF-8 Template encoding.
t
spring.mustache.check- true Whether to check that the templates location
template-location exists.
spring.mustache.conten text/html Content-Type value.
t-type
spring.mustache.enable true Whether to enable MVC view resolution for this
d technology.
spring.mustache.expose false Whether all request attributes should be added
-request-attributes to the model prior to merging with the template.
spring.mustache.expose false Whether all HttpSession attributes should be
-session-attributes added to the model prior to merging with the
template.
spring.mustache.expose true Whether to expose a RequestContext for use by
-spring-macro-helpers Spring's macro library, under the name
"springMacroRequestContext".
spring.mustache.prefix classpath:/templates/ Prefix to apply to template names.
spring.mustache.reques Name of the RequestContext attribute for all
t-context-attribute views.
spring.mustache.suffix .mustache Suffix to apply to template names.
429
Key Default Value Description
spring.mustache.view- View names that can be resolved.
names
spring.thymeleaf.cache true Whether to enable template caching.
spring.thymeleaf.check true Whether to check that the template exists before
-template rendering it.
spring.thymeleaf.check true Whether to check that the templates location
-template-location exists.
spring.thymeleaf.enabl false Enable the SpringEL compiler in SpringEL
e-spring-el-compiler expressions.
spring.thymeleaf.enabl true Whether to enable Thymeleaf view resolution
ed for Web frameworks.
spring.thymeleaf.encod UTF-8 Template files encoding.
ing
spring.thymeleaf.exclu Comma-separated list of view names (patterns
ded-view-names allowed) that should be excluded from
resolution.
spring.thymeleaf.mode HTML Template mode to be applied to templates. See
also Thymeleaf's TemplateMode enum.
spring.thymeleaf.prefi classpath:/templates/ Prefix that gets prepended to view names when
x building a URL.
spring.thymeleaf.react Comma-separated list of view names (patterns
ive.chunked-mode-view- allowed) that should be the only ones executed
names
in CHUNKED mode when a max chunk size is
set.
spring.thymeleaf.react Comma-separated list of view names (patterns
ive.full-mode-view- allowed) that should be executed in FULL mode
names
even if a max chunk size is set.
spring.thymeleaf.react 0B Maximum size of data buffers used for writing
ive.max-chunk-size to the response. Templates will execute in
CHUNKED mode by default if this is set.
spring.thymeleaf.react Media types supported by the view technology.
ive.media-types
spring.thymeleaf.rende false Whether hidden form inputs acting as markers
r-hidden-markers- for checkboxes should be rendered before the
before-checkboxes
checkbox element itself.
spring.thymeleaf.servl text/html Content-Type value written to HTTP responses.
et.content-type
spring.thymeleaf.servl true Whether Thymeleaf should start writing partial
et.produce-partial- output as soon as possible or buffer until
output-while-
processing template processing is finished.
430
Key Default Value Description
spring.thymeleaf.suffi .html Suffix that gets appended to view names when
x building a URL.
spring.thymeleaf.templ Order of the template resolver in the chain. By
ate-resolver-order default, the template resolver is first in the
chain. Order start at 1 and should only be set if
you have defined additional "TemplateResolver"
beans.
spring.thymeleaf.view- Comma-separated list of view names (patterns
names allowed) that can be resolved.
431
Key Default Value Description
server.jetty.accesslog false Append to log.
.append
server.jetty.accesslog Custom log format, see
.custom-format org.eclipse.jetty.server.CustomRequestLog. If
defined, overrides the "format" configuration
key.
server.jetty.accesslog false Enable access log.
.enabled
server.jetty.accesslog Date format to place in log file name.
.file-date-format
server.jetty.accesslog Log filename. If not specified, logs redirect to
.filename "System.err".
server.jetty.accesslog ncsa Log format.
.format
server.jetty.accesslog Request paths that should not be logged.
.ignore-paths
server.jetty.accesslog 31 Number of days before rotated log files are
.retention-period deleted.
server.jetty.connectio Time that the connection can be idle before it is
n-idle-timeout closed.
server.jetty.max-http- 200000B Maximum size of the form content in any HTTP
form-post-size post request.
server.jetty.threads.a -1 Number of acceptor threads to use. When the
cceptors value is -1, the default, the number of acceptors
is derived from the operating environment.
server.jetty.threads.i 60000ms Maximum thread idle time.
dle-timeout
server.jetty.threads.m 200 Maximum number of threads.
ax
server.jetty.threads.m Maximum capacity of the thread pool's backing
ax-queue-capacity queue. A default is computed based on the
threading configuration.
server.jetty.threads.m 8 Minimum number of threads.
in
server.jetty.threads.s -1 Number of selector threads to use. When the
electors value is -1, the default, the number of selectors is
derived from the operating environment.
server.max-http- 8KB Maximum size of the HTTP message header.
header-size
server.netty.connectio Connection timeout of the Netty channel.
n-timeout
server.port 8080 Server HTTP port.
432
Key Default Value Description
server.server-header Value to use for the Server response header (if
empty, no header is sent).
server.servlet.applica application Display name of the application.
tion-display-name
server.servlet.context Servlet context init parameters.
-parameters.*
server.servlet.context Context path of the application.
-path
server.servlet.encodin
g.charset
server.servlet.encodin true Whether to enable http encoding support.
g.enabled
server.servlet.encodin
g.force
server.servlet.encodin
g.force-request
server.servlet.encodin
g.force-response
server.servlet.encodin
g.mapping.*
server.servlet.jsp.cla org.apache.jasper.serv Class name of the servlet to use for JSPs. If
ss-name let.JspServlet registered is true and this class * is on the
classpath then it will be registered.
server.servlet.jsp.ini Init parameters used to configure the JSP servlet.
t-parameters.*
server.servlet.jsp.reg true Whether the JSP servlet is registered.
istered
server.servlet.registe true Whether to register the default Servlet with the
r-default-servlet container.
server.servlet.session Comment for the session cookie.
.cookie.comment
server.servlet.session Domain for the session cookie.
.cookie.domain
server.servlet.session Whether to use "HttpOnly" cookies for session
.cookie.http-only cookies.
server.servlet.session Maximum age of the session cookie. If a
.cookie.max-age duration suffix is not specified, seconds will be
used.
server.servlet.session Session cookie name.
.cookie.name
server.servlet.session Path of the session cookie.
.cookie.path
server.servlet.session Whether to always mark the session cookie as
.cookie.secure secure.
433
Key Default Value Description
server.servlet.session false Whether to persist session data between
.persistent restarts.
server.servlet.session Directory used to store session data.
.store-dir
server.servlet.session 30m Session timeout. If a duration suffix is not
.timeout specified, seconds will be used.
server.servlet.session Session tracking modes.
.tracking-modes
server.shutdown immediate Type of shutdown that the server will support.
server.ssl.ciphers Supported SSL ciphers.
server.ssl.client-auth Client authentication mode. Requires a trust
store.
server.ssl.enabled true Whether to enable SSL support.
server.ssl.enabled- Enabled SSL protocols.
protocols
server.ssl.key-alias Alias that identifies the key in the key store.
server.ssl.key- Password used to access the key in the key store.
password
server.ssl.key-store Path to the key store that holds the SSL
certificate (typically a jks file).
server.ssl.key-store- Password used to access the key store.
password
server.ssl.key-store- Provider for the key store.
provider
server.ssl.key-store- Type of the key store.
type
server.ssl.protocol TLS SSL protocol to use.
server.ssl.trust-store Trust store that holds SSL certificates.
server.ssl.trust- Password used to access the trust store.
store-password
server.ssl.trust- Provider for the trust store.
store-provider
server.ssl.trust- Type of the trust store.
store-type
server.tomcat.accept- 100 Maximum queue length for incoming
count connection requests when all possible request
processing threads are in use.
server.tomcat.accesslo true Whether to buffer output such that it is flushed
g.buffered only periodically.
434
Key Default Value Description
server.tomcat.accesslo false Whether to check for log file existence so it can
g.check-exists be recreated it if an external process has
renamed it.
server.tomcat.accesslo Whether logging of the request will only be
g.condition-if enabled if
"ServletRequest.getAttribute(conditionIf)" does
not yield null.
server.tomcat.accesslo Whether logging of the request will only be
g.condition-unless enabled if
"ServletRequest.getAttribute(conditionUnless)"
yield null.
server.tomcat.accesslo logs Directory in which log files are created. Can be
g.directory absolute or relative to the Tomcat base dir.
server.tomcat.accesslo false Enable access log.
g.enabled
server.tomcat.accesslo Character set used by the log file. Default to the
g.encoding system default character set.
server.tomcat.accesslo .yyyy-MM-dd Date format to place in the log file name.
g.file-date-format
server.tomcat.accesslo false Whether to use IPv6 canonical representation
g.ipv6-canonical format as defined by RFC 5952.
server.tomcat.accesslo Locale used to format timestamps in log entries
g.locale and in log file name suffix. Default to the default
locale of the Java process.
server.tomcat.accesslo -1 Number of days to retain the access log files
g.max-days before they are removed.
server.tomcat.accesslo common Format pattern for access logs.
g.pattern
server.tomcat.accesslo access_log Log file name prefix.
g.prefix
server.tomcat.accesslo false Whether to defer inclusion of the date stamp in
g.rename-on-rotate the file name until rotate time.
server.tomcat.accesslo false Set request attributes for the IP address,
g.request-attributes- Hostname, protocol, and port used for the
enabled
request.
server.tomcat.accesslo true Whether to enable access log rotation.
g.rotate
server.tomcat.accesslo .log Log file name suffix.
g.suffix
435
Key Default Value Description
server.tomcat.addition Comma-separated list of additional patterns that
al-tld-skip-patterns match jars to ignore for TLD scanning. The
special '?' and '*' characters can be used in the
pattern to match one and only one character
and zero or more characters respectively.
server.tomcat.backgrou 10s Delay between the invocation of
nd-processor-delay backgroundProcess methods. If a duration suffix
is not specified, seconds will be used.
server.tomcat.basedir Tomcat base directory. If not specified, a
temporary directory is used.
server.tomcat.connecti Amount of time the connector will wait, after
on-timeout accepting a connection, for the request URI line
to be presented.
server.tomcat.max- 8192 Maximum number of connections that the
connections server accepts and processes at any given time.
Once the limit has been reached, the operating
system may still accept connections based on the
"acceptCount" property.
server.tomcat.max- 2MB Maximum size of the form content in any HTTP
http-form-post-size post request.
server.tomcat.max- 2MB Maximum amount of request body to swallow.
swallow-size
server.tomcat.mbeanreg false Whether Tomcat's MBean Registry should be
istry.enabled enabled.
server.tomcat.processo 200 Maximum number of idle processors that will be
r-cache retained in the cache and reused with a
subsequent request. When set to -1 the cache
will be unlimited with a theoretical maximum
size equal to the maximum number of
connections.
server.tomcat.redirect true Whether requests to the context root should be
-context-root redirected by appending a / to the path. When
using SSL terminated at a proxy, this property
should be set to false.
server.tomcat.relaxed- Comma-separated list of additional unencoded
path-chars characters that should be allowed in URI paths.
Only "< > [ \ ] ^ ` { | }" are allowed.
server.tomcat.relaxed- Comma-separated list of additional unencoded
query-chars characters that should be allowed in URI query
strings. Only "< > [ \ ] ^ ` { | }" are allowed.
server.tomcat.remoteip X-Forwarded-Host Name of the HTTP header from which the
.host-header remote host is extracted.
436
Key Default Value Description
server.tomcat.remoteip 10\\.\\d{1,3}\\.\\d{1, Regular expression that matches proxies that
.internal-proxies 3}\\.\\d{1,3}|192\\.16 are to be trusted.
8\\.\\d{1,3}\\.\\d{1,3
}|169\\.254\\.\\d{1,3}
\\.\\d{1,3}|127\\.\\d{
1,3}\\.\\d{1,3}\\.\\d{
1,3}|172\\.1[6-
9]{1}\\.\\d{1,3}\\.\\d
{1,3}|172\\.2[0-
9]{1}\\.\\d{1,3}\\.\\d
{1,3}|172\\.3[0-
1]{1}\\.\\d{1,3}\\.\\d
{1,3}|0:0:0:0:0:0:0:1|
::1
server.tomcat.remoteip X-Forwarded-Port Name of the HTTP header used to override the
.port-header original port value.
server.tomcat.remoteip Header that holds the incoming protocol, usually
.protocol-header named "X-Forwarded-Proto".
server.tomcat.remoteip https Value of the protocol header indicating whether
.protocol-header- the incoming request uses SSL.
https-value
server.tomcat.remoteip Name of the HTTP header from which the
.remote-ip-header remote IP is extracted. For instance, `X-
FORWARDED-FOR`.
server.tomcat.resource true Whether static resource caching is permitted for
.allow-caching this web application.
server.tomcat.resource Time-to-live of the static resource cache.
.cache-ttl
server.tomcat.threads. 200 Maximum amount of worker threads.
max
server.tomcat.threads. 10 Minimum amount of worker threads.
min-spare
server.tomcat.uri- UTF-8 Character encoding to use to decode the URI.
encoding
server.tomcat.use- false Whether HTTP 1.1 and later location headers
relative-redirects generated by a call to sendRedirect will use
relative or absolute redirects.
server.undertow.access Undertow access log directory.
log.dir
server.undertow.access false Whether to enable the access log.
log.enabled
server.undertow.access common Format pattern for access logs.
log.pattern
server.undertow.access access_log. Log file name prefix.
log.prefix
437
Key Default Value Description
server.undertow.access true Whether to enable access log rotation.
log.rotate
server.undertow.access log Log file name suffix.
log.suffix
server.undertow.allow- false Whether the server should decode percent
encoded-slash encoded slash characters. Enabling encoded
slashes can have security implications due to
different servers interpreting the slash
differently. Only enable this if you have a legacy
application that requires it.
server.undertow.always true Whether the 'Connection: keep-alive' header
-set-keep-alive should be added to all responses, even if not
required by the HTTP specification.
server.undertow.buffer Size of each buffer. The default is derived from
-size the maximum amount of memory that is
available to the JVM.
server.undertow.decode true Whether the URL should be decoded. When
-url disabled, percent-encoded characters in the URL
will be left as-is.
server.undertow.direct Whether to allocate buffers outside the Java
-buffers heap. The default is derived from the maximum
amount of memory that is available to the JVM.
server.undertow.eager- true Whether servlet filters should be initialized on
filter-init startup.
server.undertow.max- 200 Maximum number of cookies that are allowed.
cookies This limit exists to prevent hash collision based
DOS attacks.
server.undertow.max- Maximum number of headers that are allowed.
headers This limit exists to prevent hash collision based
DOS attacks.
server.undertow.max- -1B Maximum size of the HTTP post content. When
http-post-size the value is -1, the default, the size is unlimited.
server.undertow.max- Maximum number of query or path parameters
parameters that are allowed. This limit exists to prevent
hash collision based DOS attacks.
server.undertow.no- Amount of time a connection can sit idle without
request-timeout processing a request, before it is closed by the
server.
server.undertow.option
s.server.*
server.undertow.option
s.socket.*
438
Key Default Value Description
server.undertow.thread Number of I/O threads to create for the worker.
s.io The default is derived from the number of
available processors.
server.undertow.thread Number of worker threads. The default is 8
s.worker times the number of I/O threads.
server.undertow.url- UTF-8 Charset used to decode URLs.
charset
439
Key Default Value Description
spring.security.user.n user Default user name.
ame
spring.security.user.p Password for the default user name.
assword
spring.security.user.r Granted roles for the default user name.
oles
440
Key Default Value Description
management.endpoint.co 0ms Maximum time that a response can be cached.
nditions.cache.time-
to-live
management.endpoint.co true Whether to enable the conditions endpoint.
nditions.enabled
management.endpoint.co 0ms Maximum time that a response can be cached.
nfigprops.cache.time-
to-live
management.endpoint.co true Whether to enable the configprops endpoint.
nfigprops.enabled
management.endpoint.co [password, secret, Keys that should be sanitized. Keys can be
nfigprops.keys-to- key, token, simple strings that the property ends with or
sanitize .*credentials.*,
vcap_services, regular expressions.
sun.java.command]
management.endpoint.en 0ms Maximum time that a response can be cached.
v.cache.time-to-live
management.endpoint.en true Whether to enable the env endpoint.
v.enabled
management.endpoint.en [password, secret, Keys that should be sanitized. Keys can be
v.keys-to-sanitize key, token, simple strings that the property ends with or
.*credentials.*,
vcap_services, regular expressions.
sun.java.command]
management.endpoint.fl 0ms Maximum time that a response can be cached.
yway.cache.time-to-
live
management.endpoint.fl true Whether to enable the flyway endpoint.
yway.enabled
management.endpoint.he 0ms Maximum time that a response can be cached.
alth.cache.time-to-
live
management.endpoint.he true Whether to enable the health endpoint.
alth.enabled
management.endpoint.he Health endpoint groups.
alth.group.*
management.endpoint.he false Whether to enable liveness and readiness
alth.probes.enabled probes.
management.endpoint.he Roles used to determine whether or not a user is
alth.roles authorized to be shown details. When empty, all
authenticated users are authorized.
management.endpoint.he When to show components. If not specified the
alth.show-components 'show-details' setting will be used.
management.endpoint.he never When to show full health details.
alth.show-details
441
Key Default Value Description
management.endpoint.he Mapping of health statuses to HTTP status codes.
alth.status.http- By default, registered health statuses map to
mapping.*
sensible defaults (for example, UP maps to 200).
management.endpoint.he [DOWN, OUT_OF_SERVICE, Comma-separated list of health statuses in order
alth.status.order UP, UNKNOWN] of severity.
management.endpoint.he 0ms Maximum time that a response can be cached.
apdump.cache.time-to-
live
management.endpoint.he true Whether to enable the heapdump endpoint.
apdump.enabled
management.endpoint.ht 0ms Maximum time that a response can be cached.
tptrace.cache.time-to-
live
management.endpoint.ht true Whether to enable the httptrace endpoint.
tptrace.enabled
management.endpoint.in 0ms Maximum time that a response can be cached.
fo.cache.time-to-live
management.endpoint.in true Whether to enable the info endpoint.
fo.enabled
management.endpoint.in 0ms Maximum time that a response can be cached.
tegrationgraph.cache.t
ime-to-live
management.endpoint.in true Whether to enable the integrationgraph
tegrationgraph.enabled endpoint.
management.endpoint.jo Jolokia settings. Refer to the documentation of
lokia.config.* Jolokia for more details.
management.endpoint.jo true Whether to enable the jolokia endpoint.
lokia.enabled
management.endpoint.li 0ms Maximum time that a response can be cached.
quibase.cache.time-to-
live
management.endpoint.li true Whether to enable the liquibase endpoint.
quibase.enabled
management.endpoint.lo 0ms Maximum time that a response can be cached.
gfile.cache.time-to-
live
management.endpoint.lo true Whether to enable the logfile endpoint.
gfile.enabled
management.endpoint.lo External Logfile to be accessed. Can be used if
gfile.external-file the logfile is written by output redirect and not
by the logging system itself.
management.endpoint.lo 0ms Maximum time that a response can be cached.
ggers.cache.time-to-
live
442
Key Default Value Description
management.endpoint.lo true Whether to enable the loggers endpoint.
ggers.enabled
management.endpoint.ma 0ms Maximum time that a response can be cached.
ppings.cache.time-to-
live
management.endpoint.ma true Whether to enable the mappings endpoint.
ppings.enabled
management.endpoint.me 0ms Maximum time that a response can be cached.
trics.cache.time-to-
live
management.endpoint.me true Whether to enable the metrics endpoint.
trics.enabled
management.endpoint.pr 0ms Maximum time that a response can be cached.
ometheus.cache.time-
to-live
management.endpoint.pr true Whether to enable the prometheus endpoint.
ometheus.enabled
management.endpoint.sc 0ms Maximum time that a response can be cached.
heduledtasks.cache.tim
e-to-live
management.endpoint.sc true Whether to enable the scheduledtasks endpoint.
heduledtasks.enabled
management.endpoint.se true Whether to enable the sessions endpoint.
ssions.enabled
management.endpoint.sh false Whether to enable the shutdown endpoint.
utdown.enabled
management.endpoint.th 0ms Maximum time that a response can be cached.
readdump.cache.time-
to-live
management.endpoint.th true Whether to enable the threaddump endpoint.
readdump.enabled
management.endpoints.e Whether to enable or disable all endpoints by
nabled-by-default default.
management.endpoints.j org.springframework.bo Endpoints JMX domain name. Fallback to
mx.domain ot 'spring.jmx.default-domain' if set.
management.endpoints.j Endpoint IDs that should be excluded or '*' for
mx.exposure.exclude all.
management.endpoints.j * Endpoint IDs that should be included or '*' for
mx.exposure.include all.
management.endpoints.j Additional static properties to append to all
mx.static-names ObjectNames of MBeans representing Endpoints.
management.endpoints.m false Whether to transparently migrate legacy
igrate-legacy-ids endpoint IDs.
443
Key Default Value Description
management.endpoints.w /actuator Base path for Web endpoints. Relative to
eb.base-path server.servlet.context-path or
management.server.servlet.context-path if
management.server.port is configured.
management.endpoints.w Whether credentials are supported. When not
eb.cors.allow- set, credentials are not supported.
credentials
management.endpoints.w Comma-separated list of headers to allow in a
eb.cors.allowed- request. '*' allows all headers.
headers
management.endpoints.w Comma-separated list of methods to allow. '*'
eb.cors.allowed- allows all methods. When not set, defaults to
methods
GET.
management.endpoints.w Comma-separated list of origins to allow. '*'
eb.cors.allowed- allows all origins. When not set, CORS support is
origins
disabled.
management.endpoints.w Comma-separated list of headers to include in a
eb.cors.exposed- response.
headers
management.endpoints.w 1800s How long the response from a pre-flight request
eb.cors.max-age can be cached by clients. If a duration suffix is
not specified, seconds will be used.
management.endpoints.w Endpoint IDs that should be excluded or '*' for
eb.exposure.exclude all.
management.endpoints.w [health, info] Endpoint IDs that should be included or '*' for
eb.exposure.include all.
management.endpoints.w Mapping between endpoint IDs and the path
eb.path-mapping.* that should expose them.
management.health.cass true Whether to enable Cassandra health check.
andra.enabled
management.health.couc true Whether to enable Couchbase health check.
hbase.enabled
management.health.db.e true Whether to enable database health check.
nabled
management.health.defa true Whether to enable default health indicators.
ults.enabled
management.health.disk true Whether to enable disk space health check.
space.enabled
management.health.disk Path used to compute the available disk space.
space.path
management.health.disk 10MB Minimum disk space that should be available.
space.threshold
management.health.elas true Whether to enable Elasticsearch health check.
ticsearch.enabled
444
Key Default Value Description
management.health.infl true Whether to enable InfluxDB health check.
uxdb.enabled
management.health.jms. true Whether to enable JMS health check.
enabled
management.health.ldap true Whether to enable LDAP health check.
.enabled
management.health.live false Whether to enable liveness state health check.
nessstate.enabled
management.health.mail true Whether to enable Mail health check.
.enabled
management.health.mong true Whether to enable MongoDB health check.
o.enabled
management.health.neo4 true Whether to enable Neo4j health check.
j.enabled
management.health.ping true Whether to enable ping health check.
.enabled
management.health.rabb true Whether to enable RabbitMQ health check.
it.enabled
management.health.read false Whether to enable readiness state health check.
inessstate.enabled
management.health.redi true Whether to enable Redis health check.
s.enabled
management.health.solr true Whether to enable Solr health check.
.enabled
management.info.build. true Whether to enable build info.
enabled
management.info.defaul true Whether to enable default info contributors.
ts.enabled
management.info.env.en true Whether to enable environment info.
abled
management.info.git.en true Whether to enable git info.
abled
management.info.git.mo simple Mode to use to expose git information.
de
management.metrics.dis Maximum value that meter IDs starting with the
tribution.maximum- specified name are expected to observe. The
expected-value.*
longest match wins. Values can be specified as a
long or as a Duration value (for timer meters,
defaulting to ms if no unit specified).
management.metrics.dis Minimum value that meter IDs starting with the
tribution.minimum- specified name are expected to observe. The
expected-value.*
longest match wins. Values can be specified as a
long or as a Duration value (for timer meters,
defaulting to ms if no unit specified).
445
Key Default Value Description
management.metrics.dis Whether meter IDs starting with the specified
tribution.percentiles- name should publish percentile histograms. For
histogram.*
monitoring systems that support aggregable
percentile calculation based on a histogram, this
can be set to true. For other systems, this has no
effect. The longest match wins, the key `all` can
also be used to configure all meters.
management.metrics.dis Specific computed non-aggregable percentiles to
tribution.percentiles. ship to the backend for meter IDs starting-with
*
the specified name. The longest match wins, the
key `all` can also be used to configure all
meters.
management.metrics.dis Specific service-level objective boundaries for
tribution.slo.* meter IDs starting with the specified name. The
longest match wins. Counters will be published
for each specified boundary. Values can be
specified as a long or as a Duration value (for
timer meters, defaulting to ms if no unit
specified).
management.metrics.ena Whether meter IDs starting with the specified
ble.* name should be enabled. The longest match
wins, the key `all` can also be used to configure
all meters.
management.metrics.exp AppOptics API token.
ort.appoptics.api-
token
management.metrics.exp 500 Number of measurements per request to use for
ort.appoptics.batch- this backend. If more measurements are found,
size
then multiple requests will be made.
management.metrics.exp 5s Connection timeout for requests to this backend.
ort.appoptics.connect-
timeout
management.metrics.exp true Whether exporting of metrics to this backend is
ort.appoptics.enabled enabled.
management.metrics.exp false Whether to ship a floored time, useful when
ort.appoptics.floor- sending measurements from multiple hosts to
times
align them on a given time boundary.
management.metrics.exp instance Tag that will be mapped to "@host" when
ort.appoptics.host-tag shipping metrics to AppOptics.
management.metrics.exp 10s Read timeout for requests to this backend.
ort.appoptics.read-
timeout
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.appoptics.step
446
Key Default Value Description
management.metrics.exp https://api.appoptics. URI to ship metrics to.
ort.appoptics.uri com/v1/measurements
management.metrics.exp 10000 Number of measurements per request to use for
ort.atlas.batch-size this backend. If more measurements are found,
then multiple requests will be made.
management.metrics.exp 10s Frequency for refreshing config settings from
ort.atlas.config- the LWC service.
refresh-frequency
management.metrics.exp 150s Time to live for subscriptions from the LWC
ort.atlas.config-time- service.
to-live
management.metrics.exp http://localhost:7101/ URI for the Atlas LWC endpoint to retrieve
ort.atlas.config-uri lwc/api/v1/expressions current subscriptions.
/local-dev
management.metrics.exp 1s Connection timeout for requests to this backend.
ort.atlas.connect-
timeout
management.metrics.exp true Whether exporting of metrics to this backend is
ort.atlas.enabled enabled.
management.metrics.exp http://localhost:7101/ URI for the Atlas LWC endpoint to evaluate the
ort.atlas.eval-uri lwc/api/v1/evaluate data for a subscription.
management.metrics.exp false Whether to enable streaming to Atlas LWC.
ort.atlas.lwc-enabled
management.metrics.exp 15m Time to live for meters that do not have any
ort.atlas.meter-time- activity. After this period the meter will be
to-live
considered expired and will not get reported.
management.metrics.exp 4 Number of threads to use with the metrics
ort.atlas.num-threads publishing scheduler.
management.metrics.exp 10s Read timeout for requests to this backend.
ort.atlas.read-timeout
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.atlas.step
management.metrics.exp http://localhost:7101/ URI of the Atlas server.
ort.atlas.uri api/v1/publish
management.metrics.exp Datadog API key.
ort.datadog.api-key
management.metrics.exp Datadog application key. Not strictly required,
ort.datadog.applicatio but improves the Datadog experience by sending
n-key
meter descriptions, types, and base units to
Datadog.
management.metrics.exp 10000 Number of measurements per request to use for
ort.datadog.batch-size this backend. If more measurements are found,
then multiple requests will be made.
447
Key Default Value Description
management.metrics.exp 1s Connection timeout for requests to this backend.
ort.datadog.connect-
timeout
management.metrics.exp true Whether to publish descriptions metadata to
ort.datadog.descriptio Datadog. Turn this off to minimize the amount
ns
of metadata sent.
management.metrics.exp true Whether exporting of metrics to this backend is
ort.datadog.enabled enabled.
management.metrics.exp instance Tag that will be mapped to "host" when shipping
ort.datadog.host-tag metrics to Datadog.
management.metrics.exp 10s Read timeout for requests to this backend.
ort.datadog.read-
timeout
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.datadog.step
management.metrics.exp https://api.datadoghq. URI to ship metrics to. If you need to publish
ort.datadog.uri com metrics to an internal proxy en-route to
Datadog, you can define the location of the
proxy with this.
management.metrics.exp Dynatrace authentication token.
ort.dynatrace.api-
token
management.metrics.exp 10000 Number of measurements per request to use for
ort.dynatrace.batch- this backend. If more measurements are found,
size
then multiple requests will be made.
management.metrics.exp 1s Connection timeout for requests to this backend.
ort.dynatrace.connect-
timeout
management.metrics.exp ID of the custom device that is exporting metrics
ort.dynatrace.device- to Dynatrace.
id
management.metrics.exp true Whether exporting of metrics to this backend is
ort.dynatrace.enabled enabled.
management.metrics.exp Group for exported metrics. Used to specify
ort.dynatrace.group custom device group name in the Dynatrace UI.
management.metrics.exp 10s Read timeout for requests to this backend.
ort.dynatrace.read-
timeout
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.dynatrace.step
management.metrics.exp java Technology type for exported metrics. Used to
ort.dynatrace.technolo group metrics under a logical technology name
gy-type
in the Dynatrace UI.
448
Key Default Value Description
management.metrics.exp URI to ship metrics to. Should be used for SaaS,
ort.dynatrace.uri self managed instances or to en-route through
an internal proxy.
management.metrics.exp true Whether to create the index automatically if it
ort.elastic.auto- does not exist.
create-index
management.metrics.exp 10000 Number of measurements per request to use for
ort.elastic.batch-size this backend. If more measurements are found,
then multiple requests will be made.
management.metrics.exp 1s Connection timeout for requests to this backend.
ort.elastic.connect-
timeout
management.metrics.exp true Whether exporting of metrics to this backend is
ort.elastic.enabled enabled.
management.metrics.exp http://localhost:9200 Host to export metrics to.
ort.elastic.host
management.metrics.exp metrics Index to export metrics to.
ort.elastic.index
management.metrics.exp yyyy-MM Index date format used for rolling indices.
ort.elastic.index- Appended to the index name.
date-format
management.metrics.exp - Prefix to separate the index name from the date
ort.elastic.index- format used for rolling indices.
date-separator
management.metrics.exp Login password of the Elastic server.
ort.elastic.password
management.metrics.exp Ingest pipeline name. By default, events are not
ort.elastic.pipeline pre-processed.
management.metrics.exp 10s Read timeout for requests to this backend.
ort.elastic.read-
timeout
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.elastic.step
management.metrics.exp @timestamp Name of the timestamp field.
ort.elastic.timestamp-
field-name
management.metrics.exp Login user of the Elastic server.
ort.elastic.user-name
management.metrics.exp multicast UDP addressing mode, either unicast or
ort.ganglia.addressing multicast.
-mode
management.metrics.exp milliseconds Base time unit used to report durations.
ort.ganglia.duration-
units
449
Key Default Value Description
management.metrics.exp true Whether exporting of metrics to Ganglia is
ort.ganglia.enabled enabled.
management.metrics.exp localhost Host of the Ganglia server to receive exported
ort.ganglia.host metrics.
management.metrics.exp 8649 Port of the Ganglia server to receive exported
ort.ganglia.port metrics.
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.ganglia.step
management.metrics.exp 1 Time to live for metrics on Ganglia. Set the
ort.ganglia.time-to- multi-cast Time-To-Live to be one greater than
live
the number of hops (routers) between the hosts.
management.metrics.exp milliseconds Base time unit used to report durations.
ort.graphite.duration-
units
management.metrics.exp true Whether exporting of metrics to Graphite is
ort.graphite.enabled enabled.
management.metrics.exp Whether Graphite tags should be used, as
ort.graphite.graphite- opposed to a hierarchical naming convention.
tags-enabled
Enabled by default unless "tagsAsPrefix" is set.
management.metrics.exp localhost Host of the Graphite server to receive exported
ort.graphite.host metrics.
management.metrics.exp 2004 Port of the Graphite server to receive exported
ort.graphite.port metrics.
management.metrics.exp pickled Protocol to use while shipping data to Graphite.
ort.graphite.protocol
management.metrics.exp seconds Base time unit used to report rates.
ort.graphite.rate-
units
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.graphite.step
management.metrics.exp [] For the hierarchical naming convention, turn
ort.graphite.tags-as- the specified tag keys into part of the metric
prefix
prefix. Ignored if "graphiteTagsEnabled" is true.
management.metrics.exp Humio API token.
ort.humio.api-token
management.metrics.exp 10000 Number of measurements per request to use for
ort.humio.batch-size this backend. If more measurements are found,
then multiple requests will be made.
management.metrics.exp 5s Connection timeout for requests to this backend.
ort.humio.connect-
timeout
450
Key Default Value Description
management.metrics.exp true Whether exporting of metrics to this backend is
ort.humio.enabled enabled.
management.metrics.exp 10s Read timeout for requests to this backend.
ort.humio.read-timeout
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.humio.step
management.metrics.exp Humio tags describing the data source in which
ort.humio.tags.* metrics will be stored. Humio tags are a distinct
concept from Micrometer's tags. Micrometer's
tags are used to divide metrics along
dimensional boundaries.
management.metrics.exp https://cloud.humio.co URI to ship metrics to. If you need to publish
ort.humio.uri m metrics to an internal proxy en-route to Humio,
you can define the location of the proxy with
this.
management.metrics.exp true Whether to create the Influx database if it does
ort.influx.auto- not exist before attempting to publish metrics to
create-db
it.
management.metrics.exp 10000 Number of measurements per request to use for
ort.influx.batch-size this backend. If more measurements are found,
then multiple requests will be made.
management.metrics.exp true Whether to enable GZIP compression of metrics
ort.influx.compressed batches published to Influx.
management.metrics.exp 1s Connection timeout for requests to this backend.
ort.influx.connect-
timeout
management.metrics.exp one Write consistency for each point.
ort.influx.consistency
management.metrics.exp mydb Database to send metrics to.
ort.influx.db
management.metrics.exp true Whether exporting of metrics to this backend is
ort.influx.enabled enabled.
management.metrics.exp Login password of the Influx server.
ort.influx.password
management.metrics.exp 10s Read timeout for requests to this backend.
ort.influx.read-
timeout
management.metrics.exp Time period for which Influx should retain data
ort.influx.retention- in the current database. For instance 7d, check
duration
the influx documentation for more details on the
duration format.
451
Key Default Value Description
management.metrics.exp Retention policy to use (Influx writes to the
ort.influx.retention- DEFAULT retention policy if one is not specified).
policy
management.metrics.exp How many copies of the data are stored in the
ort.influx.retention- cluster. Must be 1 for a single node instance.
replication-factor
management.metrics.exp Time range covered by a shard group. For
ort.influx.retention- instance 2w, check the influx documentation for
shard-duration
more details on the duration format.
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.influx.step
management.metrics.exp http://localhost:8086 URI of the Influx server.
ort.influx.uri
management.metrics.exp Login user of the Influx server.
ort.influx.user-name
management.metrics.exp metrics Metrics JMX domain name.
ort.jmx.domain
management.metrics.exp true Whether exporting of metrics to JMX is enabled.
ort.jmx.enabled
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.jmx.step
management.metrics.exp 10000 Number of measurements per request to use for
ort.kairos.batch-size this backend. If more measurements are found,
then multiple requests will be made.
management.metrics.exp 1s Connection timeout for requests to this backend.
ort.kairos.connect-
timeout
management.metrics.exp true Whether exporting of metrics to this backend is
ort.kairos.enabled enabled.
management.metrics.exp Login password of the KairosDB server.
ort.kairos.password
management.metrics.exp 10s Read timeout for requests to this backend.
ort.kairos.read-
timeout
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.kairos.step
management.metrics.exp http://localhost:8080/ URI of the KairosDB server.
ort.kairos.uri api/v1/datapoints
management.metrics.exp Login user of the KairosDB server.
ort.kairos.user-name
management.metrics.exp New Relic account ID.
ort.newrelic.account-
id
management.metrics.exp New Relic API key.
ort.newrelic.api-key
452
Key Default Value Description
management.metrics.exp 10000 Number of measurements per request to use for
ort.newrelic.batch- this backend. If more measurements are found,
size
then multiple requests will be made.
management.metrics.exp Client provider type to use.
ort.newrelic.client-
provider-type
management.metrics.exp 1s Connection timeout for requests to this backend.
ort.newrelic.connect-
timeout
management.metrics.exp true Whether exporting of metrics to this backend is
ort.newrelic.enabled enabled.
management.metrics.exp SpringBootSample The event type that should be published. This
ort.newrelic.event- property will be ignored if 'meter-name-event-
type
type-enabled' is set to 'true'.
management.metrics.exp false Whether to send the meter name as the event
ort.newrelic.meter- type instead of using the 'event-type'
name-event-type-
enabled configuration property value. Can be set to 'true'
if New Relic guidelines are not being followed or
event types consistent with previous Spring Boot
releases are required.
management.metrics.exp 10s Read timeout for requests to this backend.
ort.newrelic.read-
timeout
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.newrelic.step
management.metrics.exp https://insights- URI to ship metrics to.
ort.newrelic.uri collector.newrelic.com
management.metrics.exp true Whether to enable publishing descriptions as
ort.prometheus.descrip part of the scrape payload to Prometheus. Turn
tions
this off to minimize the amount of data sent on
each scrape.
management.metrics.exp true Whether exporting of metrics to Prometheus is
ort.prometheus.enabled enabled.
management.metrics.exp prometheus Histogram type for backing
ort.prometheus.histogr DistributionSummary and Timer.
am-flavor
management.metrics.exp http://localhost:9091 Base URL for the Pushgateway.
ort.prometheus.pushgat
eway.base-url
management.metrics.exp false Enable publishing via a Prometheus
ort.prometheus.pushgat Pushgateway.
eway.enabled
management.metrics.exp Grouping key for the pushed metrics.
ort.prometheus.pushgat
eway.grouping-key.*
453
Key Default Value Description
management.metrics.exp Job identifier for this application instance.
ort.prometheus.pushgat
eway.job
management.metrics.exp 1m Frequency with which to push metrics.
ort.prometheus.pushgat
eway.push-rate
management.metrics.exp none Operation that should be performed on
ort.prometheus.pushgat shutdown.
eway.shutdown-
operation
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.prometheus.step
management.metrics.exp SignalFX access token.
ort.signalfx.access-
token
management.metrics.exp 10000 Number of measurements per request to use for
ort.signalfx.batch- this backend. If more measurements are found,
size
then multiple requests will be made.
management.metrics.exp 1s Connection timeout for requests to this backend.
ort.signalfx.connect-
timeout
management.metrics.exp true Whether exporting of metrics to this backend is
ort.signalfx.enabled enabled.
management.metrics.exp 10s Read timeout for requests to this backend.
ort.signalfx.read-
timeout
management.metrics.exp Uniquely identifies the app instance that is
ort.signalfx.source publishing metrics to SignalFx. Defaults to the
local host name.
management.metrics.exp 10s Step size (i.e. reporting frequency) to use.
ort.signalfx.step
management.metrics.exp https://ingest.signalf URI to ship metrics to.
ort.signalfx.uri x.com
management.metrics.exp true Whether, in the absence of any other exporter,
ort.simple.enabled exporting of metrics to an in-memory backend is
enabled.
management.metrics.exp cumulative Counting mode.
ort.simple.mode
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.simple.step
management.metrics.exp 10000 Number of measurements per request to use for
ort.stackdriver.batch- this backend. If more measurements are found,
size
then multiple requests will be made.
454
Key Default Value Description
management.metrics.exp 1s Connection timeout for requests to this backend.
ort.stackdriver.connec
t-timeout
management.metrics.exp true Whether exporting of metrics to this backend is
ort.stackdriver.enable enabled.
d
management.metrics.exp Identifier of the Google Cloud project to monitor.
ort.stackdriver.projec
t-id
management.metrics.exp 10s Read timeout for requests to this backend.
ort.stackdriver.read-
timeout
management.metrics.exp global Monitored resource type.
ort.stackdriver.resour
ce-type
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.stackdriver.step
management.metrics.exp true Whether exporting of metrics to StatsD is
ort.statsd.enabled enabled.
management.metrics.exp datadog StatsD line protocol to use.
ort.statsd.flavor
management.metrics.exp localhost Host of the StatsD server to receive exported
ort.statsd.host metrics.
management.metrics.exp 1400 Total length of a single payload should be kept
ort.statsd.max-packet- within your network's MTU.
length
management.metrics.exp 10s How often gauges will be polled. When a gauge
ort.statsd.polling- is polled, its value is recalculated and if the
frequency
value has changed (or publishUnchangedMeters
is true), it is sent to the StatsD server.
management.metrics.exp 8125 Port of the StatsD server to receive exported
ort.statsd.port metrics.
management.metrics.exp true Whether to send unchanged meters to the StatsD
ort.statsd.publish- server.
unchanged-meters
management.metrics.exp API token used when publishing metrics directly
ort.wavefront.api- to the Wavefront API host.
token
management.metrics.exp 10000 Number of measurements per request to use for
ort.wavefront.batch- this backend. If more measurements are found,
size
then multiple requests will be made.
management.metrics.exp true Whether exporting of metrics to this backend is
ort.wavefront.enabled enabled.
455
Key Default Value Description
management.metrics.exp Global prefix to separate metrics originating
ort.wavefront.global- from this app's white box instrumentation from
prefix
those originating from other Wavefront
integrations when viewed in the Wavefront UI.
management.metrics.exp 1s
ort.wavefront.sender.f
lush-interval
management.metrics.exp 50000
ort.wavefront.sender.m
ax-queue-size
management.metrics.exp
ort.wavefront.sender.m
essage-size
management.metrics.exp Unique identifier for the app instance that is the
ort.wavefront.source source of metrics being published to Wavefront.
Defaults to the local host name.
management.metrics.exp 1m Step size (i.e. reporting frequency) to use.
ort.wavefront.step
management.metrics.exp https://longboard.wave URI to ship metrics to.
ort.wavefront.uri front.com
management.metrics.tag Common tags that are applied to every meter.
s.*
management.metrics.use true Whether auto-configured MeterRegistry
-global-registry implementations should be bound to the global
static registry on Metrics. For testing, set this to
'false' to maximize test independence.
management.metrics.web 100 Maximum number of unique URI tag values
.client.max-uri-tags allowed. After the max number of tag values is
reached, metrics with additional tag values are
denied by filter.
management.metrics.web true Whether to automatically time web client
.client.request.autoti requests.
me.enabled
management.metrics.web Computed non-aggregable percentiles to
.client.request.autoti publish.
me.percentiles
management.metrics.web false Whether percentile histograms should be
.client.request.autoti published.
me.percentiles-
histogram
management.metrics.web http.client.requests Name of the metric for sent requests.
.client.request.metric
-name
456
Key Default Value Description
management.metrics.web 100 Maximum number of unique URI tag values
.server.max-uri-tags allowed. After the max number of tag values is
reached, metrics with additional tag values are
denied by filter.
management.metrics.web true Whether to automatically time web server
.server.request.autoti requests.
me.enabled
management.metrics.web Computed non-aggregable percentiles to
.server.request.autoti publish.
me.percentiles
management.metrics.web false Whether percentile histograms should be
.server.request.autoti published.
me.percentiles-
histogram
management.metrics.web true Whether the trailing slash should be ignored
.server.request.ignore when recording metrics.
-trailing-slash
management.metrics.web http.server.requests Name of the metric for received requests.
.server.request.metric
-name
management.server.add- false Add the "X-Application-Context" HTTP header in
application-context- each response.
header
management.server.addr Network address to which the management
ess endpoints should bind. Requires a custom
management.server.port.
management.server.port Management endpoint HTTP port (uses the same
port as the application by default). Configure a
different port to use management-specific SSL.
management.server.serv Management endpoint context-path (for
let.context-path instance, `/management`). Requires a custom
management.server.port.
management.server.ssl. Supported SSL ciphers.
ciphers
management.server.ssl. Client authentication mode. Requires a trust
client-auth store.
management.server.ssl. true Whether to enable SSL support.
enabled
management.server.ssl. Enabled SSL protocols.
enabled-protocols
management.server.ssl. Alias that identifies the key in the key store.
key-alias
management.server.ssl. Password used to access the key in the key store.
key-password
457
Key Default Value Description
management.server.ssl. Path to the key store that holds the SSL
key-store certificate (typically a jks file).
management.server.ssl. Password used to access the key store.
key-store-password
management.server.ssl. Provider for the key store.
key-store-provider
management.server.ssl. Type of the key store.
key-store-type
management.server.ssl. TLS SSL protocol to use.
protocol
management.server.ssl. Trust store that holds SSL certificates.
trust-store
management.server.ssl. Password used to access the trust store.
trust-store-password
management.server.ssl. Provider for the trust store.
trust-store-provider
management.server.ssl. Type of the trust store.
trust-store-type
management.trace.http. true Whether to enable HTTP request-response
enabled tracing.
management.trace.http. [request-headers, Items to be included in the trace. Defaults to
include response-headers, request headers (excluding Authorization but
cookies, errors]
including Cookie), response headers (including
Set-Cookie), and time taken.
458
Key Default Value Description
spring.devtools.remote A shared secret required to establish a
.secret connection (required to enable remote support).
spring.devtools.remote X-AUTH-TOKEN HTTP header used to transfer the shared secret.
.secret-header-name
spring.devtools.restar Additional patterns that should be excluded
t.additional-exclude from triggering a full restart.
spring.devtools.restar Additional paths to watch for changes.
t.additional-paths
spring.devtools.restar true Whether to enable automatic restart.
t.enabled
spring.devtools.restar META- Patterns that should be excluded from triggering
t.exclude INF/maven/**,META- a full restart.
INF/resources/**,resou
rces/**,static/**,publ
ic/**,templates/**,**/
*Test.class,**/*Tests.
class,git.properties,M
ETA-INF/build-
info.properties
spring.devtools.restar true Whether to log the condition evaluation delta
t.log-condition- upon restart.
evaluation-delta
spring.devtools.restar 1s Amount of time to wait between polling for
t.poll-interval classpath changes.
spring.devtools.restar 400ms Amount of quiet time required without any
t.quiet-period classpath changes before a restart is triggered.
spring.devtools.restar Name of a specific file that, when changed,
t.trigger-file triggers the restart check. Must be a simple
name (without any path) of a file that appears
on your classpath. If not specified, any classpath
file change triggers the restart.
459
The majority of the metadata file is generated automatically at compile time by processing all items
annotated with @ConfigurationProperties. However, it is possible to write part of the metadata
manually for corner cases or more advanced use cases.
{"groups": [
{
"name": "server",
"type": "org.springframework.boot.autoconfigure.web.ServerProperties",
"sourceType": "org.springframework.boot.autoconfigure.web.ServerProperties"
},
{
"name": "spring.jpa.hibernate",
"type":
"org.springframework.boot.autoconfigure.orm.jpa.JpaProperties$Hibernate",
"sourceType": "org.springframework.boot.autoconfigure.orm.jpa.JpaProperties",
"sourceMethod": "getHibernate()"
}
...
],"properties": [
{
"name": "server.port",
"type": "java.lang.Integer",
"sourceType": "org.springframework.boot.autoconfigure.web.ServerProperties"
},
{
"name": "server.address",
"type": "java.net.InetAddress",
"sourceType": "org.springframework.boot.autoconfigure.web.ServerProperties"
},
{
"name": "spring.jpa.hibernate.ddl-auto",
"type": "java.lang.String",
"description": "DDL mode. This is actually a shortcut for the
\"hibernate.hbm2ddl.auto\" property.",
"sourceType":
"org.springframework.boot.autoconfigure.orm.jpa.JpaProperties$Hibernate"
}
...
],"hints": [
{
"name": "spring.jpa.hibernate.ddl-auto",
"values": [
{
"value": "none",
460
"description": "Disable DDL handling."
},
{
"value": "validate",
"description": "Validate the schema, make no changes to the database."
},
{
"value": "update",
"description": "Update the schema if necessary."
},
{
"value": "create",
"description": "Create the schema and destroy previous data."
},
{
"value": "create-drop",
"description": "Create and then destroy the schema at the end of the
session."
}
]
}
]}
Each “property” is a configuration item that the user specifies with a given value. For example,
server.port and server.address might be specified in application.properties, as follows:
server.port=9090
server.address=127.0.0.1
The “groups” are higher level items that do not themselves specify a value but instead provide a
contextual grouping for properties. For example, the server.port and server.address properties are
part of the server group.
It is not required that every “property” has a “group”. Some properties might exist
in their own right.
Finally, “hints” are additional information used to assist the user in configuring a given property.
For example, when a developer is configuring the spring.jpa.hibernate.ddl-auto property, a tool
can use the hints to offer some auto-completion help for the none, validate, update, create, and
create-drop values.
Group Attributes
The JSON object contained in the groups array can contain the attributes shown in the following
table:
461
Name Type Purpose
type String The class name of the data type of the group. For example, if the
group were based on a class annotated with
@ConfigurationProperties, the attribute would contain the fully
qualified name of that class. If it were based on a @Bean method, it
would be the return type of that method. If the type is not known,
the attribute may be omitted.
description String A short description of the group that can be displayed to users. If
no description is available, it may be omitted. It is recommended
that descriptions be short paragraphs, with the first line
providing a concise summary. The last line in the description
should end with a period (.).
sourceType String The class name of the source that contributed this group. For
example, if the group were based on a @Bean method annotated
with @ConfigurationProperties, this attribute would contain the
fully qualified name of the @Configuration class that contains the
method. If the source type is not known, the attribute may be
omitted.
sourceMethod String The full name of the method (include parenthesis and argument
types) that contributed this group (for example, the name of a
@ConfigurationProperties annotated @Bean method). If the source
method is not known, it may be omitted.
Property Attributes
The JSON object contained in the properties array can contain the attributes described in the
following table:
462
Name Type Purpose
description String A short description of the property that can be displayed to users.
If no description is available, it may be omitted. It is
recommended that descriptions be short paragraphs, with the
first line providing a concise summary. The last line in the
description should end with a period (.).
sourceType String The class name of the source that contributed this property. For
example, if the property were from a class annotated with
@ConfigurationProperties, this attribute would contain the fully
qualified name of that class. If the source type is unknown, it
may be omitted.
defaultValue Object The default value, which is used if the property is not specified. If
the type of the property is an array, it can be an array of value(s).
If the default value is unknown, it may be omitted.
deprecation Deprecation Specify whether the property is deprecated. If the field is not
deprecated or if that information is not known, it may be
omitted. The next table offers more detail about the deprecation
attribute.
The JSON object contained in the deprecation attribute of each properties element can contain the
following attributes:
Prior to Spring Boot 1.3, a single deprecated boolean attribute can be used instead
of the deprecation element. This is still supported in a deprecated fashion and
should no longer be used. If no reason and replacement are available, an empty
deprecation object should be set.
463
app.acme.name. The following example shows how to handle that situation:
@ConfigurationProperties("app.acme")
public class AcmeProperties {
@DeprecatedConfigurationProperty(replacement = "app.acme.name")
@Deprecated
public String getTarget() {
return getName();
}
@Deprecated
public void setTarget(String target) {
setName(target);
}
}
There is no way to set a level. warning is always assumed, since code is still
handling the property.
The preceding code makes sure that the deprecated property still works (delegating to the name
property behind the scenes). Once the getTarget and setTarget methods can be removed from your
public API, the automatic deprecation hint in the metadata goes away as well. If you want to keep a
hint, adding manual metadata with an error deprecation level ensures that users are still informed
about that property. Doing so is particularly useful when a replacement is provided.
Hint Attributes
The JSON object contained in the hints array can contain the attributes shown in the following
table:
464
Name Type Purpose
providers ValueProvider[ A list of providers as defined by the ValueProvider object
] (described later in this document). Each entry defines the name
of the provider and its parameters, if any.
The JSON object contained in the values attribute of each hint element can contain the attributes
described in the following table:
The JSON object contained in the providers attribute of each hint element can contain the attributes
described in the following table:
Objects with the same “property” and “group” name can appear multiple times within a metadata
file. For example, you could bind two separate classes to the same prefix, with each having
potentially overlapping property names. While the same names appearing in the metadata multiple
times should not be common, consumers of metadata should take care to ensure that they support
it.
To improve the user experience and further assist the user in configuring a given property, you can
provide additional metadata that:
• Associates a provider, to attach a well defined semantic to a property, so that a tool can discover
the list of potential values based on the project’s context.
465
Value Hint
The name attribute of each hint refers to the name of a property. In the initial example shown earlier,
we provide five values for the spring.jpa.hibernate.ddl-auto property: none, validate, update,
create, and create-drop. Each value may have a description as well.
If your property is of type Map, you can provide hints for both the keys and the values (but not for
the map itself). The special .keys and .values suffixes must refer to the keys and the values,
respectively.
Assume a sample.contexts maps magic String values to an integer, as shown in the following
example:
@ConfigurationProperties("sample")
public class SampleProperties {
The magic values are (in this example) are sample1 and sample2. In order to offer additional content
assistance for the keys, you could add the following JSON to the manual metadata of the module:
{"hints": [
{
"name": "sample.contexts.keys",
"values": [
{
"value": "sample1"
},
{
"value": "sample2"
}
]
}
]}
We recommend that you use an Enum for those two values instead. If your IDE
supports it, this is by far the most effective approach to auto-completion.
Value Providers
Providers are a powerful way to attach semantics to a property. In this section, we define the
official providers that you can use for your own hints. However, your favorite IDE may implement
some of these or none of them. Also, it could eventually provide its own.
466
As this is a new feature, IDE vendors must catch up with how it works. Adoption
times naturally vary.
Name Description
any Permits any additional value to be provided.
class-reference Auto-completes the classes available in the project. Usually
constrained by a base class that is specified by the target
parameter.
handle-as Handles the property as if it were defined by the type defined by
the mandatory target parameter.
logger-name Auto-completes valid logger names and logger groups. Typically,
package and class names available in the current project can be
auto-completed as well as defined groups.
spring-bean-reference Auto-completes the available bean names in the current project.
Usually constrained by a base class that is specified by the target
parameter.
spring-profile-name Auto-completes the available Spring profile names in the project.
Only one provider can be active for a given property, but you can specify several
providers if they can all manage the property in some way. Make sure to place the
most powerful provider first, as the IDE must use the first one in the JSON section
that it can handle. If no provider for a given property is supported, no special
content assistance is provided, either.
Any
The special any provider value permits any additional values to be provided. Regular value
validation based on the property type should be applied if this is supported.
This provider is typically used if you have a list of values and any extra values should still be
considered as valid.
The following example offers on and off as auto-completion values for system.state:
467
{"hints": [
{
"name": "system.state",
"values": [
{
"value": "on"
},
{
"value": "off"
}
],
"providers": [
{
"name": "any"
}
]
}
]}
Note that, in the preceding example, any other value is also allowed.
Class Reference
The class-reference provider auto-completes classes available in the project. This provider
supports the following parameters:
468
{"hints": [
{
"name": "server.servlet.jsp.class-name",
"providers": [
{
"name": "class-reference",
"parameters": {
"target": "javax.servlet.http.HttpServlet"
}
}
]
}
]}
Handle As
The handle-as provider lets you substitute the type of the property to a more high-level type. This
typically happens when the property has a java.lang.String type, because you do not want your
configuration classes to rely on classes that may not be on the classpath. This provider supports the
following parameters:
• Any java.lang.Enum: Lists the possible values for the property. (We recommend defining the
property with the Enum type, as no further hint should be required for the IDE to auto-complete
the values)
If multiple values can be provided, use a Collection or Array type to teach the IDE
about it.
469
{"hints": [
{
"name": "spring.liquibase.change-log",
"providers": [
{
"name": "handle-as",
"parameters": {
"target": "org.springframework.core.io.Resource"
}
}
]
}
]}
Logger Name
The logger-name provider auto-completes valid logger names and logger groups. Typically,
package and class names available in the current project can be auto-completed. If groups are
enabled (default) and if a custom logger group is identified in the configuration, auto-completion
for it should be provided. Specific frameworks may have extra magic logger names that can be
supported as well.
Since a logger name can be any arbitrary name, this provider should allow any value but could
highlight valid package and class names that are not available in the project’s classpath.
The following metadata snippet corresponds to the standard logging.level property. Keys are
logger names, and values correspond to the standard log levels or any custom level. As Spring Boot
defines a few logger groups out-of-the-box, dedicated value hints have been added for those.
{"hints": [
{
"name": "logging.level.keys",
"values": [
{
"value": "root",
"description": "Root logger used to assign the default logging level."
},
{
"value": "sql",
"description": "SQL logging group including Hibernate SQL logger."
},
{
470
"value": "web",
"description": "Web logging group including codecs."
}
],
"providers": [
{
"name": "logger-name"
}
]
},
{
"name": "logging.level.values",
"values": [
{
"value": "trace"
},
{
"value": "debug"
},
{
"value": "info"
},
{
"value": "warn"
},
{
"value": "error"
},
{
"value": "fatal"
},
{
"value": "off"
}
],
"providers": [
{
"name": "any"
}
]
}
]}
The spring-bean-reference provider auto-completes the beans that are defined in the
configuration of the current project. This provider supports the following parameters:
471
Parameter Type Default value Description
target String none The fully qualified name of the bean class that
(Class) should be assignable to the candidate. Typically
used to filter out non-candidate beans.
The following metadata snippet corresponds to the standard spring.jmx.server property that
defines the name of the MBeanServer bean to use:
{"hints": [
{
"name": "spring.jmx.server",
"providers": [
{
"name": "spring-bean-reference",
"parameters": {
"target": "javax.management.MBeanServer"
}
}
]
}
]}
The binder is not aware of the metadata. If you provide that hint, you still need to
transform the bean name into an actual Bean reference using by the
ApplicationContext.
The spring-profile-name provider auto-completes the Spring profiles that are defined in the
configuration of the current project.
The following metadata snippet corresponds to the standard spring.profiles.active property that
defines the name of the Spring profile(s) to enable:
{"hints": [
{
"name": "spring.profiles.active",
"providers": [
{
"name": "spring-profile-name"
}
]
}
]}
472
11.B.3. Generating Your Own Metadata by Using the Annotation Processor
You can easily generate your own configuration metadata file from items annotated with
@ConfigurationProperties by using the spring-boot-configuration-processor jar. The jar includes a
Java annotation processor which is invoked as your project is compiled.
With Maven the dependency should be declared as optional, as shown in the following example:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
If you have defined @ConfigurationProperties in your application, make sure to configure the
spring-boot-maven-plugin to prevent the repackage goal from adding the dependency into the fat jar:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-
processor</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
dependencies {
annotationProcessor "org.springframework.boot:spring-boot-configuration-processor"
}
473
If you are using an additional-spring-configuration-metadata.json file, the compileJava task should
be configured to depend on the processResources task, as shown in the following example:
compileJava.inputs.files(processResources)
This dependency ensures that the additional metadata is available when the annotation processor
runs during compilation.
If you are using AspectJ in your project, you need to make sure that the annotation
processor runs only once. There are several ways to do this. With Maven, you can
configure the maven-apt-plugin explicitly and add the dependency to the
annotation processor only there. You could also let the AspectJ plugin run all the
processing and disable annotation processing in the maven-compiler-plugin
configuration, as follows:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<proc>none</proc>
</configuration>
</plugin>
The processor picks up both classes and methods that are annotated with @ConfigurationProperties.
If the class is also annotated with @ConstructorBinding, a single constructor is expected and one
property is created per constructor parameter. Otherwise, properties are discovered through the
presence of standard getters and setters with special handling for collection and map types (that is
detected even if only a getter is present). The annotation processor also supports the use of the
@Data, @Getter, and @Setter lombok annotations.
474
@ConfigurationProperties(prefix="server")
public class ServerProperties {
/**
* Name of the server.
*/
private String name;
/**
* IP address to listen to.
*/
private String ip = "127.0.0.1";
/**
* Port to listener to.
*/
private int port = 9797;
This exposes three properties where server.name has no default and server.ip and server.port
defaults to "127.0.0.1" and 9797 respectively. The Javadoc on fields is used to populate the
description attribute. For instance, the description of server.ip is "IP address to listen to.".
You should only use plain text with @ConfigurationProperties field Javadoc, since
they are not processed before being added to the JSON.
The annotation processor applies a number of heuristics to extract the default value from the
source model. Default values have to be provided statically. In particular, do not refer to a constant
defined in another class. Also, the annotation processor cannot auto-detect default values for Enums
and Collectionss.
For cases where the default value could not be detected, manual metadata should be provided.
Consider the following example:
475
@ConfigurationProperties(prefix = "acme.messaging")
public class MessagingProperties {
SIMPLE,
DIRECT
}
In order to document default values for properties in the class above, you could add the following
content to the manual metadata of the module:
{"properties": [
{
"name": "acme.messaging.addresses",
"defaultValue": ["a", "b"]
},
{
"name": "acme.messaging.container-type",
"defaultValue": "simple"
}
]}
Only the name of the property is required to document additional metadata for
existing properties.
Nested Properties
The annotation processor automatically considers inner classes as nested properties. Rather than
documenting the ip and port at the root of the namespace, we could create a sub-namespace for it.
Consider the updated example:
476
@ConfigurationProperties(prefix="server")
public class ServerProperties {
}
The preceding example produces metadata information for server.name, server.host.ip, and
server.host.port properties. You can use the @NestedConfigurationProperty annotation on a field to
indicate that a regular (non-inner) class should be treated as if it were nested.
This has no effect on collections and maps, as those types are automatically
identified, and a single metadata property is generated for each of them.
Spring Boot’s configuration file handling is quite flexible, and it is often the case that properties
may exist that are not bound to a @ConfigurationProperties bean. You may also need to tune some
attributes of an existing key. To support such cases and let you provide custom "hints", the
annotation processor automatically merges items from META-INF/additional-spring-configuration-
metadata.json into the main metadata file.
If you refer to a property that has been detected automatically, the description, default value, and
deprecation information are overridden, if specified. If the manual property declaration is not
identified in the current module, it is added as a new property.
477
application for more details of which features are switched on. (To do so, start the app with --debug
or -Ddebug or, in an Actuator application, use the conditions endpoint).
11.C.1. spring-boot-autoconfigure
478
Configuration Class Links
ErrorWebFluxAutoConfiguration javadoc
FlywayAutoConfiguration javadoc
FreeMarkerAutoConfiguration javadoc
GroovyTemplateAutoConfiguration javadoc
GsonAutoConfiguration javadoc
H2ConsoleAutoConfiguration javadoc
HazelcastAutoConfiguration javadoc
HazelcastJpaDependencyAutoConfiguration javadoc
HibernateJpaAutoConfiguration javadoc
HttpEncodingAutoConfiguration javadoc
HttpHandlerAutoConfiguration javadoc
HttpMessageConvertersAutoConfiguration javadoc
HypermediaAutoConfiguration javadoc
InfluxDbAutoConfiguration javadoc
IntegrationAutoConfiguration javadoc
JacksonAutoConfiguration javadoc
JdbcRepositoriesAutoConfiguration javadoc
JdbcTemplateAutoConfiguration javadoc
JerseyAutoConfiguration javadoc
JmsAutoConfiguration javadoc
JmxAutoConfiguration javadoc
JndiConnectionFactoryAutoConfiguration javadoc
JndiDataSourceAutoConfiguration javadoc
JooqAutoConfiguration javadoc
JpaRepositoriesAutoConfiguration javadoc
JsonbAutoConfiguration javadoc
JtaAutoConfiguration javadoc
KafkaAutoConfiguration javadoc
LdapAutoConfiguration javadoc
LdapRepositoriesAutoConfiguration javadoc
LifecycleAutoConfiguration javadoc
LiquibaseAutoConfiguration javadoc
MailSenderAutoConfiguration javadoc
479
Configuration Class Links
MailSenderValidatorAutoConfiguration javadoc
MessageSourceAutoConfiguration javadoc
MongoAutoConfiguration javadoc
MongoDataAutoConfiguration javadoc
MongoReactiveAutoConfiguration javadoc
MongoReactiveDataAutoConfiguration javadoc
MongoReactiveRepositoriesAutoConfiguration javadoc
MongoRepositoriesAutoConfiguration javadoc
MultipartAutoConfiguration javadoc
MustacheAutoConfiguration javadoc
Neo4jDataAutoConfiguration javadoc
Neo4jRepositoriesAutoConfiguration javadoc
OAuth2ClientAutoConfiguration javadoc
OAuth2ResourceServerAutoConfiguration javadoc
PersistenceExceptionTranslationAutoConfiguration javadoc
ProjectInfoAutoConfiguration javadoc
PropertyPlaceholderAutoConfiguration javadoc
QuartzAutoConfiguration javadoc
R2dbcAutoConfiguration javadoc
R2dbcDataAutoConfiguration javadoc
R2dbcRepositoriesAutoConfiguration javadoc
R2dbcTransactionManagerAutoConfiguration javadoc
RSocketMessagingAutoConfiguration javadoc
RSocketRequesterAutoConfiguration javadoc
RSocketSecurityAutoConfiguration javadoc
RSocketServerAutoConfiguration javadoc
RSocketStrategiesAutoConfiguration javadoc
RabbitAutoConfiguration javadoc
ReactiveElasticsearchRepositoriesAutoConfiguration javadoc
ReactiveElasticsearchRestClientAutoConfiguration javadoc
ReactiveOAuth2ClientAutoConfiguration javadoc
ReactiveOAuth2ResourceServerAutoConfiguration javadoc
ReactiveSecurityAutoConfiguration javadoc
480
Configuration Class Links
ReactiveUserDetailsServiceAutoConfiguration javadoc
ReactiveWebServerFactoryAutoConfiguration javadoc
RedisAutoConfiguration javadoc
RedisReactiveAutoConfiguration javadoc
RedisRepositoriesAutoConfiguration javadoc
RepositoryRestMvcAutoConfiguration javadoc
RestTemplateAutoConfiguration javadoc
Saml2RelyingPartyAutoConfiguration javadoc
SecurityAutoConfiguration javadoc
SecurityFilterAutoConfiguration javadoc
SendGridAutoConfiguration javadoc
ServletWebServerFactoryAutoConfiguration javadoc
SessionAutoConfiguration javadoc
SolrAutoConfiguration javadoc
SolrRepositoriesAutoConfiguration javadoc
SpringApplicationAdminJmxAutoConfiguration javadoc
SpringDataWebAutoConfiguration javadoc
TaskExecutionAutoConfiguration javadoc
TaskSchedulingAutoConfiguration javadoc
ThymeleafAutoConfiguration javadoc
TransactionAutoConfiguration javadoc
UserDetailsServiceAutoConfiguration javadoc
ValidationAutoConfiguration javadoc
WebClientAutoConfiguration javadoc
WebFluxAutoConfiguration javadoc
WebMvcAutoConfiguration javadoc
WebServiceTemplateAutoConfiguration javadoc
WebServicesAutoConfiguration javadoc
WebSocketMessagingAutoConfiguration javadoc
WebSocketReactiveAutoConfiguration javadoc
WebSocketServletAutoConfiguration javadoc
XADataSourceAutoConfiguration javadoc
481
11.C.2. spring-boot-actuator-autoconfigure
482
Configuration Class Links
GraphiteMetricsExportAutoConfiguration javadoc
HazelcastHealthContributorAutoConfiguration javadoc
HealthContributorAutoConfiguration javadoc
HealthEndpointAutoConfiguration javadoc
HeapDumpWebEndpointAutoConfiguration javadoc
HibernateMetricsAutoConfiguration javadoc
HttpClientMetricsAutoConfiguration javadoc
HttpTraceAutoConfiguration javadoc
HttpTraceEndpointAutoConfiguration javadoc
HumioMetricsExportAutoConfiguration javadoc
InfluxDbHealthContributorAutoConfiguration javadoc
InfluxMetricsExportAutoConfiguration javadoc
InfoContributorAutoConfiguration javadoc
InfoEndpointAutoConfiguration javadoc
IntegrationGraphEndpointAutoConfiguration javadoc
JerseyServerMetricsAutoConfiguration javadoc
JettyMetricsAutoConfiguration javadoc
JmsHealthContributorAutoConfiguration javadoc
JmxEndpointAutoConfiguration javadoc
JmxMetricsExportAutoConfiguration javadoc
JolokiaEndpointAutoConfiguration javadoc
JvmMetricsAutoConfiguration javadoc
KafkaMetricsAutoConfiguration javadoc
KairosMetricsExportAutoConfiguration javadoc
LdapHealthContributorAutoConfiguration javadoc
LiquibaseEndpointAutoConfiguration javadoc
Log4J2MetricsAutoConfiguration javadoc
LogFileWebEndpointAutoConfiguration javadoc
LogbackMetricsAutoConfiguration javadoc
LoggersEndpointAutoConfiguration javadoc
MailHealthContributorAutoConfiguration javadoc
ManagementContextAutoConfiguration javadoc
ManagementWebSecurityAutoConfiguration javadoc
483
Configuration Class Links
MappingsEndpointAutoConfiguration javadoc
MetricsAutoConfiguration javadoc
MetricsEndpointAutoConfiguration javadoc
MongoHealthContributorAutoConfiguration javadoc
MongoReactiveHealthContributorAutoConfiguration javadoc
Neo4jHealthContributorAutoConfiguration javadoc
NewRelicMetricsExportAutoConfiguration javadoc
PrometheusMetricsExportAutoConfiguration javadoc
RabbitHealthContributorAutoConfiguration javadoc
RabbitMetricsAutoConfiguration javadoc
ReactiveCloudFoundryActuatorAutoConfiguration javadoc
ReactiveManagementContextAutoConfiguration javadoc
ReactiveManagementWebSecurityAutoConfiguration javadoc
RedisHealthContributorAutoConfiguration javadoc
RedisReactiveHealthContributorAutoConfiguration javadoc
ScheduledTasksEndpointAutoConfiguration javadoc
ServletManagementContextAutoConfiguration javadoc
SessionsEndpointAutoConfiguration javadoc
ShutdownEndpointAutoConfiguration javadoc
SignalFxMetricsExportAutoConfiguration javadoc
SimpleMetricsExportAutoConfiguration javadoc
SolrHealthContributorAutoConfiguration javadoc
StackdriverMetricsExportAutoConfiguration javadoc
StatsdMetricsExportAutoConfiguration javadoc
SystemMetricsAutoConfiguration javadoc
ThreadDumpEndpointAutoConfiguration javadoc
TomcatMetricsAutoConfiguration javadoc
WavefrontMetricsExportAutoConfiguration javadoc
WebEndpointAutoConfiguration javadoc
WebFluxMetricsAutoConfiguration javadoc
WebMvcMetricsAutoConfiguration javadoc
484
Appendix D: Test Auto-configuration Annotations
This appendix describes the @…Test auto-configuration annotations that Spring Boot provides to
test slices of your application.
The following table lists the various @…Test annotations that can be used to test slices of your
application and the auto-configuration that they import by default:
485
Test slice Imported auto-configuration
@DataJpaTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.data.jp
a.JpaRepositoriesAutoConfiguration
org.springframework.boot.autoconfigure.flyway.
FlywayAutoConfiguration
org.springframework.boot.autoconfigure.jdbc.Da
taSourceAutoConfiguration
org.springframework.boot.autoconfigure.jdbc.Da
taSourceTransactionManagerAutoConfiguration
org.springframework.boot.autoconfigure.jdbc.Jd
bcTemplateAutoConfiguration
org.springframework.boot.autoconfigure.liquiba
se.LiquibaseAutoConfiguration
org.springframework.boot.autoconfigure.orm.jpa
.HibernateJpaAutoConfiguration
org.springframework.boot.autoconfigure.transac
tion.TransactionAutoConfiguration
org.springframework.boot.test.autoconfigure.jd
bc.TestDatabaseAutoConfiguration
org.springframework.boot.test.autoconfigure.or
m.jpa.TestEntityManagerAutoConfiguration
@DataLdapTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.data.ld
ap.LdapRepositoriesAutoConfiguration
org.springframework.boot.autoconfigure.ldap.Ld
apAutoConfiguration
org.springframework.boot.autoconfigure.ldap.em
bedded.EmbeddedLdapAutoConfiguration
@DataMongoTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.data.mo
ngo.MongoDataAutoConfiguration
org.springframework.boot.autoconfigure.data.mo
ngo.MongoReactiveDataAutoConfiguration
org.springframework.boot.autoconfigure.data.mo
ngo.MongoReactiveRepositoriesAutoConfiguration
org.springframework.boot.autoconfigure.data.mo
ngo.MongoRepositoriesAutoConfiguration
org.springframework.boot.autoconfigure.mongo.M
ongoAutoConfiguration
org.springframework.boot.autoconfigure.mongo.M
ongoReactiveAutoConfiguration
org.springframework.boot.autoconfigure.mongo.e
mbedded.EmbeddedMongoAutoConfiguration
org.springframework.boot.autoconfigure.transac
tion.TransactionAutoConfiguration
486
Test slice Imported auto-configuration
@DataNeo4jTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.data.ne
o4j.Neo4jDataAutoConfiguration
org.springframework.boot.autoconfigure.data.ne
o4j.Neo4jRepositoriesAutoConfiguration
org.springframework.boot.autoconfigure.transac
tion.TransactionAutoConfiguration
@DataR2dbcTest org.springframework.boot.autoconfigure.data.r2
dbc.R2dbcDataAutoConfiguration
org.springframework.boot.autoconfigure.data.r2
dbc.R2dbcRepositoriesAutoConfiguration
org.springframework.boot.autoconfigure.data.r2
dbc.R2dbcTransactionManagerAutoConfiguration
org.springframework.boot.autoconfigure.flyway.
FlywayAutoConfiguration
org.springframework.boot.autoconfigure.liquiba
se.LiquibaseAutoConfiguration
org.springframework.boot.autoconfigure.r2dbc.R
2dbcAutoConfiguration
org.springframework.boot.autoconfigure.transac
tion.TransactionAutoConfiguration
@DataRedisTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.data.re
dis.RedisAutoConfiguration
org.springframework.boot.autoconfigure.data.re
dis.RedisReactiveAutoConfiguration
org.springframework.boot.autoconfigure.data.re
dis.RedisRepositoriesAutoConfiguration
@JdbcTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.flyway.
FlywayAutoConfiguration
org.springframework.boot.autoconfigure.jdbc.Da
taSourceAutoConfiguration
org.springframework.boot.autoconfigure.jdbc.Da
taSourceTransactionManagerAutoConfiguration
org.springframework.boot.autoconfigure.jdbc.Jd
bcTemplateAutoConfiguration
org.springframework.boot.autoconfigure.liquiba
se.LiquibaseAutoConfiguration
org.springframework.boot.autoconfigure.transac
tion.TransactionAutoConfiguration
org.springframework.boot.test.autoconfigure.jd
bc.TestDatabaseAutoConfiguration
487
Test slice Imported auto-configuration
@JooqTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.flyway.
FlywayAutoConfiguration
org.springframework.boot.autoconfigure.jdbc.Da
taSourceAutoConfiguration
org.springframework.boot.autoconfigure.jdbc.Da
taSourceTransactionManagerAutoConfiguration
org.springframework.boot.autoconfigure.jooq.Jo
oqAutoConfiguration
org.springframework.boot.autoconfigure.liquiba
se.LiquibaseAutoConfiguration
org.springframework.boot.autoconfigure.transac
tion.TransactionAutoConfiguration
@JsonTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.gson.Gs
onAutoConfiguration
org.springframework.boot.autoconfigure.jackson
.JacksonAutoConfiguration
org.springframework.boot.autoconfigure.jsonb.J
sonbAutoConfiguration
org.springframework.boot.test.autoconfigure.js
on.JsonTestersAutoConfiguration
@RestClientTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.gson.Gs
onAutoConfiguration
org.springframework.boot.autoconfigure.http.Ht
tpMessageConvertersAutoConfiguration
org.springframework.boot.autoconfigure.http.co
dec.CodecsAutoConfiguration
org.springframework.boot.autoconfigure.jackson
.JacksonAutoConfiguration
org.springframework.boot.autoconfigure.jsonb.J
sonbAutoConfiguration
org.springframework.boot.autoconfigure.web.cli
ent.RestTemplateAutoConfiguration
org.springframework.boot.autoconfigure.web.rea
ctive.function.client.WebClientAutoConfigurati
on
org.springframework.boot.test.autoconfigure.we
b.client.MockRestServiceServerAutoConfiguratio
n
org.springframework.boot.test.autoconfigure.we
b.client.WebClientRestTemplateAutoConfiguratio
n
488
Test slice Imported auto-configuration
@WebFluxTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.context
.MessageSourceAutoConfiguration
org.springframework.boot.autoconfigure.freemar
ker.FreeMarkerAutoConfiguration
org.springframework.boot.autoconfigure.gson.Gs
onAutoConfiguration
org.springframework.boot.autoconfigure.http.co
dec.CodecsAutoConfiguration
org.springframework.boot.autoconfigure.jackson
.JacksonAutoConfiguration
org.springframework.boot.autoconfigure.jsonb.J
sonbAutoConfiguration
org.springframework.boot.autoconfigure.mustach
e.MustacheAutoConfiguration
org.springframework.boot.autoconfigure.securit
y.oauth2.client.reactive.ReactiveOAuth2ClientA
utoConfiguration
org.springframework.boot.autoconfigure.securit
y.oauth2.resource.reactive.ReactiveOAuth2Resou
rceServerAutoConfiguration
org.springframework.boot.autoconfigure.securit
y.reactive.ReactiveSecurityAutoConfiguration
org.springframework.boot.autoconfigure.securit
y.reactive.ReactiveUserDetailsServiceAutoConfi
guration
org.springframework.boot.autoconfigure.thymele
af.ThymeleafAutoConfiguration
org.springframework.boot.autoconfigure.validat
ion.ValidationAutoConfiguration
org.springframework.boot.autoconfigure.web.rea
ctive.WebFluxAutoConfiguration
org.springframework.boot.autoconfigure.web.rea
ctive.error.ErrorWebFluxAutoConfiguration
org.springframework.boot.test.autoconfigure.we
b.reactive.WebTestClientAutoConfiguration
489
Test slice Imported auto-configuration
@WebMvcTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.context
.MessageSourceAutoConfiguration
org.springframework.boot.autoconfigure.data.we
b.SpringDataWebAutoConfiguration
org.springframework.boot.autoconfigure.freemar
ker.FreeMarkerAutoConfiguration
org.springframework.boot.autoconfigure.groovy.
template.GroovyTemplateAutoConfiguration
org.springframework.boot.autoconfigure.gson.Gs
onAutoConfiguration
org.springframework.boot.autoconfigure.hateoas
.HypermediaAutoConfiguration
org.springframework.boot.autoconfigure.http.Ht
tpMessageConvertersAutoConfiguration
org.springframework.boot.autoconfigure.jackson
.JacksonAutoConfiguration
org.springframework.boot.autoconfigure.jsonb.J
sonbAutoConfiguration
org.springframework.boot.autoconfigure.mustach
e.MustacheAutoConfiguration
org.springframework.boot.autoconfigure.securit
y.oauth2.client.servlet.OAuth2ClientAutoConfig
uration
org.springframework.boot.autoconfigure.securit
y.oauth2.resource.servlet.OAuth2ResourceServer
AutoConfiguration
org.springframework.boot.autoconfigure.securit
y.servlet.SecurityAutoConfiguration
org.springframework.boot.autoconfigure.securit
y.servlet.SecurityFilterAutoConfiguration
org.springframework.boot.autoconfigure.securit
y.servlet.UserDetailsServiceAutoConfiguration
org.springframework.boot.autoconfigure.task.Ta
skExecutionAutoConfiguration
org.springframework.boot.autoconfigure.thymele
af.ThymeleafAutoConfiguration
org.springframework.boot.autoconfigure.validat
ion.ValidationAutoConfiguration
org.springframework.boot.autoconfigure.web.ser
vlet.HttpEncodingAutoConfiguration
org.springframework.boot.autoconfigure.web.ser
vlet.WebMvcAutoConfiguration
org.springframework.boot.autoconfigure.web.ser
vlet.error.ErrorMvcAutoConfiguration
org.springframework.boot.test.autoconfigure.we
b.servlet.MockMvcAutoConfiguration
org.springframework.boot.test.autoconfigure.we
b.servlet.MockMvcSecurityConfiguration
org.springframework.boot.test.autoconfigure.we
b.servlet.MockMvcWebClientAutoConfiguration
org.springframework.boot.test.autoconfigure.we
490 b.servlet.MockMvcWebDriverAutoConfiguration
Test slice Imported auto-configuration
@WebServiceClientTest org.springframework.boot.autoconfigure.cache.C
acheAutoConfiguration
org.springframework.boot.autoconfigure.webserv
ices.client.WebServiceTemplateAutoConfiguratio
n
org.springframework.boot.test.autoconfigure.we
bservices.client.MockWebServiceServerAutoConfi
guration
org.springframework.boot.test.autoconfigure.we
bservices.client.WebServiceClientTemplateAutoC
onfiguration
If you need to create executable jars from a different build system or if you are just curious about
the underlying technology, this appendix provides some background.
Java does not provide any standard way to load nested jar files (that is, jar files that are themselves
contained within a jar). This can be problematic if you need to distribute a self-contained
application that can be run from the command line without unpacking.
To solve this problem, many developers use “shaded” jars. A shaded jar packages all classes, from
all jars, into a single “uber jar”. The problem with shaded jars is that it becomes hard to see which
libraries are actually in your application. It can also be problematic if the same filename is used
(but with different content) in multiple jars. Spring Boot takes a different approach and lets you
actually nest jars directly.
Spring Boot Loader-compatible jar files should be structured in the following way:
491
example.jar
|
+-META-INF
| +-MANIFEST.MF
+-org
| +-springframework
| +-boot
| +-loader
| +-<spring boot loader classes>
+-BOOT-INF
+-classes
| +-mycompany
| +-project
| +-YourClasses.class
+-lib
+-dependency1.jar
+-dependency2.jar
Spring Boot Loader-compatible war files should be structured in the following way:
example.war
|
+-META-INF
| +-MANIFEST.MF
+-org
| +-springframework
| +-boot
| +-loader
| +-<spring boot loader classes>
+-WEB-INF
+-classes
| +-com
| +-mycompany
| +-project
| +-YourClasses.class
+-lib
| +-dependency1.jar
| +-dependency2.jar
+-lib-provided
+-servlet-api.jar
+-dependency3.jar
Dependencies should be placed in a nested WEB-INF/lib directory. Any dependencies that are
492
required when running embedded but are not required when deploying to a traditional web
container should be placed in WEB-INF/lib-provided.
Index Files
Spring Boot Loader-compatible jar and war archives can include additional index files under the
BOOT-INF/ directory. A classpath.idx file can be provided for both jars and wars, and it provides the
ordering that jars should be added to the classpath. The layers.idx file can be used only for jars,
and it allows a jar to be split into logical layers for Docker/OCI image creation.
Index files follow a YAML compatible syntax so that they can be easily parsed by third-party tools.
These files, however, are not parsed internally as YAML and they must be written in exactly the
formats described below in order to be used.
Classpath Index
The classpath index file can be provided in BOOT-INF/classpath.idx. It provides a list of jar names
(including the directory) in the order that they should be added to the classpath. Each line must
start with dash space ("-·") and names must be in double quotes.
example.jar
|
+-META-INF
| +-...
+-BOOT-INF
+-classes
| +...
+-lib
+-dependency1.jar
+-dependency2.jar
- "BOOT-INF/lib/dependency2.jar"
- "BOOT-INF/lib/dependency1.jar"
Layer Index
The layers index file can be provided in BOOT-INF/layers.idx. It provides a list of layers and the
parts of the jar that should be contained within them. Layers are written in the order that they
should be added to the Docker/OCI image. Layers names are written as quoted strings prefixed with
dash space ("-·") and with a colon (":") suffix. Layer content is either a file or directory name
written as a quoted string prefixed by space space dash space ("··-·"). A directory name ends with
/, a file name does not. When a directory name is used it means that all files inside that directory
are in the same layer.
493
A typical example of a layers index would be:
- "dependencies":
- "BOOT-INF/lib/dependency1.jar"
- "BOOT-INF/lib/dependency2.jar"
- "application":
- "BOOT-INF/classes/"
- "META-INF/"
myapp.jar
+-------------------+-------------------------+
| /BOOT-INF/classes | /BOOT-INF/lib/mylib.jar |
|+-----------------+||+-----------+----------+|
|| A.class ||| B.class | C.class ||
|+-----------------+||+-----------+----------+|
+-------------------+-------------------------+
^ ^ ^
0063 3452 3980
The preceding example shows how A.class can be found in /BOOT-INF/classes in myapp.jar at
position 0063. B.class from the nested jar can actually be found in myapp.jar at position 3452, and
C.class is at position 3980.
Armed with this information, we can load specific nested entries by seeking to the appropriate part
of the outer jar. We do not need to unpack the archive, and we do not need to read all entry data
into memory.
Spring Boot Loader strives to remain compatible with existing code and libraries.
org.springframework.boot.loader.jar.JarFile extends from java.util.jar.JarFile and should work
as a drop-in replacement. The getURL() method returns a URL that opens a connection compatible
with java.net.JarURLConnection and can be used with Java’s URLClassLoader.
There are three launcher subclasses (JarLauncher, WarLauncher, and PropertiesLauncher). Their
494
purpose is to load resources (.class files and so on) from nested jar files or war files in directories
(as opposed to those explicitly on the classpath). In the case of JarLauncher and WarLauncher, the
nested paths are fixed. JarLauncher looks in BOOT-INF/lib/, and WarLauncher looks in WEB-INF/lib/
and WEB-INF/lib-provided/. You can add extra jars in those locations if you want more. The
PropertiesLauncher looks in BOOT-INF/lib/ in your application archive by default. You can add
additional locations by setting an environment variable called LOADER_PATH or loader.path in
loader.properties (which is a comma-separated list of directories, archives, or directories within
archives).
Launcher Manifest
You need to specify an appropriate Launcher as the Main-Class attribute of META-INF/MANIFEST.MF. The
actual class that you want to launch (that is, the class that contains a main method) should be
specified in the Start-Class attribute.
The following example shows a typical MANIFEST.MF for an executable jar file:
Main-Class: org.springframework.boot.loader.JarLauncher
Start-Class: com.mycompany.project.MyApplication
Main-Class: org.springframework.boot.loader.WarLauncher
Start-Class: com.mycompany.project.MyApplication
You need not specify Class-Path entries in your manifest file. The classpath is
deduced from the nested jars.
PropertiesLauncher has a few special features that can be enabled with external properties (System
properties, environment variables, manifest entries, or loader.properties). The following table
describes these properties:
Key Purpose
loader.path Comma-separated Classpath, such as
lib,${HOME}/app/lib. Earlier entries take
precedence, like a regular -classpath on the
javac command line.
495
Key Purpose
loader.home Used to resolve relative paths in loader.path. For
example, given loader.path=lib, then
${loader.home}/lib is a classpath location (along
with all jar files in that directory). This property
is also used to locate a loader.properties file, as
in the following example /opt/app It defaults to
${user.dir}.
loader.args Default arguments for the main method (space
separated).
loader.main Name of main class to launch (for example,
com.app.Application).
loader.config.name Name of properties file (for example, launcher).
It defaults to loader.
loader.config.location Path to properties file (for example,
classpath:loader.properties). It defaults to
loader.properties.
loader.system Boolean flag to indicate that all properties
should be added to System properties. It defaults
to false.
When specified as environment variables or manifest entries, the following names should be used:
Build plugins automatically move the Main-Class attribute to Start-Class when the
fat jar is built. If you use that, specify the name of the class to launch by using the
Main-Class attribute and leaving out Start-Class.
• loader.properties is searched for in loader.home, then in the root of the classpath, and then in
classpath:/BOOT-INF/classes. The first location where a file with that name exists is used.
• loader.home is the directory location of an additional properties file (overriding the default) only
when loader.config.location is not specified.
• loader.path can contain directories (which are scanned recursively for jar and zip files), archive
paths, a directory within an archive that is scanned for jar files (for example,
496
dependencies.jar!/lib), or wildcard patterns (for the default JVM behavior). Archive paths can
be relative to loader.home or anywhere in the file system with a jar:file: prefix.
• loader.path (if empty) defaults to BOOT-INF/lib (meaning a local directory or a nested one if
running from an archive). Because of this, PropertiesLauncher behaves the same as JarLauncher
when no additional configuration is provided.
• loader.path can not be used to configure the location of loader.properties (the classpath used to
search for the latter is the JVM classpath when PropertiesLauncher is launched).
• Placeholder replacement is done from System and environment variables plus the properties
file itself on all values before use.
• The search order for properties (where it makes sense to look in more than one place) is
environment variables, system properties, loader.properties, the exploded archive manifest,
and the archive manifest.
You need to consider the following restrictions when working with a Spring Boot Loader packaged
application:
• Zip entry compression: The ZipEntry for a nested jar must be saved by using the ZipEntry.STORED
method. This is required so that we can seek directly to individual content within the nested jar.
The content of the nested jar file itself can still be compressed, as can any other entries in the
outer jar.
If the preceding restrictions mean that you cannot use Spring Boot Loader, consider the following
alternatives:
• JarClassLoader
• OneJar
The following table provides details of all of the dependency versions that are provided by Spring
Boot in its CLI (Command Line Interface), Maven dependency management, and Gradle plugin.
497
When you declare a dependency on one of these artifacts without declaring a version, the version
listed in the table is used.
498
Group ID Artifact ID Version
com.fasterxml.jackson.datatype jackson-datatype-eclipse- 2.11.4
collections
com.fasterxml.jackson.datatype jackson-datatype-guava 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-hibernate3 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-hibernate4 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-hibernate5 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-hppc 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-jaxrs 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-jdk8 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-joda 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-joda-money 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-json-org 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-jsr310 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-jsr353 2.11.4
com.fasterxml.jackson.datatype jackson-datatype-pcollections 2.11.4
com.fasterxml.jackson.jaxrs jackson-jaxrs-base 2.11.4
com.fasterxml.jackson.jaxrs jackson-jaxrs-cbor-provider 2.11.4
com.fasterxml.jackson.jaxrs jackson-jaxrs-json-provider 2.11.4
com.fasterxml.jackson.jaxrs jackson-jaxrs-smile-provider 2.11.4
com.fasterxml.jackson.jaxrs jackson-jaxrs-xml-provider 2.11.4
com.fasterxml.jackson.jaxrs jackson-jaxrs-yaml-provider 2.11.4
com.fasterxml.jackson.jr jackson-jr-all 2.11.4
com.fasterxml.jackson.jr jackson-jr-annotation-support 2.11.4
com.fasterxml.jackson.jr jackson-jr-objects 2.11.4
com.fasterxml.jackson.jr jackson-jr-retrofit2 2.11.4
com.fasterxml.jackson.jr jackson-jr-stree 2.11.4
com.fasterxml.jackson.module jackson-module-afterburner 2.11.4
com.fasterxml.jackson.module jackson-module-guice 2.11.4
com.fasterxml.jackson.module jackson-module-jaxb- 2.11.4
annotations
com.fasterxml.jackson.module jackson-module-jsonSchema 2.11.4
com.fasterxml.jackson.module jackson-module-kotlin 2.11.4
com.fasterxml.jackson.module jackson-module-mrbean 2.11.4
com.fasterxml.jackson.module jackson-module-osgi 2.11.4
com.fasterxml.jackson.module jackson-module-parameter-names 2.11.4
com.fasterxml.jackson.module jackson-module-paranamer 2.11.4
com.fasterxml.jackson.module jackson-module-scala_2.10 2.11.4
com.fasterxml.jackson.module jackson-module-scala_2.11 2.11.4
com.fasterxml.jackson.module jackson-module-scala_2.12 2.11.4
499
Group ID Artifact ID Version
com.fasterxml.jackson.module jackson-module-scala_2.13 2.11.4
com.github.ben-manes.caffeine caffeine 2.8.8
com.github.ben-manes.caffeine guava 2.8.8
com.github.ben-manes.caffeine jcache 2.8.8
com.github.ben-manes.caffeine simulator 2.8.8
com.github.mxab.thymeleaf.extr thymeleaf-extras-data- 2.0.1
as attribute
com.google.appengine appengine-api-1.0-sdk 1.9.89
com.google.cloud cloud-spanner-r2dbc 0.5.0
com.google.code.gson gson 2.8.7
com.h2database h2 1.4.200
com.hazelcast hazelcast 3.12.12
com.hazelcast hazelcast-client 3.12.12
com.hazelcast hazelcast-hibernate52 1.3.2
com.hazelcast hazelcast-hibernate53 1.3.2
com.hazelcast hazelcast-spring 3.12.12
com.ibm.db2 jcc 11.5.5.0
com.jayway.jsonpath json-path 2.4.0
com.jayway.jsonpath json-path-assert 2.4.0
com.microsoft.sqlserver mssql-jdbc 7.4.1.jre8
com.nimbusds nimbus-jose-jwt 8.19
com.nimbusds oauth2-oidc-sdk 7.1.3
com.oracle.database.ha ons 19.3.0.0
com.oracle.database.ha simplefan 19.3.0.0
com.oracle.database.jdbc ojdbc10 19.3.0.0
com.oracle.database.jdbc ojdbc10dms 19.3.0.0
com.oracle.database.jdbc ojdbc8 19.3.0.0
com.oracle.database.jdbc ojdbc8dms 19.3.0.0
com.oracle.database.jdbc ucp 19.3.0.0
com.oracle.database.jdbc.debug ojdbc10_g 19.3.0.0
com.oracle.database.jdbc.debug ojdbc10dms_g 19.3.0.0
com.oracle.database.jdbc.debug ojdbc8_g 19.3.0.0
com.oracle.database.jdbc.debug ojdbc8dms_g 19.3.0.0
com.oracle.database.nls orai18n 19.3.0.0
com.oracle.database.observabil dms 19.3.0.0
ity
com.oracle.database.r2dbc oracle-r2dbc 0.1.0
com.oracle.database.security oraclepki 19.3.0.0
com.oracle.database.security osdt_cert 19.3.0.0
500
Group ID Artifact ID Version
com.oracle.database.security osdt_core 19.3.0.0
com.oracle.database.xml xdb 19.3.0.0
com.oracle.database.xml xmlparserv2 19.3.0.0
com.oracle.ojdbc dms 19.3.0.0
com.oracle.ojdbc ojdbc10 19.3.0.0
com.oracle.ojdbc ojdbc10_g 19.3.0.0
com.oracle.ojdbc ojdbc10dms 19.3.0.0
com.oracle.ojdbc ojdbc10dms_g 19.3.0.0
com.oracle.ojdbc ojdbc8 19.3.0.0
com.oracle.ojdbc ojdbc8_g 19.3.0.0
com.oracle.ojdbc ojdbc8dms 19.3.0.0
com.oracle.ojdbc ojdbc8dms_g 19.3.0.0
com.oracle.ojdbc ons 19.3.0.0
com.oracle.ojdbc oraclepki 19.3.0.0
com.oracle.ojdbc orai18n 19.3.0.0
com.oracle.ojdbc osdt_cert 19.3.0.0
com.oracle.ojdbc osdt_core 19.3.0.0
com.oracle.ojdbc simplefan 19.3.0.0
com.oracle.ojdbc ucp 19.3.0.0
com.oracle.ojdbc xdb 19.3.0.0
com.oracle.ojdbc xmlparserv2 19.3.0.0
com.querydsl querydsl-apt 4.3.1
com.querydsl querydsl-collections 4.3.1
com.querydsl querydsl-core 4.3.1
com.querydsl querydsl-jpa 4.3.1
com.querydsl querydsl-mongodb 4.3.1
com.rabbitmq amqp-client 5.9.0
com.samskivert jmustache 1.15
com.sendgrid sendgrid-java 4.4.8
com.squareup.okhttp3 logging-interceptor 3.14.9
com.squareup.okhttp3 mockwebserver 3.14.9
com.squareup.okhttp3 okcurl 3.14.9
com.squareup.okhttp3 okhttp 3.14.9
com.squareup.okhttp3 okhttp-dnsoverhttps 3.14.9
com.squareup.okhttp3 okhttp-sse 3.14.9
com.squareup.okhttp3 okhttp-testing-support 3.14.9
com.squareup.okhttp3 okhttp-tls 3.14.9
com.squareup.okhttp3 okhttp-urlconnection 3.14.9
501
Group ID Artifact ID Version
com.sun.activation jakarta.activation 1.2.2
com.sun.mail jakarta.mail 1.6.7
com.sun.xml.messaging.saaj saaj-impl 1.5.3
com.unboundid unboundid-ldapsdk 4.0.14
com.zaxxer HikariCP 3.4.5
commons-codec commons-codec 1.14
commons-pool commons-pool 1.6
de.flapdoodle.embed de.flapdoodle.embed.mongo 2.2.0
dev.miku r2dbc-mysql 0.8.2.RELEASE
io.dropwizard.metrics metrics-annotation 4.1.22
io.dropwizard.metrics metrics-caffeine 4.1.22
io.dropwizard.metrics metrics-collectd 4.1.22
io.dropwizard.metrics metrics-core 4.1.22
io.dropwizard.metrics metrics-ehcache 4.1.22
io.dropwizard.metrics metrics-graphite 4.1.22
io.dropwizard.metrics metrics-healthchecks 4.1.22
io.dropwizard.metrics metrics-httpasyncclient 4.1.22
io.dropwizard.metrics metrics-httpclient 4.1.22
io.dropwizard.metrics metrics-jcache 4.1.22
io.dropwizard.metrics metrics-jdbi 4.1.22
io.dropwizard.metrics metrics-jdbi3 4.1.22
io.dropwizard.metrics metrics-jersey2 4.1.22
io.dropwizard.metrics metrics-jetty9 4.1.22
io.dropwizard.metrics metrics-jmx 4.1.22
io.dropwizard.metrics metrics-json 4.1.22
io.dropwizard.metrics metrics-jvm 4.1.22
io.dropwizard.metrics metrics-log4j2 4.1.22
io.dropwizard.metrics metrics-logback 4.1.22
io.dropwizard.metrics metrics-servlet 4.1.22
io.dropwizard.metrics metrics-servlets 4.1.22
io.lettuce lettuce-core 5.3.7.RELEASE
io.micrometer micrometer-core 1.5.14
io.micrometer micrometer-jersey2 1.5.14
io.micrometer micrometer-registry-appoptics 1.5.14
io.micrometer micrometer-registry-atlas 1.5.14
io.micrometer micrometer-registry-azure- 1.5.14
monitor
io.micrometer micrometer-registry-cloudwatch 1.5.14
502
Group ID Artifact ID Version
io.micrometer micrometer-registry- 1.5.14
cloudwatch2
io.micrometer micrometer-registry-datadog 1.5.14
io.micrometer micrometer-registry-dynatrace 1.5.14
io.micrometer micrometer-registry-elastic 1.5.14
io.micrometer micrometer-registry-ganglia 1.5.14
io.micrometer micrometer-registry-graphite 1.5.14
io.micrometer micrometer-registry-humio 1.5.14
io.micrometer micrometer-registry-influx 1.5.14
io.micrometer micrometer-registry-jmx 1.5.14
io.micrometer micrometer-registry-kairos 1.5.14
io.micrometer micrometer-registry-new-relic 1.5.14
io.micrometer micrometer-registry-opentsdb 1.5.14
io.micrometer micrometer-registry-prometheus 1.5.14
io.micrometer micrometer-registry-signalfx 1.5.14
io.micrometer micrometer-registry- 1.5.14
stackdriver
io.micrometer micrometer-registry-statsd 1.5.14
io.micrometer micrometer-registry-wavefront 1.5.14
io.micrometer micrometer-test 1.5.14
io.netty netty-all 4.1.65.Final
io.netty netty-buffer 4.1.65.Final
io.netty netty-codec 4.1.65.Final
io.netty netty-codec-dns 4.1.65.Final
io.netty netty-codec-haproxy 4.1.65.Final
io.netty netty-codec-http 4.1.65.Final
io.netty netty-codec-http2 4.1.65.Final
io.netty netty-codec-memcache 4.1.65.Final
io.netty netty-codec-mqtt 4.1.65.Final
io.netty netty-codec-redis 4.1.65.Final
io.netty netty-codec-smtp 4.1.65.Final
io.netty netty-codec-socks 4.1.65.Final
io.netty netty-codec-stomp 4.1.65.Final
io.netty netty-codec-xml 4.1.65.Final
io.netty netty-common 4.1.65.Final
io.netty netty-dev-tools 4.1.65.Final
io.netty netty-example 4.1.65.Final
io.netty netty-handler 4.1.65.Final
io.netty netty-handler-proxy 4.1.65.Final
503
Group ID Artifact ID Version
io.netty netty-resolver 4.1.65.Final
io.netty netty-resolver-dns 4.1.65.Final
io.netty netty-resolver-dns-native- 4.1.65.Final
macos
io.netty netty-tcnative 2.0.39.Final
io.netty netty-tcnative-boringssl- 2.0.39.Final
static
io.netty netty-transport 4.1.65.Final
io.netty netty-transport-native-epoll 4.1.65.Final
io.netty netty-transport-native-kqueue 4.1.65.Final
io.netty netty-transport-native-unix- 4.1.65.Final
common
io.netty netty-transport-rxtx 4.1.65.Final
io.netty netty-transport-sctp 4.1.65.Final
io.netty netty-transport-udt 4.1.65.Final
io.projectreactor reactor-core 3.3.17.RELEASE
io.projectreactor reactor-test 3.3.17.RELEASE
io.projectreactor reactor-tools 3.3.17.RELEASE
io.projectreactor.addons reactor-adapter 3.3.6.RELEASE
io.projectreactor.addons reactor-extra 3.3.6.RELEASE
io.projectreactor.addons reactor-pool 0.1.11.RELEASE
io.projectreactor.kafka reactor-kafka 1.2.5.RELEASE
io.projectreactor.kotlin reactor-kotlin-extensions 1.0.3.RELEASE
io.projectreactor.netty reactor-netty 0.9.20.RELEASE
io.projectreactor.rabbitmq reactor-rabbitmq 1.4.6.RELEASE
io.prometheus simpleclient_pushgateway 0.9.0
io.r2dbc r2dbc-h2 0.8.4.RELEASE
io.r2dbc r2dbc-mssql 0.8.6.RELEASE
io.r2dbc r2dbc-pool 0.8.7.RELEASE
io.r2dbc r2dbc-postgresql 0.8.8.RELEASE
io.r2dbc r2dbc-proxy 0.8.6.RELEASE
io.r2dbc r2dbc-spi 0.8.5.RELEASE
io.reactivex rxjava 1.3.8
io.reactivex rxjava-reactive-streams 1.2.1
io.reactivex.rxjava2 rxjava 2.2.21
io.rest-assured json-path 3.3.0
io.rest-assured json-schema-validator 3.3.0
io.rest-assured rest-assured 3.3.0
io.rest-assured scala-support 3.3.0
504
Group ID Artifact ID Version
io.rest-assured spring-mock-mvc 3.3.0
io.rest-assured spring-web-test-client 3.3.0
io.rest-assured xml-path 3.3.0
io.rsocket rsocket-core 1.0.5
io.rsocket rsocket-load-balancer 1.0.5
io.rsocket rsocket-micrometer 1.0.5
io.rsocket rsocket-test 1.0.5
io.rsocket rsocket-transport-local 1.0.5
io.rsocket rsocket-transport-netty 1.0.5
io.spring.gradle dependency-management-plugin 1.0.11.RELEASE
io.undertow undertow-core 2.1.7.Final
io.undertow undertow-servlet 2.1.7.Final
io.undertow undertow-websockets-jsr 2.1.7.Final
jakarta.activation jakarta.activation-api 1.2.2
jakarta.annotation jakarta.annotation-api 1.3.5
jakarta.jms jakarta.jms-api 2.0.3
jakarta.json jakarta.json-api 1.1.6
jakarta.json.bind jakarta.json.bind-api 1.0.2
jakarta.mail jakarta.mail-api 1.6.7
jakarta.persistence jakarta.persistence-api 2.2.3
jakarta.servlet jakarta.servlet-api 4.0.4
jakarta.servlet.jsp.jstl jakarta.servlet.jsp.jstl-api 1.2.7
jakarta.transaction jakarta.transaction-api 1.3.3
jakarta.validation jakarta.validation-api 2.0.2
jakarta.websocket jakarta.websocket-api 1.1.2
jakarta.ws.rs jakarta.ws.rs-api 2.1.6
jakarta.xml.bind jakarta.xml.bind-api 2.3.3
jakarta.xml.soap jakarta.xml.soap-api 1.4.2
jakarta.xml.ws jakarta.xml.ws-api 2.3.3
javax.activation javax.activation-api 1.2.0
javax.annotation javax.annotation-api 1.3.2
javax.cache cache-api 1.1.1
javax.jms javax.jms-api 2.0.1
javax.json javax.json-api 1.1.4
javax.json.bind javax.json.bind-api 1.0
javax.mail javax.mail-api 1.6.2
javax.money money-api 1.0.3
javax.persistence javax.persistence-api 2.2
505
Group ID Artifact ID Version
javax.servlet javax.servlet-api 4.0.1
javax.servlet jstl 1.2
javax.transaction javax.transaction-api 1.3
javax.validation validation-api 2.0.1.Final
javax.websocket javax.websocket-api 1.1
javax.xml.bind jaxb-api 2.3.1
javax.xml.ws jaxws-api 2.3.1
jaxen jaxen 1.2.0
junit junit 4.12
mysql mysql-connector-java 8.0.25
net.bytebuddy byte-buddy 1.10.22
net.bytebuddy byte-buddy-agent 1.10.22
net.minidev json-smart 2.3.1
net.sf.ehcache ehcache 2.10.9.2
net.sourceforge.htmlunit htmlunit 2.40.0
net.sourceforge.jtds jtds 1.3.1
net.sourceforge.nekohtml nekohtml 1.9.22
nz.net.ultraq.thymeleaf thymeleaf-layout-dialect 2.4.1
org.apache.activemq activemq-amqp 5.15.15
org.apache.activemq activemq-blueprint 5.15.15
org.apache.activemq activemq-broker 5.15.15
org.apache.activemq activemq-camel 5.15.15
org.apache.activemq activemq-client 5.15.15
org.apache.activemq activemq-console 5.15.15
org.apache.activemq activemq-http 5.15.15
org.apache.activemq activemq-jaas 5.15.15
org.apache.activemq activemq-jdbc-store 5.15.15
org.apache.activemq activemq-jms-pool 5.15.15
org.apache.activemq activemq-kahadb-store 5.15.15
org.apache.activemq activemq-karaf 5.15.15
org.apache.activemq activemq-leveldb-store 5.15.15
org.apache.activemq activemq-log4j-appender 5.15.15
org.apache.activemq activemq-mqtt 5.15.15
org.apache.activemq activemq-openwire-generator 5.15.15
org.apache.activemq activemq-openwire-legacy 5.15.15
org.apache.activemq activemq-osgi 5.15.15
org.apache.activemq activemq-partition 5.15.15
org.apache.activemq activemq-pool 5.15.15
506
Group ID Artifact ID Version
org.apache.activemq activemq-ra 5.15.15
org.apache.activemq activemq-run 5.15.15
org.apache.activemq activemq-runtime-config 5.15.15
org.apache.activemq activemq-shiro 5.15.15
org.apache.activemq activemq-spring 5.15.15
org.apache.activemq activemq-stomp 5.15.15
org.apache.activemq activemq-web 5.15.15
org.apache.activemq artemis-amqp-protocol 2.12.0
org.apache.activemq artemis-commons 2.12.0
org.apache.activemq artemis-core-client 2.12.0
org.apache.activemq artemis-jms-client 2.12.0
org.apache.activemq artemis-jms-server 2.12.0
org.apache.activemq artemis-journal 2.12.0
org.apache.activemq artemis-selector 2.12.0
org.apache.activemq artemis-server 2.12.0
org.apache.activemq artemis-service-extensions 2.12.0
org.apache.commons commons-dbcp2 2.7.0
org.apache.commons commons-lang3 3.10
org.apache.commons commons-pool2 2.8.1
org.apache.derby derby 10.14.2.0
org.apache.derby derbyclient 10.14.2.0
org.apache.httpcomponents fluent-hc 4.5.13
org.apache.httpcomponents httpasyncclient 4.1.4
org.apache.httpcomponents httpclient 4.5.13
org.apache.httpcomponents httpclient-cache 4.5.13
org.apache.httpcomponents httpclient-osgi 4.5.13
org.apache.httpcomponents httpclient-win 4.5.13
org.apache.httpcomponents httpcore 4.4.14
org.apache.httpcomponents httpcore-nio 4.4.14
org.apache.httpcomponents httpmime 4.5.13
org.apache.johnzon johnzon-core 1.2.13
org.apache.johnzon johnzon-jaxrs 1.2.13
org.apache.johnzon johnzon-jsonb 1.2.13
org.apache.johnzon johnzon-jsonb-extras 1.2.13
org.apache.johnzon johnzon-jsonschema 1.2.13
org.apache.johnzon johnzon-mapper 1.2.13
org.apache.johnzon johnzon-websocket 1.2.13
org.apache.kafka connect-api 2.5.1
507
Group ID Artifact ID Version
org.apache.kafka connect-basic-auth-extension 2.5.1
org.apache.kafka connect-file 2.5.1
org.apache.kafka connect-json 2.5.1
org.apache.kafka connect-runtime 2.5.1
org.apache.kafka connect-transforms 2.5.1
org.apache.kafka kafka-clients 2.5.1
org.apache.kafka kafka-log4j-appender 2.5.1
org.apache.kafka kafka-streams 2.5.1
org.apache.kafka kafka-streams-scala_2.12 2.5.1
org.apache.kafka kafka-streams-scala_2.13 2.5.1
org.apache.kafka kafka-streams-test-utils 2.5.1
org.apache.kafka kafka-tools 2.5.1
org.apache.kafka kafka_2.12 2.5.1
org.apache.kafka kafka_2.13 2.5.1
org.apache.logging.log4j log4j-1.2-api 2.13.3
org.apache.logging.log4j log4j-api 2.13.3
org.apache.logging.log4j log4j-appserver 2.13.3
org.apache.logging.log4j log4j-cassandra 2.13.3
org.apache.logging.log4j log4j-core 2.13.3
org.apache.logging.log4j log4j-couchdb 2.13.3
org.apache.logging.log4j log4j-docker 2.13.3
org.apache.logging.log4j log4j-flume-ng 2.13.3
org.apache.logging.log4j log4j-iostreams 2.13.3
org.apache.logging.log4j log4j-jcl 2.13.3
org.apache.logging.log4j log4j-jmx-gui 2.13.3
org.apache.logging.log4j log4j-jpa 2.13.3
org.apache.logging.log4j log4j-jpl 2.13.3
org.apache.logging.log4j log4j-jul 2.13.3
org.apache.logging.log4j log4j-kubernetes 2.13.3
org.apache.logging.log4j log4j-liquibase 2.13.3
org.apache.logging.log4j log4j-mongodb2 2.13.3
org.apache.logging.log4j log4j-mongodb3 2.13.3
org.apache.logging.log4j log4j-slf4j-impl 2.13.3
org.apache.logging.log4j log4j-slf4j18-impl 2.13.3
org.apache.logging.log4j log4j-spring-cloud-config- 2.13.3
client
org.apache.logging.log4j log4j-taglib 2.13.3
org.apache.logging.log4j log4j-to-slf4j 2.13.3
org.apache.logging.log4j log4j-web 2.13.3
508
Group ID Artifact ID Version
org.apache.solr solr-analysis-extras 8.5.2
org.apache.solr solr-analytics 8.5.2
org.apache.solr solr-cell 8.5.2
org.apache.solr solr-clustering 8.5.2
org.apache.solr solr-core 8.5.2
org.apache.solr solr-dataimporthandler 8.5.2
org.apache.solr solr-dataimporthandler-extras 8.5.2
org.apache.solr solr-langid 8.5.2
org.apache.solr solr-ltr 8.5.2
org.apache.solr solr-solrj 8.5.2
org.apache.solr solr-test-framework 8.5.2
org.apache.solr solr-velocity 8.5.2
org.apache.tomcat tomcat-annotations-api 9.0.46
org.apache.tomcat tomcat-jdbc 9.0.46
org.apache.tomcat tomcat-jsp-api 9.0.46
org.apache.tomcat.embed tomcat-embed-core 9.0.46
org.apache.tomcat.embed tomcat-embed-el 9.0.46
org.apache.tomcat.embed tomcat-embed-jasper 9.0.46
org.apache.tomcat.embed tomcat-embed-websocket 9.0.46
org.aspectj aspectjrt 1.9.6
org.aspectj aspectjtools 1.9.6
org.aspectj aspectjweaver 1.9.6
org.assertj assertj-core 3.16.1
org.awaitility awaitility 4.0.3
org.awaitility awaitility-groovy 4.0.3
org.awaitility awaitility-kotlin 4.0.3
org.awaitility awaitility-scala 4.0.3
org.codehaus.btm btm 2.1.4
org.codehaus.groovy groovy 2.5.14
org.codehaus.groovy groovy-ant 2.5.14
org.codehaus.groovy groovy-bsf 2.5.14
org.codehaus.groovy groovy-cli-commons 2.5.14
org.codehaus.groovy groovy-cli-picocli 2.5.14
org.codehaus.groovy groovy-console 2.5.14
org.codehaus.groovy groovy-datetime 2.5.14
org.codehaus.groovy groovy-dateutil 2.5.14
org.codehaus.groovy groovy-docgenerator 2.5.14
org.codehaus.groovy groovy-groovydoc 2.5.14
509
Group ID Artifact ID Version
org.codehaus.groovy groovy-groovysh 2.5.14
org.codehaus.groovy groovy-jaxb 2.5.14
org.codehaus.groovy groovy-jmx 2.5.14
org.codehaus.groovy groovy-json 2.5.14
org.codehaus.groovy groovy-json-direct 2.5.14
org.codehaus.groovy groovy-jsr223 2.5.14
org.codehaus.groovy groovy-macro 2.5.14
org.codehaus.groovy groovy-nio 2.5.14
org.codehaus.groovy groovy-servlet 2.5.14
org.codehaus.groovy groovy-sql 2.5.14
org.codehaus.groovy groovy-swing 2.5.14
org.codehaus.groovy groovy-templates 2.5.14
org.codehaus.groovy groovy-test 2.5.14
org.codehaus.groovy groovy-test-junit5 2.5.14
org.codehaus.groovy groovy-testng 2.5.14
org.codehaus.groovy groovy-xml 2.5.14
org.codehaus.janino commons-compiler 3.1.4
org.codehaus.janino commons-compiler-jdk 3.1.4
org.codehaus.janino janino 3.1.4
org.eclipse.jetty apache-jsp 9.4.42.v20210604
org.eclipse.jetty apache-jstl 9.4.42.v20210604
org.eclipse.jetty infinispan-common 9.4.42.v20210604
org.eclipse.jetty infinispan-embedded-query 9.4.42.v20210604
org.eclipse.jetty infinispan-remote-query 9.4.42.v20210604
org.eclipse.jetty jetty-alpn-client 9.4.42.v20210604
org.eclipse.jetty jetty-alpn-conscrypt-client 9.4.42.v20210604
org.eclipse.jetty jetty-alpn-conscrypt-server 9.4.42.v20210604
org.eclipse.jetty jetty-alpn-java-client 9.4.42.v20210604
org.eclipse.jetty jetty-alpn-java-server 9.4.42.v20210604
org.eclipse.jetty jetty-alpn-openjdk8-client 9.4.42.v20210604
org.eclipse.jetty jetty-alpn-openjdk8-server 9.4.42.v20210604
org.eclipse.jetty jetty-alpn-server 9.4.42.v20210604
org.eclipse.jetty jetty-annotations 9.4.42.v20210604
org.eclipse.jetty jetty-ant 9.4.42.v20210604
org.eclipse.jetty jetty-client 9.4.42.v20210604
org.eclipse.jetty jetty-continuation 9.4.42.v20210604
org.eclipse.jetty jetty-deploy 9.4.42.v20210604
org.eclipse.jetty jetty-distribution 9.4.42.v20210604
510
Group ID Artifact ID Version
org.eclipse.jetty jetty-hazelcast 9.4.42.v20210604
org.eclipse.jetty jetty-home 9.4.42.v20210604
org.eclipse.jetty jetty-http 9.4.42.v20210604
org.eclipse.jetty jetty-http-spi 9.4.42.v20210604
org.eclipse.jetty jetty-io 9.4.42.v20210604
org.eclipse.jetty jetty-jaas 9.4.42.v20210604
org.eclipse.jetty jetty-jaspi 9.4.42.v20210604
org.eclipse.jetty jetty-jmx 9.4.42.v20210604
org.eclipse.jetty jetty-jndi 9.4.42.v20210604
org.eclipse.jetty jetty-nosql 9.4.42.v20210604
org.eclipse.jetty jetty-openid 9.4.42.v20210604
org.eclipse.jetty jetty-plus 9.4.42.v20210604
org.eclipse.jetty jetty-proxy 9.4.42.v20210604
org.eclipse.jetty jetty-quickstart 9.4.42.v20210604
org.eclipse.jetty jetty-reactive-httpclient 1.1.9
org.eclipse.jetty jetty-rewrite 9.4.42.v20210604
org.eclipse.jetty jetty-security 9.4.42.v20210604
org.eclipse.jetty jetty-server 9.4.42.v20210604
org.eclipse.jetty jetty-servlet 9.4.42.v20210604
org.eclipse.jetty jetty-servlets 9.4.42.v20210604
org.eclipse.jetty jetty-spring 9.4.42.v20210604
org.eclipse.jetty jetty-unixsocket 9.4.42.v20210604
org.eclipse.jetty jetty-util 9.4.42.v20210604
org.eclipse.jetty jetty-util-ajax 9.4.42.v20210604
org.eclipse.jetty jetty-webapp 9.4.42.v20210604
org.eclipse.jetty jetty-xml 9.4.42.v20210604
org.eclipse.jetty.fcgi fcgi-client 9.4.42.v20210604
org.eclipse.jetty.fcgi fcgi-server 9.4.42.v20210604
org.eclipse.jetty.gcloud jetty-gcloud-session-manager 9.4.42.v20210604
org.eclipse.jetty.http2 http2-client 9.4.42.v20210604
org.eclipse.jetty.http2 http2-common 9.4.42.v20210604
org.eclipse.jetty.http2 http2-hpack 9.4.42.v20210604
org.eclipse.jetty.http2 http2-http-client-transport 9.4.42.v20210604
org.eclipse.jetty.http2 http2-server 9.4.42.v20210604
org.eclipse.jetty.memcached jetty-memcached-sessions 9.4.42.v20210604
org.eclipse.jetty.orbit javax.servlet.jsp 2.2.0.v201112011158
org.eclipse.jetty.osgi jetty-httpservice 9.4.42.v20210604
org.eclipse.jetty.osgi jetty-osgi-boot 9.4.42.v20210604
511
Group ID Artifact ID Version
org.eclipse.jetty.osgi jetty-osgi-boot-jsp 9.4.42.v20210604
org.eclipse.jetty.osgi jetty-osgi-boot-warurl 9.4.42.v20210604
org.eclipse.jetty.websocket javax-websocket-client-impl 9.4.42.v20210604
org.eclipse.jetty.websocket javax-websocket-server-impl 9.4.42.v20210604
org.eclipse.jetty.websocket websocket-api 9.4.42.v20210604
org.eclipse.jetty.websocket websocket-client 9.4.42.v20210604
org.eclipse.jetty.websocket websocket-common 9.4.42.v20210604
org.eclipse.jetty.websocket websocket-server 9.4.42.v20210604
org.eclipse.jetty.websocket websocket-servlet 9.4.42.v20210604
org.ehcache ehcache 3.8.1
org.ehcache ehcache-clustered 3.8.1
org.ehcache ehcache-transactions 3.8.1
org.elasticsearch elasticsearch 7.6.2
org.elasticsearch.client elasticsearch-rest-client 7.6.2
org.elasticsearch.client elasticsearch-rest-client- 7.6.2
sniffer
org.elasticsearch.client elasticsearch-rest-high-level- 7.6.2
client
org.elasticsearch.client transport 7.6.2
org.elasticsearch.distribution elasticsearch 7.6.2
.integ-test-zip
org.elasticsearch.plugin transport-netty4-client 7.6.2
org.firebirdsql.jdbc jaybird-jdk17 3.0.11
org.firebirdsql.jdbc jaybird-jdk18 3.0.11
org.flywaydb flyway-core 6.4.4
org.freemarker freemarker 2.3.31
org.glassfish jakarta.el 3.0.3
org.glassfish.jaxb codemodel 2.3.4
org.glassfish.jaxb codemodel-annotation-compiler 2.3.4
org.glassfish.jaxb jaxb-jxc 2.3.4
org.glassfish.jaxb jaxb-runtime 2.3.4
org.glassfish.jaxb jaxb-xjc 2.3.4
org.glassfish.jaxb txw2 2.3.4
org.glassfish.jaxb txwc2 2.3.4
org.glassfish.jaxb xsom 2.3.4
org.glassfish.jersey.bundles jaxrs-ri 2.30.1
org.glassfish.jersey.connector jersey-apache-connector 2.30.1
s
org.glassfish.jersey.connector jersey-grizzly-connector 2.30.1
s
512
Group ID Artifact ID Version
org.glassfish.jersey.connector jersey-jdk-connector 2.30.1
s
org.glassfish.jersey.connector jersey-jetty-connector 2.30.1
s
org.glassfish.jersey.connector jersey-netty-connector 2.30.1
s
org.glassfish.jersey.container jersey-container-grizzly2-http 2.30.1
s
org.glassfish.jersey.container jersey-container-grizzly2- 2.30.1
s servlet
org.glassfish.jersey.container jersey-container-jdk-http 2.30.1
s
org.glassfish.jersey.container jersey-container-jetty-http 2.30.1
s
org.glassfish.jersey.container jersey-container-jetty-servlet 2.30.1
s
org.glassfish.jersey.container jersey-container-netty-http 2.30.1
s
org.glassfish.jersey.container jersey-container-servlet 2.30.1
s
org.glassfish.jersey.container jersey-container-servlet-core 2.30.1
s
org.glassfish.jersey.container jersey-container-simple-http 2.30.1
s
org.glassfish.jersey.container jersey-gf-ejb 2.30.1
s.glassfish
org.glassfish.jersey.core jersey-client 2.30.1
org.glassfish.jersey.core jersey-common 2.30.1
org.glassfish.jersey.core jersey-server 2.30.1
org.glassfish.jersey.ext jersey-bean-validation 2.30.1
org.glassfish.jersey.ext jersey-declarative-linking 2.30.1
org.glassfish.jersey.ext jersey-entity-filtering 2.30.1
org.glassfish.jersey.ext jersey-metainf-services 2.30.1
org.glassfish.jersey.ext jersey-mvc 2.30.1
org.glassfish.jersey.ext jersey-mvc-bean-validation 2.30.1
org.glassfish.jersey.ext jersey-mvc-freemarker 2.30.1
org.glassfish.jersey.ext jersey-mvc-jsp 2.30.1
org.glassfish.jersey.ext jersey-mvc-mustache 2.30.1
org.glassfish.jersey.ext jersey-proxy-client 2.30.1
org.glassfish.jersey.ext jersey-servlet-portability 2.30.1
org.glassfish.jersey.ext jersey-spring4 2.30.1
org.glassfish.jersey.ext jersey-spring5 2.30.1
513
Group ID Artifact ID Version
org.glassfish.jersey.ext jersey-wadl-doclet 2.30.1
org.glassfish.jersey.ext.cdi jersey-cdi1x 2.30.1
org.glassfish.jersey.ext.cdi jersey-cdi1x-ban-custom-hk2- 2.30.1
binding
org.glassfish.jersey.ext.cdi jersey-cdi1x-servlet 2.30.1
org.glassfish.jersey.ext.cdi jersey-cdi1x-transaction 2.30.1
org.glassfish.jersey.ext.cdi jersey-cdi1x-validation 2.30.1
org.glassfish.jersey.ext.cdi jersey-weld2-se 2.30.1
org.glassfish.jersey.ext.micro jersey-mp-config 2.30.1
profile
org.glassfish.jersey.ext.micro jersey-mp-rest-client 2.30.1
profile
org.glassfish.jersey.ext.rx jersey-rx-client-guava 2.30.1
org.glassfish.jersey.ext.rx jersey-rx-client-rxjava 2.30.1
org.glassfish.jersey.ext.rx jersey-rx-client-rxjava2 2.30.1
org.glassfish.jersey.inject jersey-cdi2-se 2.30.1
org.glassfish.jersey.inject jersey-hk2 2.30.1
org.glassfish.jersey.media jersey-media-jaxb 2.30.1
org.glassfish.jersey.media jersey-media-json-binding 2.30.1
org.glassfish.jersey.media jersey-media-json-jackson 2.30.1
org.glassfish.jersey.media jersey-media-json-jackson1 2.30.1
org.glassfish.jersey.media jersey-media-json-jettison 2.30.1
org.glassfish.jersey.media jersey-media-json-processing 2.30.1
org.glassfish.jersey.media jersey-media-kryo 2.30.1
org.glassfish.jersey.media jersey-media-moxy 2.30.1
org.glassfish.jersey.media jersey-media-multipart 2.30.1
org.glassfish.jersey.media jersey-media-sse 2.30.1
org.glassfish.jersey.security oauth1-client 2.30.1
org.glassfish.jersey.security oauth1-server 2.30.1
org.glassfish.jersey.security oauth1-signature 2.30.1
org.glassfish.jersey.security oauth2-client 2.30.1
org.glassfish.jersey.test- jersey-test-framework-core 2.30.1
framework
org.glassfish.jersey.test- jersey-test-framework-util 2.30.1
framework
org.glassfish.jersey.test- jersey-test-framework- 2.30.1
framework.providers provider-bundle
org.glassfish.jersey.test- jersey-test-framework- 2.30.1
framework.providers provider-external
org.glassfish.jersey.test- jersey-test-framework- 2.30.1
framework.providers provider-grizzly2
514
Group ID Artifact ID Version
org.glassfish.jersey.test- jersey-test-framework- 2.30.1
framework.providers provider-inmemory
org.glassfish.jersey.test- jersey-test-framework- 2.30.1
framework.providers provider-jdk-http
org.glassfish.jersey.test- jersey-test-framework- 2.30.1
framework.providers provider-jetty
org.glassfish.jersey.test- jersey-test-framework- 2.30.1
framework.providers provider-simple
org.hamcrest hamcrest 2.2
org.hamcrest hamcrest-core 2.2
org.hamcrest hamcrest-library 2.2
org.hibernate hibernate-c3p0 5.4.32.Final
org.hibernate hibernate-core 5.4.32.Final
org.hibernate hibernate-ehcache 5.4.32.Final
org.hibernate hibernate-entitymanager 5.4.32.Final
org.hibernate hibernate-envers 5.4.32.Final
org.hibernate hibernate-hikaricp 5.4.32.Final
org.hibernate hibernate-java8 5.4.32.Final
org.hibernate hibernate-jcache 5.4.32.Final
org.hibernate hibernate-jpamodelgen 5.4.32.Final
org.hibernate hibernate-micrometer 5.4.32.Final
org.hibernate hibernate-proxool 5.4.32.Final
org.hibernate hibernate-spatial 5.4.32.Final
org.hibernate hibernate-testing 5.4.32.Final
org.hibernate hibernate-vibur 5.4.32.Final
org.hibernate.validator hibernate-validator 6.1.7.Final
org.hibernate.validator hibernate-validator- 6.1.7.Final
annotation-processor
org.hsqldb hsqldb 2.5.2
org.infinispan infinispan-api 10.1.8.Final
org.infinispan infinispan-cachestore-jdbc 10.1.8.Final
org.infinispan infinispan-cachestore-jpa 10.1.8.Final
org.infinispan infinispan-cachestore-remote 10.1.8.Final
org.infinispan infinispan-cachestore-rest 10.1.8.Final
org.infinispan infinispan-cachestore-rocksdb 10.1.8.Final
org.infinispan infinispan-cdi-common 10.1.8.Final
org.infinispan infinispan-cdi-embedded 10.1.8.Final
org.infinispan infinispan-cdi-remote 10.1.8.Final
org.infinispan infinispan-client-hotrod 10.1.8.Final
org.infinispan infinispan-client-rest 10.1.8.Final
515
Group ID Artifact ID Version
org.infinispan infinispan-clustered-counter 10.1.8.Final
org.infinispan infinispan-clustered-lock 10.1.8.Final
org.infinispan infinispan-commons 10.1.8.Final
org.infinispan infinispan-component- 10.1.8.Final
annotations
org.infinispan infinispan-core 10.1.8.Final
org.infinispan infinispan-directory-provider 10.1.8.Final
org.infinispan infinispan-hibernate-cache-v53 10.1.8.Final
org.infinispan infinispan-jboss-marshalling 10.1.8.Final
org.infinispan infinispan-jcache 10.1.8.Final
org.infinispan infinispan-jcache-commons 10.1.8.Final
org.infinispan infinispan-jcache-remote 10.1.8.Final
org.infinispan infinispan-key-value-store- 10.1.8.Final
client
org.infinispan infinispan-lucene-directory 10.1.8.Final
org.infinispan infinispan-objectfilter 10.1.8.Final
org.infinispan infinispan-osgi 10.1.8.Final
org.infinispan infinispan-persistence-soft- 10.1.8.Final
index
org.infinispan infinispan-query 10.1.8.Final
org.infinispan infinispan-query-core 10.1.8.Final
org.infinispan infinispan-query-dsl 10.1.8.Final
org.infinispan infinispan-remote-query-client 10.1.8.Final
org.infinispan infinispan-remote-query-server 10.1.8.Final
org.infinispan infinispan-scripting 10.1.8.Final
org.infinispan infinispan-server-core 10.1.8.Final
org.infinispan infinispan-server-hotrod 10.1.8.Final
org.infinispan infinispan-server-memcached 10.1.8.Final
org.infinispan infinispan-server-rest 10.1.8.Final
org.infinispan infinispan-server-router 10.1.8.Final
org.infinispan infinispan-spring5-common 10.1.8.Final
org.infinispan infinispan-spring5-embedded 10.1.8.Final
org.infinispan infinispan-spring5-remote 10.1.8.Final
org.infinispan infinispan-tasks 10.1.8.Final
org.infinispan infinispan-tasks-api 10.1.8.Final
org.infinispan infinispan-tools 10.1.8.Final
org.influxdb influxdb-java 2.18
org.jboss jboss-transaction-spi 7.6.1.Final
org.jboss.logging jboss-logging 3.4.2.Final
516
Group ID Artifact ID Version
org.jdom jdom2 2.0.6
org.jetbrains.kotlin kotlin-compiler 1.3.72
org.jetbrains.kotlin kotlin-compiler-embeddable 1.3.72
org.jetbrains.kotlin kotlin-daemon-client 1.3.72
org.jetbrains.kotlin kotlin-main-kts 1.3.72
org.jetbrains.kotlin kotlin-osgi-bundle 1.3.72
org.jetbrains.kotlin kotlin-reflect 1.3.72
org.jetbrains.kotlin kotlin-script-runtime 1.3.72
org.jetbrains.kotlin kotlin-script-util 1.3.72
org.jetbrains.kotlin kotlin-scripting-common 1.3.72
org.jetbrains.kotlin kotlin-scripting-jvm 1.3.72
org.jetbrains.kotlin kotlin-scripting-jvm-host 1.3.72
org.jetbrains.kotlin kotlin-stdlib 1.3.72
org.jetbrains.kotlin kotlin-stdlib-common 1.3.72
org.jetbrains.kotlin kotlin-stdlib-jdk7 1.3.72
org.jetbrains.kotlin kotlin-stdlib-jdk8 1.3.72
org.jetbrains.kotlin kotlin-stdlib-js 1.3.72
org.jetbrains.kotlin kotlin-test 1.3.72
org.jetbrains.kotlin kotlin-test-annotations-common 1.3.72
org.jetbrains.kotlin kotlin-test-common 1.3.72
org.jetbrains.kotlin kotlin-test-js 1.3.72
org.jetbrains.kotlin kotlin-test-junit 1.3.72
org.jetbrains.kotlin kotlin-test-junit5 1.3.72
org.jetbrains.kotlin kotlin-test-testng 1.3.72
org.jetbrains.kotlinx kotlinx-coroutines-android 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-core 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-core-common 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-core-js 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-core-native 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-debug 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-guava 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-javafx 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-jdk8 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-jdk9 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-play- 1.3.8
services
org.jetbrains.kotlinx kotlinx-coroutines-reactive 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-reactor 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-rx2 1.3.8
517
Group ID Artifact ID Version
org.jetbrains.kotlinx kotlinx-coroutines-rx3 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-slf4j 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-swing 1.3.8
org.jetbrains.kotlinx kotlinx-coroutines-test 1.3.8
org.jolokia jolokia-core 1.6.2
org.jooq jooq 3.13.6
org.jooq jooq-codegen 3.13.6
org.jooq jooq-meta 3.13.6
org.junit.jupiter junit-jupiter 5.6.3
org.junit.jupiter junit-jupiter-api 5.6.3
org.junit.jupiter junit-jupiter-engine 5.6.3
org.junit.jupiter junit-jupiter-migrationsupport 5.6.3
org.junit.jupiter junit-jupiter-params 5.6.3
org.junit.platform junit-platform-commons 1.6.3
org.junit.platform junit-platform-console 1.6.3
org.junit.platform junit-platform-engine 1.6.3
org.junit.platform junit-platform-launcher 1.6.3
org.junit.platform junit-platform-reporting 1.6.3
org.junit.platform junit-platform-runner 1.6.3
org.junit.platform junit-platform-suite-api 1.6.3
org.junit.platform junit-platform-testkit 1.6.3
org.junit.vintage junit-vintage-engine 5.6.3
org.jvnet.mimepull mimepull 1.9.14
org.liquibase liquibase-core 3.8.9
org.mariadb r2dbc-mariadb 1.0.1
org.mariadb.jdbc mariadb-java-client 2.6.2
org.messaginghub pooled-jms 1.1.2
org.mockito mockito-core 3.3.3
org.mockito mockito-inline 3.3.3
org.mockito mockito-junit-jupiter 3.3.3
org.mongodb bson 4.0.6
org.mongodb mongodb-driver-core 4.0.6
org.mongodb mongodb-driver-legacy 4.0.6
org.mongodb mongodb-driver-reactivestreams 4.0.6
org.mongodb mongodb-driver-sync 4.0.6
org.mortbay.jasper apache-el 8.5.54
org.neo4j neo4j-ogm-api 3.2.24
org.neo4j neo4j-ogm-bolt-driver 3.2.24
518
Group ID Artifact ID Version
org.neo4j neo4j-ogm-bolt-native-types 3.2.24
org.neo4j neo4j-ogm-core 3.2.24
org.neo4j neo4j-ogm-embedded-driver 3.2.24
org.neo4j neo4j-ogm-embedded-native- 3.2.24
types
org.neo4j neo4j-ogm-http-driver 3.2.24
org.postgresql postgresql 42.2.20
org.projectlombok lombok 1.18.20
org.quartz-scheduler quartz 2.3.2
org.quartz-scheduler quartz-jobs 2.3.2
org.reactivestreams reactive-streams 1.0.3
org.seleniumhq.selenium htmlunit-driver 2.40.0
org.seleniumhq.selenium selenium-api 3.141.59
org.seleniumhq.selenium selenium-chrome-driver 3.141.59
org.seleniumhq.selenium selenium-edge-driver 3.141.59
org.seleniumhq.selenium selenium-firefox-driver 3.141.59
org.seleniumhq.selenium selenium-ie-driver 3.141.59
org.seleniumhq.selenium selenium-java 3.141.59
org.seleniumhq.selenium selenium-opera-driver 3.141.59
org.seleniumhq.selenium selenium-remote-driver 3.141.59
org.seleniumhq.selenium selenium-safari-driver 3.141.59
org.seleniumhq.selenium selenium-support 3.141.59
org.skyscreamer jsonassert 1.5.0
org.slf4j jcl-over-slf4j 1.7.30
org.slf4j jul-to-slf4j 1.7.30
org.slf4j log4j-over-slf4j 1.7.30
org.slf4j slf4j-api 1.7.30
org.slf4j slf4j-ext 1.7.30
org.slf4j slf4j-jcl 1.7.30
org.slf4j slf4j-jdk14 1.7.30
org.slf4j slf4j-log4j12 1.7.30
org.slf4j slf4j-nop 1.7.30
org.slf4j slf4j-simple 1.7.30
org.springframework spring-aop 5.2.15.RELEASE
org.springframework spring-aspects 5.2.15.RELEASE
org.springframework spring-beans 5.2.15.RELEASE
org.springframework spring-context 5.2.15.RELEASE
org.springframework spring-context-indexer 5.2.15.RELEASE
org.springframework spring-context-support 5.2.15.RELEASE
519
Group ID Artifact ID Version
org.springframework spring-core 5.2.15.RELEASE
org.springframework spring-expression 5.2.15.RELEASE
org.springframework spring-instrument 5.2.15.RELEASE
org.springframework spring-jcl 5.2.15.RELEASE
org.springframework spring-jdbc 5.2.15.RELEASE
org.springframework spring-jms 5.2.15.RELEASE
org.springframework spring-messaging 5.2.15.RELEASE
org.springframework spring-orm 5.2.15.RELEASE
org.springframework spring-oxm 5.2.15.RELEASE
org.springframework spring-test 5.2.15.RELEASE
org.springframework spring-tx 5.2.15.RELEASE
org.springframework spring-web 5.2.15.RELEASE
org.springframework spring-webflux 5.2.15.RELEASE
org.springframework spring-webmvc 5.2.15.RELEASE
org.springframework spring-websocket 5.2.15.RELEASE
org.springframework.amqp spring-amqp 2.2.18.RELEASE
org.springframework.amqp spring-rabbit 2.2.18.RELEASE
org.springframework.amqp spring-rabbit-junit 2.2.18.RELEASE
org.springframework.amqp spring-rabbit-test 2.2.18.RELEASE
org.springframework.batch spring-batch-core 4.2.7.RELEASE
org.springframework.batch spring-batch-infrastructure 4.2.7.RELEASE
org.springframework.batch spring-batch-integration 4.2.7.RELEASE
org.springframework.batch spring-batch-test 4.2.7.RELEASE
org.springframework.boot spring-boot 2.3.12.RELEASE
org.springframework.boot spring-boot-actuator 2.3.12.RELEASE
org.springframework.boot spring-boot-actuator- 2.3.12.RELEASE
autoconfigure
org.springframework.boot spring-boot-autoconfigure 2.3.12.RELEASE
org.springframework.boot spring-boot-autoconfigure- 2.3.12.RELEASE
processor
org.springframework.boot spring-boot-buildpack-platform 2.3.12.RELEASE
org.springframework.boot spring-boot-configuration- 2.3.12.RELEASE
metadata
org.springframework.boot spring-boot-configuration- 2.3.12.RELEASE
processor
org.springframework.boot spring-boot-devtools 2.3.12.RELEASE
org.springframework.boot spring-boot-jarmode-layertools 2.3.12.RELEASE
org.springframework.boot spring-boot-loader 2.3.12.RELEASE
org.springframework.boot spring-boot-loader-tools 2.3.12.RELEASE
520
Group ID Artifact ID Version
org.springframework.boot spring-boot-properties- 2.3.12.RELEASE
migrator
org.springframework.boot spring-boot-starter 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-activemq 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-actuator 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-amqp 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-aop 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-artemis 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-batch 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-cache 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-data- 2.3.12.RELEASE
cassandra
org.springframework.boot spring-boot-starter-data- 2.3.12.RELEASE
cassandra-reactive
org.springframework.boot spring-boot-starter-data- 2.3.12.RELEASE
couchbase
org.springframework.boot spring-boot-starter-data- 2.3.12.RELEASE
couchbase-reactive
org.springframework.boot spring-boot-starter-data- 2.3.12.RELEASE
elasticsearch
org.springframework.boot spring-boot-starter-data-jdbc 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-data-jpa 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-data-ldap 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-data- 2.3.12.RELEASE
mongodb
org.springframework.boot spring-boot-starter-data- 2.3.12.RELEASE
mongodb-reactive
org.springframework.boot spring-boot-starter-data-neo4j 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-data-r2dbc 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-data-redis 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-data- 2.3.12.RELEASE
redis-reactive
org.springframework.boot spring-boot-starter-data-rest 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-data-solr 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-freemarker 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-groovy- 2.3.12.RELEASE
templates
org.springframework.boot spring-boot-starter-hateoas 2.3.12.RELEASE
org.springframework.boot spring-boot-starter- 2.3.12.RELEASE
integration
org.springframework.boot spring-boot-starter-jdbc 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-jersey 2.3.12.RELEASE
521
Group ID Artifact ID Version
org.springframework.boot spring-boot-starter-jetty 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-jooq 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-json 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-jta- 2.3.12.RELEASE
atomikos
org.springframework.boot spring-boot-starter-jta- 2.3.12.RELEASE
bitronix
org.springframework.boot spring-boot-starter-log4j2 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-logging 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-mail 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-mustache 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-oauth2- 2.3.12.RELEASE
client
org.springframework.boot spring-boot-starter-oauth2- 2.3.12.RELEASE
resource-server
org.springframework.boot spring-boot-starter-quartz 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-reactor- 2.3.12.RELEASE
netty
org.springframework.boot spring-boot-starter-rsocket 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-security 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-test 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-thymeleaf 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-tomcat 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-undertow 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-validation 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-web 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-web- 2.3.12.RELEASE
services
org.springframework.boot spring-boot-starter-webflux 2.3.12.RELEASE
org.springframework.boot spring-boot-starter-websocket 2.3.12.RELEASE
org.springframework.boot spring-boot-test 2.3.12.RELEASE
org.springframework.boot spring-boot-test-autoconfigure 2.3.12.RELEASE
org.springframework.data spring-data-cassandra 3.0.9.RELEASE
org.springframework.data spring-data-commons 2.3.9.RELEASE
org.springframework.data spring-data-couchbase 4.0.9.RELEASE
org.springframework.data spring-data-elasticsearch 4.0.9.RELEASE
org.springframework.data spring-data-envers 2.3.9.RELEASE
org.springframework.data spring-data-gemfire 2.3.9.RELEASE
org.springframework.data spring-data-geode 2.3.9.RELEASE
org.springframework.data spring-data-jdbc 2.0.9.RELEASE
522
Group ID Artifact ID Version
org.springframework.data spring-data-jpa 2.3.9.RELEASE
org.springframework.data spring-data-keyvalue 2.3.9.RELEASE
org.springframework.data spring-data-ldap 2.3.9.RELEASE
org.springframework.data spring-data-mongodb 3.0.9.RELEASE
org.springframework.data spring-data-neo4j 5.3.9.RELEASE
org.springframework.data spring-data-r2dbc 1.1.9.RELEASE
org.springframework.data spring-data-redis 2.3.9.RELEASE
org.springframework.data spring-data-relational 2.0.9.RELEASE
org.springframework.data spring-data-rest-core 3.3.9.RELEASE
org.springframework.data spring-data-rest-hal-browser 3.3.9.RELEASE
org.springframework.data spring-data-rest-hal-explorer 3.3.9.RELEASE
org.springframework.data spring-data-rest-webmvc 3.3.9.RELEASE
org.springframework.data spring-data-solr 4.2.9.RELEASE
org.springframework.hateoas spring-hateoas 1.1.5.RELEASE
org.springframework.integratio spring-integration-amqp 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-core 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-event 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-feed 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-file 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-ftp 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-gemfire 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-groovy 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-http 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-ip 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-jdbc 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-jms 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-jmx 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-jpa 5.3.8.RELEASE
n
523
Group ID Artifact ID Version
org.springframework.integratio spring-integration-mail 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-mongodb 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-mqtt 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-redis 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-rmi 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-rsocket 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-scripting 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-security 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-sftp 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-stomp 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-stream 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-syslog 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-test 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-test- 5.3.8.RELEASE
n support
org.springframework.integratio spring-integration-webflux 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-websocket 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-ws 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-xml 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-xmpp 5.3.8.RELEASE
n
org.springframework.integratio spring-integration-zookeeper 5.3.8.RELEASE
n
org.springframework.kafka spring-kafka 2.5.14.RELEASE
org.springframework.kafka spring-kafka-test 2.5.14.RELEASE
org.springframework.ldap spring-ldap-core 2.3.4.RELEASE
org.springframework.ldap spring-ldap-core-tiger 2.3.4.RELEASE
org.springframework.ldap spring-ldap-ldif-batch 2.3.4.RELEASE
524
Group ID Artifact ID Version
org.springframework.ldap spring-ldap-ldif-core 2.3.4.RELEASE
org.springframework.ldap spring-ldap-odm 2.3.4.RELEASE
org.springframework.ldap spring-ldap-test 2.3.4.RELEASE
org.springframework.restdocs spring-restdocs-asciidoctor 2.0.5.RELEASE
org.springframework.restdocs spring-restdocs-core 2.0.5.RELEASE
org.springframework.restdocs spring-restdocs-mockmvc 2.0.5.RELEASE
org.springframework.restdocs spring-restdocs-restassured 2.0.5.RELEASE
org.springframework.restdocs spring-restdocs-webtestclient 2.0.5.RELEASE
org.springframework.retry spring-retry 1.2.5.RELEASE
org.springframework.security spring-security-acl 5.3.9.RELEASE
org.springframework.security spring-security-aspects 5.3.9.RELEASE
org.springframework.security spring-security-cas 5.3.9.RELEASE
org.springframework.security spring-security-config 5.3.9.RELEASE
org.springframework.security spring-security-core 5.3.9.RELEASE
org.springframework.security spring-security-crypto 5.3.9.RELEASE
org.springframework.security spring-security-data 5.3.9.RELEASE
org.springframework.security spring-security-ldap 5.3.9.RELEASE
org.springframework.security spring-security-messaging 5.3.9.RELEASE
org.springframework.security spring-security-oauth2-client 5.3.9.RELEASE
org.springframework.security spring-security-oauth2-core 5.3.9.RELEASE
org.springframework.security spring-security-oauth2-jose 5.3.9.RELEASE
org.springframework.security spring-security-oauth2- 5.3.9.RELEASE
resource-server
org.springframework.security spring-security-openid 5.3.9.RELEASE
org.springframework.security spring-security-remoting 5.3.9.RELEASE
org.springframework.security spring-security-rsocket 5.3.9.RELEASE
org.springframework.security spring-security-saml2-service- 5.3.9.RELEASE
provider
org.springframework.security spring-security-taglibs 5.3.9.RELEASE
org.springframework.security spring-security-test 5.3.9.RELEASE
org.springframework.security spring-security-web 5.3.9.RELEASE
org.springframework.session spring-session-core 2.3.3.RELEASE
org.springframework.session spring-session-data-geode 2.3.5.RELEASE
org.springframework.session spring-session-data-mongodb 2.3.2.RELEASE
org.springframework.session spring-session-data-redis 2.3.3.RELEASE
org.springframework.session spring-session-hazelcast 2.3.3.RELEASE
org.springframework.session spring-session-jdbc 2.3.3.RELEASE
org.springframework.ws spring-ws-core 3.0.10.RELEASE
org.springframework.ws spring-ws-security 3.0.10.RELEASE
525
Group ID Artifact ID Version
org.springframework.ws spring-ws-support 3.0.10.RELEASE
org.springframework.ws spring-ws-test 3.0.10.RELEASE
org.springframework.ws spring-xml 3.0.10.RELEASE
org.synchronoss.cloud nio-multipart-parser 1.1.0
org.thymeleaf thymeleaf 3.0.12.RELEASE
org.thymeleaf thymeleaf-spring5 3.0.12.RELEASE
org.thymeleaf.extras thymeleaf-extras-java8time 3.0.4.RELEASE
org.thymeleaf.extras thymeleaf-extras- 3.0.4.RELEASE
springsecurity5
org.webjars hal-browser 3325375
org.webjars webjars-locator-core 0.45
org.xerial sqlite-jdbc 3.31.1
org.xmlunit xmlunit-assertj 2.7.0
org.xmlunit xmlunit-core 2.7.0
org.xmlunit xmlunit-legacy 2.7.0
org.xmlunit xmlunit-matchers 2.7.0
org.xmlunit xmlunit-placeholders 2.7.0
org.yaml snakeyaml 1.26
redis.clients jedis 3.3.0
wsdl4j wsdl4j 1.6.3
The following table provides all properties that can be used to override the versions managed by
Spring Boot. Browse the spring-boot-dependencies build.gradle for a complete list of dependencies.
526
Library Version Property
Classmate classmate.version
Commons Codec commons-codec.version
Commons DBCP2 commons-dbcp2.version
Commons Lang3 commons-lang3.version
Commons Pool commons-pool.version
Commons Pool2 commons-pool2.version
Couchbase Client couchbase-client.version
DB2 JDBC db2-jdbc.version
Dependency Management Plugin dependency-management-plugin.version
Derby derby.version
Dropwizard Metrics dropwizard-metrics.version
Ehcache ehcache.version
Ehcache3 ehcache3.version
Elasticsearch elasticsearch.version
Embedded Mongo embedded-mongo.version
Exec Maven Plugin exec-maven-plugin.version
Flatten Maven Plugin flatten-maven-plugin.version
Flyway flyway.version
FreeMarker freemarker.version
Git Commit ID Plugin git-commit-id-plugin.version
Glassfish EL glassfish-el.version
Glassfish JAXB glassfish-jaxb.version
Groovy groovy.version
Gson gson.version
H2 h2.version
Hamcrest hamcrest.version
Hazelcast hazelcast.version
Hazelcast Hibernate5 hazelcast-hibernate5.version
Hibernate hibernate.version
Hibernate Validator hibernate-validator.version
HikariCP hikaricp.version
HSQLDB hsqldb.version
HtmlUnit htmlunit.version
HttpAsyncClient httpasyncclient.version
HttpClient httpclient.version
HttpCore httpcore.version
Infinispan infinispan.version
InfluxDB Java influxdb-java.version
527
Library Version Property
Jackson Bom jackson-bom.version
Jakarta Activation jakarta-activation.version
Jakarta Annotation jakarta-annotation.version
Jakarta JMS jakarta-jms.version
Jakarta Json jakarta-json.version
Jakarta Json Bind jakarta-json-bind.version
Jakarta Mail jakarta-mail.version
Jakarta Persistence jakarta-persistence.version
Jakarta Servlet jakarta-servlet.version
Jakarta Servlet JSP JSTL jakarta-servlet-jsp-jstl.version
Jakarta Transaction jakarta-transaction.version
Jakarta Validation jakarta-validation.version
Jakarta WebSocket jakarta-websocket.version
Jakarta WS RS jakarta-ws-rs.version
Jakarta XML Bind jakarta-xml-bind.version
Jakarta XML SOAP jakarta-xml-soap.version
Jakarta XML WS jakarta-xml-ws.version
Janino janino.version
Javax Activation javax-activation.version
Javax Annotation javax-annotation.version
Javax Cache javax-cache.version
Javax JAXB javax-jaxb.version
Javax JAXWS javax-jaxws.version
Javax JMS javax-jms.version
Javax Json javax-json.version
Javax JsonB javax-jsonb.version
Javax Mail javax-mail.version
Javax Money javax-money.version
Javax Persistence javax-persistence.version
Javax Transaction javax-transaction.version
Javax Validation javax-validation.version
Javax WebSocket javax-websocket.version
Jaxen jaxen.version
Jaybird jaybird.version
JBoss Logging jboss-logging.version
JBoss Transaction SPI jboss-transaction-spi.version
JDOM2 jdom2.version
Jedis jedis.version
528
Library Version Property
Jersey jersey.version
Jetty jetty.version
Jetty EL jetty-el.version
Jetty JSP jetty-jsp.version
Jetty Reactive HTTPClient jetty-reactive-httpclient.version
JMustache jmustache.version
Johnzon johnzon.version
Jolokia jolokia.version
jOOQ jooq.version
Json Path json-path.version
Json-smart json-smart.version
JsonAssert jsonassert.version
JSTL jstl.version
JTDS jtds.version
JUnit junit.version
JUnit Jupiter junit-jupiter.version
Kafka kafka.version
Kotlin kotlin.version
Kotlin Coroutines kotlin-coroutines.version
Lettuce lettuce.version
Liquibase liquibase.version
Log4j2 log4j2.version
Logback logback.version
Lombok lombok.version
MariaDB mariadb.version
Maven AntRun Plugin maven-antrun-plugin.version
Maven Assembly Plugin maven-assembly-plugin.version
Maven Clean Plugin maven-clean-plugin.version
Maven Compiler Plugin maven-compiler-plugin.version
Maven Dependency Plugin maven-dependency-plugin.version
Maven Deploy Plugin maven-deploy-plugin.version
Maven Enforcer Plugin maven-enforcer-plugin.version
Maven Failsafe Plugin maven-failsafe-plugin.version
Maven Help Plugin maven-help-plugin.version
Maven Install Plugin maven-install-plugin.version
Maven Invoker Plugin maven-invoker-plugin.version
Maven Jar Plugin maven-jar-plugin.version
Maven Javadoc Plugin maven-javadoc-plugin.version
529
Library Version Property
Maven Resources Plugin maven-resources-plugin.version
Maven Shade Plugin maven-shade-plugin.version
Maven Source Plugin maven-source-plugin.version
Maven Surefire Plugin maven-surefire-plugin.version
Maven War Plugin maven-war-plugin.version
Micrometer micrometer.version
MIMEPull mimepull.version
Mockito mockito.version
MongoDB mongodb.version
MSSQL JDBC mssql-jdbc.version
MySQL mysql.version
NekoHTML nekohtml.version
Neo4j OGM neo4j-ogm.version
Netty netty.version
Netty tcNative netty-tcnative.version
Nimbus JOSE JWT nimbus-jose-jwt.version
NIO Multipart Parser nio-multipart-parser.version
OAuth2 OIDC SDK oauth2-oidc-sdk.version
OJDBC ojdbc.version
OkHttp3 okhttp3.version
Oracle Database oracle-database.version
Pooled JMS pooled-jms.version
Postgresql postgresql.version
Prometheus PushGateway prometheus-pushgateway.version
Quartz quartz.version
QueryDSL querydsl.version
R2DBC Bom r2dbc-bom.version
Rabbit AMQP Client rabbit-amqp-client.version
Reactive Streams reactive-streams.version
Reactor Bom reactor-bom.version
REST Assured rest-assured.version
RSocket rsocket.version
RxJava rxjava.version
RxJava Adapter rxjava-adapter.version
RxJava2 rxjava2.version
SAAJ Impl saaj-impl.version
Selenium selenium.version
Selenium HtmlUnit selenium-htmlunit.version
530
Library Version Property
SendGrid sendgrid.version
Servlet API servlet-api.version
SLF4J slf4j.version
SnakeYAML snakeyaml.version
Solr solr.version
Spring AMQP spring-amqp.version
Spring Batch spring-batch.version
Spring Data Releasetrain spring-data-releasetrain.version
Spring Framework spring-framework.version
Spring HATEOAS spring-hateoas.version
Spring Integration spring-integration.version
Spring Kafka spring-kafka.version
Spring LDAP spring-ldap.version
Spring RESTDocs spring-restdocs.version
Spring Retry spring-retry.version
Spring Security spring-security.version
Spring Session Bom spring-session-bom.version
Spring WS spring-ws.version
SQLite JDBC sqlite-jdbc.version
Sun Mail sun-mail.version
Thymeleaf thymeleaf.version
Thymeleaf Extras Data Attribute thymeleaf-extras-data-attribute.version
Thymeleaf Extras Java8Time thymeleaf-extras-java8time.version
Thymeleaf Extras SpringSecurity thymeleaf-extras-springsecurity.version
Thymeleaf Layout Dialect thymeleaf-layout-dialect.version
Tomcat tomcat.version
UnboundID LDAPSDK unboundid-ldapsdk.version
Undertow undertow.version
Versions Maven Plugin versions-maven-plugin.version
WebJars HAL Browser webjars-hal-browser.version
WebJars Locator Core webjars-locator-core.version
WSDL4j wsdl4j.version
XML Maven Plugin xml-maven-plugin.version
XmlUnit2 xmlunit2.version
531