Spring Profiles 提供了一种隔离应用程序配置的各部分并使之仅在某些环境中可用的方法。可以用@Profile标记任何@Component或@Configuration以限制其加载时间,如以下示例所示:
@Configuration
@Profile("production")
public class ProductionConfiguration {
// ...
}
您可以使用spring.profiles.active Environment属性来指定哪些配置文件处于 Active 状态。您可以通过本章前面介绍的任何方式指定属性。例如,您可以将其包含在application.properties中,如以下示例所示:
spring.profiles.active=dev,hsqldb
spring.profiles.active属性遵循与其他属性相同的排序规则:最高PropertySource获胜。这意味着您可以在application.properties中指定 Active 配置文件,然后使用命令行开关“替换”它们。
有时,将特定于配置文件的属性“添加”到 Active 配置文件而不是替换它们
可以在 YAML 文档中定义spring.profiles属性,以确定何时将该特定文档包括在配置中。spring.profiles.include属性可用于无条件添加 Active 配置文件。 SpringApplication入口点还具有 Java API,用于设置其他配置文件(即,在spring.profiles.active属性激活的配置文件之上)
例如,当使用开关–spring.profiles.active=prod运行具有以下属性的应用程序时,还将激活prod_db和prod_service配置文件:
spring.profiles: prod
spring.profiles.include:
-prod_db
-prod_service
YAML 文件也可以在一个文件中完成所有 profile 的配置, 用‘—’来分割每个profile内容
---
prod
spring:
profiles:
active: prod
也可以同时激活多个 profile
spring.profiles.active: prod,proddb,prodlog
---
dev 配置
spring:
profiles: dev
---
spring:
profiles: qa
略去配置
---
spring.profiles: prod
spring.profiles.include:
-prod_db
-prod_service
---
spring:
profiles: local
---
插件激活 profile
spring-boot:run -Drun.profiles=prod
Java 代码中激活 profile
直接指定环境变量来激活 profile:
System.setProperty("spring.profiles.active", "test");
jar 激活 profile
**JVM 激活profile**
java -jar -Dspring.profiles.active=prod *.jar
在tomcat中加 JAVA_OPTS="-Dspring.profiles.active=dev"