配置文件
配置文件(Profiles)
Spring Profiles 提供了一种方法来隔离应用程序配置的各个部分,并使其仅在某些环境中可用。任何 @Component
,@Configuration
或 @ConfigurationProperties
都可以用 @Profile
标记来限制加载,如下例所示:
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Profile;
@Configuration(proxyBeanMethods = false)
@Profile("production")
public class ProductionConfiguration {
// ...
}
注意:
如果 @ConfigurationProperties
bean 是通过 @EnableConfigurationProperties
而不是自动扫描注册的,则需要在具有 @EnableConfigurationProperty
注释的 @Configuration
类上指定 @Profile
注解。在扫描 @ConfigurationProperties
的情况下,可以在 @ConfigurationProperties
类本身上指定 @Profile
。
可以使用 spring.profiles.active Environment
属性来指定哪些配置文件处于活动状态。可以用本章前面描述的任何方式指定属性。例如,可以将其包含在 application.properties
中,如下例所示:
Properties
spring.profiles.active=dev,hsqldb
Yaml
spring:
profiles:
active: "dev,hsqldb"
也可以在命令行上使用以下开关指定它:--spring.profiles.active=dev,hsqldb
。
如果没有激活配置文件,则启用默认配置文件。默认配置文件的名称是 default
的,可以使用 spring.profile.default Environment
属性对其进行调整,如下例所示:
Properties
spring.profiles.default=none
Yaml
spring:
profiles:
default: "none"
spring.profiles.active
和 spring.profiles.default
只能在非配置文件特定的文档中使用。这意味着它们不能包含在 spring.config.activate.on-profile
激活的特定于配置文件的文件或文档中。
例如,第二个文档配置无效:
Properties
# this document is valid
spring.profiles.active=prod
#---
# this document is invalid
spring.config.activate.on-profile=prod
spring.profiles.active=metrics
Yaml
# this document is valid
spring:
profiles:
active: "prod"
---
# this document is invalid
spring:
config:
activate:
on-profile: "prod"
profiles:
active: "metrics"
1.添加 active 配置文件
spring.profiles.active
属性遵循与其他属性相同的排序规则:PropertySource
优先级最高者获胜。这意味着你可以在 application.properties
中指定活动配置文件,然后使用命令行开关替换它们。
有时,将属性添加到活动配置文件而不是替换它们是很有用的。spring.profiles.include
属性可用于在 spring.profiles.active
属性激活的配置文件之上添加活动配置文件。SpringApplication
入口点还具有用于设置其他概要文件的 Java API。请参阅 SpringApplication 中的 setAdditionalProfiles()
方法。
例如,当运行具有以下属性的应用程序时,即使使用 --spring.profiles.active
开关运行,也会激活通用和本地配置文件:
Properties
spring.profiles.include[0]=common
spring.profiles.include[1]=local
Yaml
spring:
profiles:
include:
- "common"
- "local"
警告:
与 spring.profile.active
类似,spring.profile.include
只能用于非配置文件特定的文档。这意味着它不能包含在 spring.config.activate.on-profile
激活的特定于配置文件的文件或文档中。
如果给定的配置文件处于活动状态,则下一节中介绍的配置文件组也可用于添加活动配置文件。
2.配置文件组
有时,你在应用程序中定义和使用的配置文件过于细粒度,使用起来很麻烦。例如,你可以使用 proddb
和 prodmq
配置文件来独立启用数据库和消息传递功能。
为了帮助实现这一点,Spring Boot 允许你定义配置文件组。配置文件组允许你为相关的配置文件组定义逻辑名称。
例如,我们可以创建一个由 proddb
和 prodmq
配置文件组成的生产组。
Properties
spring.profiles.group.production[0]=proddb
spring.profiles.group.production[1]=prodmq
Yaml
spring:
profiles:
group:
production:
- "proddb"
- "prodmq"
我们的应用程序现在可以使用 --spring.profiles.active=production
启动 production
、proddb
和 prodmq
配置文件。
3.编程设置配置文件
你可以通过在应用程序运行之前调用 SpringApplication.setAdditionalProfiles(…)
以编程方式设置活动配置文件。还可以使用 Spring 的 ConfigurationEnvironment
接口激活配置文件。如下图所示:
4.特定于配置文件的配置文件
application.properties
(或 application.yml
)和通过 @ConfigurationProperties
引用的文件的特定于配置文件的变量都被视为文件并被加载。