Spring配置文件提供了一种方法来隔离应用程序配置的部分,并使其仅在某些环境中可用。任何@Component
或@Configuration
均可以标记为@Profile
,以限制加载时的限制,以下例所示:html
@Configuration @Profile("production") public class ProductionConfiguration { // ... }
你能够使用spring.profiles.active
Environment
属性来指定哪些配置文件是激活的,你能够在本章前面描述的任何方法中指定属性。例如,你能够在application.properties
中包含它,以下例所示:spring
spring.profiles.active=dev,hsqldb
你还能够使用如下开关在命令行上指定它:--spring.profiles.active=dev,hsqldb
。sql
spring.profiles.active
属性与其余属性遵循相同的排序规则:最高的PropertySource
获胜,这意味着你能够在application.properties
中指定激活配置文件,而后使用命令行开关替换它们。编程
有时,将特殊配置文件的属性添加到激活的配置文件中而不是替换它们是有用的,spring.profiles.include
属性可用于无条件地添加激活配置文件,SpringApplication
入口点还有一个Java API用于设置额外的配置文件(也就是说,在spring.profiles.active
属性激活的配置文件之上)。参见SpringApplication中的setAdditionalProfiles()
方法。segmentfault
例如,当使用--spring.profiles.active=prod
开关运行具备如下属性的应用程序时,proddb
和prodmq
配置文件也被激活:api
--- my.property: fromyamlfile --- spring.profiles: prod spring.profiles.include: - proddb - prodmq
请记住能够在YAML文档中定义
spring.profiles
属性,以肯定该文档什么时候包含在配置中,有关更多细节,请参阅
第74.7节“根据环境更改配置”。
你能够在应用程序运行以前经过调用SpringApplication.setAdditionalProfiles(…)
来编程地设置激活配置文件,也能够经过使用Spring的ConfigurableEnvironment
接口来激活配置文件。app
application.properties
(或application.yml
)和经过@ConfigurationProperties
引用的文件的特殊配置文件的变体被视为文件并被加载。有关详细信息,请参阅“第24.4节”“特殊配置文件的属性”spring-boot