Importing properties from an external file in Spring Boot

With earlier versions of Spring Boot, it was cumbersome to import additional properties or yaml files short of using and application.yml. You could use the spring.config.additional-location property, but you needed to set it pretty early and it was quite limited with the types of files that it could deal with.

With Spring Boot 2.4.0 release, you can use the new spring.config.import property directly in your or application.yml files. Let’s see an example application.

We will use the following file:

This file imports another file named with extra properties:

app.title=Learning Spring Boot app.description=Working with properties file

And here is a sample Controller class which references these properties:

package com.example.testrest;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.beans.factory.annotation.Value;
@RestController public class SampleController {
  private String appTitle;
  @Value("${app.description}") private String appDescription;
  @RequestMapping("/hello") public String hello() {
    return "Hello from " + appTitle + " " + appDescription;

This example is available here:

Optional configurations

Config locations specified via spring.config.location and spring.config.import (introduced in the Spring Boot release 2.4.0) will no longer fail silently if the file or folder does not exist. If you want to import a location, but you don’t mind skipping it if it cannot be found, you should now prefix it with optional:

For example:


This configuration file will import an file from /etc/config/ if it exists, and skip it if it does not.

If you want to treat all locations as optional you can set spring.config.on-not-found=ignore in SpringApplication.setDefaultProperties(…​) or with a system/environment variable.

You can even combine spring.config.import declarations with spring.config.activate.on-profile properties. For example, here we load only if the prod profile is active: