Spring Boot
Spring Boot is an extension of the Spring framework that simplifies the initial configuration of Spring applications. It enables you to quickly create a working standalone Spring application with minimum default configuration.
Spring Initializr is a web application that can generate a Spring Boot project. You can select the necessary configuration, including the build tool, language, version of the Spring Boot framework, and any dependencies for your project. IntelliJ IDEA provides the Spring Initializr project wizard that integrates with the Spring Initializr API to generate and import your project directly from the IDE.
In the main menu, go to File | New | Project.
In the left pane of the New Project wizard, select Spring Boot.
Go through the steps of the Spring Boot project wizard.
For an example, refer to Tutorial: Create your first Spring application.
Spring Initializr generates a valid project structure with the following files:
A build configuration file, for example, build.gradle for Gradle or pom.xml for Maven.
A class with the
main()
method to bootstrap the application.An empty JUnit test class.
An empty Spring application configuration file: application.properties
When you create a new Spring Boot project with IntelliJ IDEA, you can add starters in the dedicated new project wizard. You can also add them to existing projects using Add Starters inlay hints in your build files.
Open your pom.xml or build.gradle(.kts) file.
In the
dependencies
block, click Add Starters.In the Add Starters dialog that opens, select starters that you want to add.
Your build file will be modified accordingly. When you add dependencies this way, IntelliJ IDEA considers your Spring Boot version, saving you from the need to worry about compatible dependency versions.
You can disable and enable this inlay hint in the IDE settings (CtrlAlt0S), in Editor | Inlay Hints | Other, under Groovy, Kotlin, and XML.
By default, IntelliJ IDEA applies code formatting to the generated files. If you want the files to remain formatted as they are generated by Spring Initializr, open the IDE settings with CtrlAlt0S, select Languages & Frameworks | Spring | Spring Initializr and disable the Reformat code when creating a new project option.
Open the class with the
main()
method (it is usually also designated with the@SpringBootApplication
annotation), click in the gutter, and select to run the class.Alternatively, you can press CtrlShiftF10 with the class file open in the editor.
IntelliJ IDEA creates and executes the Spring Boot run configuration. For more information, refer to Spring Boot run configuration.
By default, for Spring Boot Gradle-based applications, IntelliJ IDEA uses Gradle to build the project and IntelliJ IDEA to run it. You can configure the IDE to use Gradle instead of IntelliJ IDEA to run Spring Boot applications.
Go to the Advanced Settings settings page CtrlAlt0S.
Under Frameworks. Spring Boot select Run using Gradle.
The Run using Gradle checkbox has no effect if IntelliJ IDEA is selected in Build, Execution, Deployment | Build Tools | Gradle | Build and run using. In this case, IntelliJ IDEA will be used to both build and run your Spring Boot application.
tip
The value of Advanced Settings | Run using Gradle is an IDE-level setting while settings under Build, Execution, Deployment | Build Tools | Gradle can be configured for each project individually.
Spring Initializr creates one default configuration file that may not always be sufficient for development. If you do not want to use the default configuration file, or if you want to run your code in different environments, you can use custom configuration files defined in your project.
Let IntelliJ IDEA know which files are configuration files in your project to enable relevant highlighting and coding assistance:
In the main menu, go to File | Project Structure or press CtrlAltShift0S to open the Project Structure dialog.
Add the Spring facet: from the left-hand list, select Facets, click , and select Spring.
In the right-hand section, select Configuration Files and click (Customize Spring Boot) in the toolbar.
If you want to use a custom configuration file instead of the default one, type its name in the
spring.config.name
field.If you want to use multiple configuration files, click and select files from the project tree.
Valid configuration files are marked with .
Click OK and apply the changes.
note
Some custom configuration files are detected automatically. For example, profile-specific configuration files with names that match the current naming pattern will be added to the context.
Spring Boot includes additional features for monitoring and managing the state of your application in the production environment through HTTP endpoints or with Java Management Extensions (JMX). For more information, refer to Spring Boot Actuator: Production-ready Features.
In your pom.xml or build.gradle file, click the Add Starters inlay hint next to the
dependencies
list.Alternatively, press AltInsert anywhere in the file and select Add Starters.
In the window that opens, select Spring Boot Actuator.
Or you can add the spring-boot-starter-actuator
dependency manually:
Open the pom.xml file and add the following dependency under dependencies
:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
Open the build.gradle file and add the following dependency under dependencies
:
implementation 'org.springframework.boot:spring-boot-starter-actuator'
Open the build.gradle.kts file and add the following dependency under dependencies
:
implementation("org.springframework.boot:spring-boot-starter-actuator")
When you run your application with this dependency, you will be able to access the exposed actuator endpoints via HTTP. For example, if the application is running on localhost port number 8080, the default URL for the health
endpoint will be http://localhost:8080/actuator/health.
Run your Spring Boot application and open the Services tool window: select View | Tool Windows | Services or press Alt08.
Select your running Spring Boot application and open the Actuator tab.
note
If the Spring Boot run configurations are not available in the Services tool window, either add them or use the Run or Debug tool window.
You can use tabs to view endpoints of the following types: runtime beans, health information, and request mappings.
The Beans tab under Actuator shows the runtime beans of your Spring Boot application. Double-click any bean to open its declaration in the editor. These beans are indicated using the icon in the gutter. Click this icon to view dependent and injected beans.
The Beans tab includes the following toolbar actions:
Action | Description |
---|---|
Refresh | Refresh the runtime beans information collected by the JMX agent. |
Diagram Mode | Show the complete graph for all your runtime beans instead of a list. Required plugin: Diagrams (bundled). |
Show Library Beans | Show beans from libraries. |
Show Contexts | Show available Spring application contexts. |
Show Configuration Files | Show available configuration files. |
Show Bean Documentation | Show the documentation for the selected bean. |
Show Bean Graph | Show the direct dependencies for the selected bean. Required plugin: Diagrams (bundled). |
The Health tab under Actuator shows the status of your application. There are some auto-configured health indicators and you can also write custom health indicators.
For more information, refer to Health.
The Mappings tab under Actuator shows the request mappings of your application. It lists all methods with the @RequestMapping
annotation or its shortcuts, such as @GetMapping
.
If you click the path mapping URI, you can select to run the corresponding HTTP request, open an HTTP requests file with the request, or open the request URL in the web browser (if it's a GET
request). For more information, refer to HTTP Client.
Double-click a method to open its declaration in the editor. Spring registers such methods as handlers and IntelliJ IDEA indicates them with the icon in the gutter. Click this icon to run the corresponding HTTP request, open it in a requests files, or in the web browser (if it's a GET
request).
The Mappings tab includes the following toolbar actions:
Action | Description |
---|---|
Refresh | Refresh the request mappings collected by the JMX agent. |
Open in Browser | Open the root application URL in a web browser. |
Request Method | Select which request methods to show. |
Show Library Mappings | Show request mappings from libraries. |
With the spring-boot-devtools
module, your application will restart every time files on the classpath change. If IntelliJ IDEA is configured to continuously compile changed files, you can set a trigger file. In this case, your application will restart only after you modify the trigger file. For more information, refer to Automatic Restart.
Add the
spring-boot-devtools
module dependency for your project.MavenGradleOpen the pom.xml file and add the following dependency under
dependencies
:<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional> </dependency>
Setting the
spring-boot-devtools
dependency asoptional
prevents it from being used in other modules that use your project.Open the build.gradle file and add the following dependency under
dependencies
:developmentOnly("org.springframework.boot:spring-boot-devtools")
Setting the
spring-boot-devtools
dependency asdevelopmentOnly
prevents it from being used in other modules that use your project.
To update a running application, go to Run | Debugging Actions | Update Running Application CtrlF10 in the main menu, or select your application in the Services tool window and click . Depending on your needs, you can configure what the IDE will do when you execute this action.
note
If the Spring Boot run configurations are not available in the Services tool window, either add them or use the Run or Debug tool window.
In the main menu, go to Run | Edit Configurations.
Select the necessary Spring Boot run configuration to open its settings. Click Modify options.
In the list that opens, point to On 'Update' action. You can choose to update only the resources, update both the classes and the resources (build your application), update the trigger file (which will trigger a restart), or try to perform a class hot swap, and if it fails, update the trigger file.
note
For the Update trigger file and the Hot swap classes and update trigger file if failed policies, the IDE sets a trigger file when you start the application.
In the Modify options list, point to On frame deactivation and select an action that the IDE will do after you switch to another application: update the resources, or build your application.
tip
You can create several Spring Boot run/debug configurations with different update policies and switch between them.
Thanks for your feedback!