SpringBoot 多环境配置文件切换
背景
很多时候,我们项目在开发环境和生成环境的环境配置是不一样的,例如,数据库配置,在开发的时候,我们一般用测试数据库,而在生产环境的时候,我们是用正式的数据,这时候,我们可以利用profile在不同的环境下配置用不同的配置文件或者不同的配置。
解决方案
spring boot允许你通过命名约定按照一定的格式(application-{profile}.properties)来定义多个配置文件,然后通过在application.properyies通过spring.profiles.active来具体激活一个或者多个配置文件,如果没有没有指定任何profile的配置文件的话,spring boot默认会启动application-default.properties。
一、新建配置文件
注:配置文件优先级(由高到低):
bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml
此处使用.yml文件格式,在src/main/resources下新建如下文件

application.yml (主配置)
server:
port: 9990 spring:
profiles:
active: dev #选定配置 #自定义默认值
curvar:
context: default.curvar
application-pro.yml (开发配置)
#模拟开发配置
curvar:
context: "开发配置变量"
application-pro.yml(生产配置)
#模拟生产配置
curvar:
context: "生产配置变量"
二、 服务调用测试
2.1 新建调用类
@Slf4j
@RestController
public class IndexController { @Value("${curvar.context}")
private String cusvar; /**
* .
* 使用哪一个配置
*
* @return
*/
@RequestMapping("/test")
public String test() {
log.debug("使用:[{}]", cusvar);
return "使用配置: " + cusvar;
} }
2.2 使用样例项目
打开浏览器输入:http://localhost:9990/test


三、扩展练习
3.1 使用注解标记配置,首先定义一个接口
public interface Connector {
String configure();
}
3.2 分别定义俩个实现类来实现它
import org.springframework.context.annotation.Profile;
import org.springframework.stereotype.Component; @Component
@Profile("pro-db")//标记文件,环境切换
public class ProConnector implements Connector { @Override
public String configure() {
return "pro生产标记文件...";
}
}
import org.springframework.context.annotation.Profile;
import org.springframework.stereotype.Component; @Component
@Profile("dev-db")//标记文件,环境切换
public class DevConnector implements Connector { @Override
public String configure() {
return "dev开发标记文件...";
}
}
3.3 修改application.yml文件激活配置
spring:
profiles:
#active: dev #选定配置
active: pro-db #选定配置激活标记文件
3.4 新增查询方法
@Autowired
private Connector connector; //注入 /**
* .
* 使用哪一个被标记文件
*
* @return
*/
@GetMapping("/proFile")
public String proFile() {
log.debug("使用配置文件:[{}]", connector.configure());
return connector.configure();
}
打开浏览器输入:http://localhost:9990/proFile

3.5 使用一个或多个配置文件及激活标记文件
3.5.1 修改application.yml文件,进行属性叠加
spring:
profiles:
include: pro,dev-db #指定配置文件及激活标记文件
#active: pro-db #选定标记文件
3.5.2 新增查询方法
/**
* .
* 使用哪一个配置文件及标记文件
*
* @return
*/
@GetMapping("/include")
public String include() {
return String.format("使用配置文件:%s,使用标记文件:%s", cusvar, connector.configure());
}
打开浏览器输入:http://localhost:9990/include

3.6 切换日志文件
3.6.1 新建logback文件

logback-pro.yml (生产日志)
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
<contextName>logback</contextName> <!--定义文件名及存储路径-->
<property name="log.path" value="./pro.log"/>
<!-- ConsoleAppender:控制台设置 -->
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>debug</level>
</filter>
<encoder>
<pattern>%d{HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} [%file : %line] - %msg%n
</pattern>
</encoder>
</appender>
<!--RollingFileAppender:滚动记录文件,先将日志记录到指定文件-->
<appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.path}</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${log.path}.%d{yyyy-MM-dd}.%i.gz</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>100MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<!-- 每产生一个日志文件,该日志文件的保存期限为7天 -->
<maxHistory>7</maxHistory>
</rollingPolicy> <encoder>
<pattern>%date %level [%thread] %logger{36} [%file : %line] %msg%n
</pattern>
</encoder>
</appender> <!--将上述name名称:console:标签名称为debug-->
<root level="debug">
<appender-ref ref="console"/>
</root>
<!--将上述name名称:file:标签名称为info-->
<root level="info">
<appender-ref ref="file"/>
</root>
<logger name="org.springframework.scheduling" level="error"/>
<Logger name="org.apache.catalina.util.LifecycleBase" level="error"/>
<Logger name="org.apache.coyote.http11.Http11NioProtocol" level="warn"/>
<Logger name="org.apache.tomcat.util.net.NioSelectorPool" level="warn"/>
<Logger name="org.springframework" level="info"/>
<Logger name="org.freeswitch.esl" level="warn"/>
<logger name="java.sql" level="error"/>
<logger name="org.mybatis" level="info"/><!--mybatis的日志级别为info-->
<logger name="com.example" level="debug"/><!--com.hy包下的日志级别为debug-->
</configuration>
3.6.2 修改application.yml文件,配置日志属性
spring:
profiles:
#include: pro,dev-db #指定配置文件及激活标记文件
#active: pro-db #选定标记文件
active: pro #指定配置文件 #日志
logging:
config: classpath:logback-${spring.profiles.active}.xml #本地IDEA启动配置
#config: config/logback-${spring.profiles.active}.xml # java -jar 包启动配置
项目启动访问接口,控制台打印日志

友情提示:jar运行指定配置
java -jar xxx.jar --spring.profiles.active=dev #指定dev配置 java -jar xxx.jar --server.port=9090 #指定启动端口
SpringBoot 多环境配置文件切换的更多相关文章
- spring-boot多环境配置文件
spring-boot多环境配置文件 目录 配置 多环境配置文件名称要遵循格式 application-{profile}.yml application.yml spring: profiles: ...
- spring 笔记3: Spring 多环境配置文件切换
使用Spring进行开发时,需要面对不同的运行环境,比如开发环境.测试环境.生产环境等.大多时候不同的环境需要不同的配置文件.网上很多资料都是使用Spring的Bean definition prof ...
- springboot多环境配置文件
一.关于springboot的配置文件 springboot的配置文件主要有两种:properties文件和yml文件,我们只要选择一种使用就可以了.我们通过properties文件介绍一下配置的方式 ...
- SpringBoot(二): SpringBoot属性配置文件 SpringBoot多环境配置文件 SpringBoot自定义配置文件
1.属性配置文件 一共分为两种,一种是键值对的properties属性配置文件,一种是yaml格式的配置文件 properties配置: 2.多环境配置文件 当我们的项目中有多套配置文件 比如开发的配 ...
- 「快学springboot」SpringBoot多环境配置文件
前言 我们都知道springboot的配置卸载application.properties配置文件上(或者application.yml).但是,如果想要把不同的环境(如开发环境,测试环境,生产环境) ...
- springboot 不同环境切换不同的配置文件
开发的流程是本地>测试>预发布>正式,所以不同的环境,肯定是不同的配置文件,所以我们需要针对不同的环境做不同的配置切换. 下面我们来说说 springboot 是怎么来切换的: 1. ...
- springboot笔记05——profile多环境配置切换
前言 一个应用程序从开发到上线,往往需要经历几个阶段,例如开发.测试.上线.每个阶段所用到的环境的配置可能都是不一样的,Springboot 应用可以很方便地在各个环境中对配置进行切换.所以,今天主要 ...
- SpringProfile轻松切换多环境配置文件
在项目开发的过程中,我们难免会遇到开发.测试.生产等环境的切换,而各个环境的配置肯定是不同的.传统的办法是在项目打包的时候修改配置文件.但人为做的事情难免产生意外.Spring 为我们提供了一种多环境 ...
- springBoot 多配置文件切换之profile
说明: 我们平时工作,有开发环境,和生产环境,利用springboot的多profile配置,可以很轻松切换配置. 实现方式1(推荐): 配置文件命名遵循:application-{开发模式}.pro ...
随机推荐
- 菜鸟到大神之多图预警——从 RAID 到分布式系统中的副本分布
我们知道,在面对大规模数据的计算和存储时,有两种处理思路: 垂直扩展(scale up):通过升级单机的硬件,如 CPU.内存.磁盘等,提高计算机的处理能力. 水平扩展(scale out):通过添加 ...
- ASP.NET Core 6框架揭秘实例演示[12]:诊断跟踪的进阶用法
一个好的程序员能够在系统出现问题之后马上定位错误的根源并找到正确的解决方案,一个更好的程序员能够根据当前的运行状态预知未来可能发生的问题,并将问题扼杀在摇篮中.诊断跟踪能够帮助我们有效地纠错和排错&l ...
- 报表工具和BI商业智能的区别,你真的弄清楚了吗?
许多人在投身大数据行业的时候,肯定会听到的两个词就是"报表工具"和"BI商业智能".但是大部分人并不太清楚这两者之间的概念和区别,认为报表就是BI,BI就是报表 ...
- 命名空间 namespace
命名空间是一块程序员可以自己命名的内存区域,用于解决同名冲突的问题. 举例来说,某班及内有三个张三,分别坐在班级的第一排.第三排和最后一排.当老师喊张三时,三个张三都站起来应答,这就是同名冲突 ...
- C#如何在安全的上下文中使用不安全的代码?
文章原文:https://www.cnblogs.com/2Yous/p/4887904.html 从通常情况下来看,为了保持类型安全,默认情况C# 不支持指针算法. 不过,当你需要使用指针的时候,请 ...
- 二叉树的N中遍历方式和拓展应用
(一)创建二叉树,如下图所示,一个标准的二叉树是所有位于根节点的左侧的子节点都是比根节点小的,右侧则都是大于根节点的. public class BinaryNode { public int val ...
- 给bootstrap-table填坑
由于设计变更,需要把数据由分页展示改为全部展示(才3500条数据),结果chrome浏览器页面卡顿,火狐浏览器直接卡死! console.time分析之后,竟然是bootstrap-table插件的坑 ...
- Bash初识与常用命令
转至:https://www.cnblogs.com/baishou/p/13850258.html Shell介绍 Shell在中文的意思是壳,寓意是操作系统的壳.Shell是指一种应用程序,这个应 ...
- cannot send list of active checks to "127.0.0.1": host [Zabbix server] not monitored
查看错误日志: /etc/log/zabbix/zabbix_server.log 3148:20210404:233938.363 cannot send list of active check ...
- JZ-020-包含 min 函数的栈
包含 min 函数的栈 题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)). 题目链接: 包含 min 函数的栈 代码 import jav ...