Externalized Configuration with Spring Boot

For externalized configurations, Spring Boot supports file formats such as YAML and the .properties file.

While properties file works with @PropertySource annotation, YAML does not. While we can configure more than one Spring profiles per properties file, we can have any with YAML files.

 

@ConfigurationProperties

The annotation @ConfigurationProperties can turn your application properties into type safe POJOs, and then Spring can do the binding and injection part. You will need to annotate a class with @ConfigurationProperties and define the properties along with setters and getters. Maps and collections can be extended with only a getter, whereas arrays will require a setter. You can either annotate this class with @Component or add this class to the configuration using @EnableConfigurationProperties. Now you can autowire the config class in other components using @Inject annotation.

You can validate your configuration properties using JSR 303 annotations such as @NotNull, @Pattern, @Max, @Min, @Digits etc. @ConfigurationProperties can be used to configure your beans as well as third party beans.

 

Configuration Metadata

Spring Boot jars are shipped with meta-data files that provide details of all supported configuration properties. The files are designed to allow IDE developers to offer contextual help and “code completion” as users are working with application.properties or application.yml files.

You can generate your own configuration meta-data file from items annotated with @ConfigurationProperties by using the spring-boot-configuration-processor jar. Read more here.

Spring boot uses relaxed names for configuration properties. For instance, feature-enabled or FEATURE_ENABLED will be matched to featureEnabled.

 

Order of resolution of configuration options

Spring Boot provides cascading resolution of configuration.

Order of resolution is as follows:

  1. command line arguments (prefix any property with a double dash),  

  2. embedded JSON in SPRING_APPLICATION_JSON environment variable,

  3. StandardServletEnvironment,

    1. StandardServletEnvironment implementation is a hierarchy within itself and looks in following in order:

      1. ServletConfig init parameters,

      2. ServletContext init parameters,

      3. JNDI attributes,

      4. System.getProperties(),

      5. OS environment variables.

  4. RandomValuePropertySource,

  5. application.properties/application.yml (variants),  

    1. In case of application.properties/application.yml variants, first profile specific files (e.g. application-{profile}.properties) and then the generic application.properties/application.yml.

  6. @PropertySource,

  7. Default Properties.

    1. The default properties can be set in the main class using SpringApplication.setDefaultProperties().

References and notes: 

YAML is a human friendly data serialization standard, which is mainly made for configuration files. YAML stands for YAML Ain't Markup Language.

YAML supports Maps, lists and scalar types. YAML is hierarchical and may use consistent spaces to denote hierarchy. It will also support inline maps.

Properties file is mainly used with Java, supports only String types and is non-hierarchical.

In Properties file, we can have maps by denoting hierarchies as dots.

Quick Notes Finder Tags

Activities (1) advanced java (1) agile (3) App Servers (6) archived notes (2) Arrays (1) Best Practices (12) Best Practices (Design) (3) Best Practices (Java) (7) Best Practices (Java EE) (1) BigData (3) Chars & Encodings (6) coding problems (2) Collections (15) contests (3) Core Java (All) (55) course plan (2) Database (12) Design patterns (8) dev tools (3) downloads (2) eclipse (9) Essentials (1) examples (14) Exception (1) Exceptions (4) Exercise (1) exercises (6) Getting Started (18) Groovy (2) hadoop (4) hibernate (77) hibernate interview questions (6) History (1) Hot book (5) http monitoring (2) Inheritance (4) intellij (1) java 8 notes (4) Java 9 (1) Java Concepts (7) Java Core (9) java ee exercises (1) java ee interview questions (2) Java Elements (16) Java Environment (1) Java Features (4) java interview points (4) java interview questions (4) javajee initiatives (1) javajee thoughts (3) Java Performance (6) Java Programmer 1 (11) Java Programmer 2 (7) Javascript Frameworks (1) Java SE Professional (1) JPA 1 - Module (6) JPA 1 - Modules (1) JSP (1) Legacy Java (1) linked list (3) maven (1) Multithreading (16) NFR (1) No SQL (1) Object Oriented (9) OCPJP (4) OCPWCD (1) OOAD (3) Operators (4) Overloading (2) Overriding (2) Overviews (1) policies (1) programming (1) Quartz Scheduler (1) Quizzes (17) RabbitMQ (1) references (2) restful web service (3) Searching (1) security (10) Servlets (8) Servlets and JSP (31) Site Usage Guidelines (1) Sorting (1) source code management (1) spring (4) spring boot (3) Spring Examples (1) Spring Features (1) spring jpa (1) Stack (1) Streams & IO (3) Strings (11) SW Developer Tools (2) testing (1) troubleshooting (1) user interface (1) vxml (8) web services (1) Web Technologies (1) Web Technology Books (1) youtube (1)