在开发Spring Boot项目中,如果我们想把自己的项目开源到Github仓库,application.yml中的某些配置比如MySQL、Redis的账户密码,还有的就是现在引入AI之后的一些密钥,可能都不太愿意推送到仓库去。
这个时候,可以通过配置多环境来解决,给本地一个专有的配置文件,然后将其添加到.gitignore文件中,这样就有效解决了这个问题。
下面介绍一下 Spring Boot的多环境配置方法:
Spring Boot 支持的多环境配置文件,命名规则为application-{profile}.yml(profile是环境标识,如local/dev/test/prod)。
操作步骤
application.yml(公共配置)
spring:application:name:xxxprofiles:active:local# 激活local环境# springdoc-openapi(所有环境都用这个扫描包,通用)springdoc:group-configs:-group:'default'packages-to-scan:com.xx.xx.controller# knife4j(所有环境都开启,中文界面,通用)knife4j:enable:truesetting:language:zh_cnapplication-local.yml(本地开发专属配置)
# 本地专属:端口、上下文路径server:port:xxxxservlet:context-path:/api# 本地专属的其他配置(比如数据库、日志、Redis等)# spring:# datasource:# url: jdbc:mysql://localhost:3306/xx?useSSL=false&serverTimezone=UTC# username: xx# password: xx# driver-class-name: com.mysql.cj.jdbc.Driver# logging:# level:# com.xx.xx: debug # 本地开发开启debug日志# redis:# host: localhost# port: xxxx通过在application.yml中配置spring.profiles.active激活指定环境,最后的加载顺序就是:
先加载公共配置
application.yml;再加载激活的环境配置
application-local.yml;
这样的话,环境配置中的同名配置项会覆盖公共配置,不同配置项自动合并,实现 “公共 + 专属” 并存。