spring boot设置多环境的配置文件
目录
- 说明
- 规划
- 步骤
- 案例
- application.yml
- application-dev.yml
- application-test.yml
- application-prod.yml
说明
在项目开发过程中,回有开发环境、测试环境、生产环境等等。如果所有环境的配置都放在application.yml中并且需要打包到不同的环境中时,修改application.yml同一个文件时会出现遗漏,或者是配置错误的情况。
例如不通过环境下的数据库配置、项目启动的端口号等等。
此时我们可以多创建几个不同环境下的配置文件使用,需要让项目在打包时、运行时 自动去识别需要使用的配置文件。
规划
本案例主要规划为开发环境、测试环境、生产环境。为这三个环境创建三个配置文件。如以下表:
环境 | 文件名称 |
---|---|
开发环境 | application-dev.yml |
测试环境 | application-test.yml |
生产环境 | application-prod.yml |
步骤
- 项目创建后,创建配置文件,如下:
- application.yml : springboot项目能识别的配置文件。必须存在。
- application-dev.yml : 自定义的开发环境配置文件。其中主要配置开发环境中使用的配置内容
- application-test.yml :自定义的测试环境配置文件。其中主要配置测试环境中使用的配置内容
- application-prod.yml :自定义的生产环境配置文件。其中主要配置生产环境中使用的配置内容
- 修改项目的pom.xml
在项目的pom.xml中加入以下配置:
<!-- 配置文件管理 -->
<profiles>
<!-- 开发环境使用的配置文件 -->
<profile>
<id>dev</id>
<activation>
<!-- 默认启动时使用开发环境配置启动 -->
<activeByDefault>true</activeByDefault>
</activation>
<properties>
<!--
environment 标签为自定义标签,
dev值与上面的id标签值一致,且与配置文件名称中的 -dev 一致
environment标签的名称会在application.yml 中使用。
-->
<environment>dev</environment>
</properties>
</profile>
<!-- 测试环境使用的配置文件 -->
<profile>
<id>test</id>
<properties>
<environment>test</environment>
</properties>
</profile>
<!-- 生产环境使用的配置文件 -->
<profile>
<id>prod</id>
<properties>
<environment>prod</environment>
</properties>
</profile>
</profiles>
此时idea中的maven中就会出现配置的三个环境的选项。
当我们需要打包或者需要以哪个环境的配置文件启动项目时,再此勾选后运行或者打包项目即可。
3. 在application.yml 配置中新增加以下的配置
spring:
profiles:
# 开始和结尾使用@符号
# environment为pom.xml中步骤2中配置的自定义标签名称。
active: @environment@
案例
application.yml
此配置中可以放三个环境中相同配置的内容
# 项目端口是公共的,即三个环境中配置的端口是一致的,可以放在此配置文件中
server:
port: 8081
spring:
profiles:
# 开始和结尾使用@符号
# environment为pom.xml中步骤2中配置的自定义标签名称。
active: @environment@
application-dev.yml
开发环境下的配置文件
spring:
datasource:
druid:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/zhangDev?characterEncoding=utf8&serverTimezone=Asia/Shanghai&useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true
username: root
password: 123456
application-test.yml
测试环境下的配置文件
spring:
datasource:
druid:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.83.156:3306/zhangTest?characterEncoding=utf8&serverTimezone=Asia/Shanghai&useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true
username: root
password: ajhbie234
application-prod.yml
生产环境下的配置文件
spring:
datasource:
druid:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://xxx.xx.xxx.xxx:3306/usersystem?characterEncoding=utf8&serverTimezone=Asia/Shanghai&useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true
username: userapi
password: ajue@zhang2258