SpringBoot中的Profile多环境配置方法
Tony_chenph 人气:0Profile多环境配置
在实际开发中,应用程序通常需要部署到不同的运行环境中如开发环境、测试环境、生产环境等。不同的环境可能使用不同的配置,如果每次部署都去手动修改配置文件,显然是一件非常麻烦的事。因此SpringBoot提供了两种多环境配置的方式,分别是使用profile文件进行多环境配置以及使用@Profile注解进行多环境配置
激活环境配置方式
1、在控制台运行下列命令激活环境配置
java -jar xxx.jar --spring.profiles.active=proflieName
2、在全局配置文件application.properties中配置激活环境属性(常用方式)
spring.profiles.active = proflieName
一、使用profile文件进行多环境配置
使用profile文件进行多环境配置时,该配置文件名需要满足application-{profile}.properties的格式,如下所示
application-{dev}.properties //开发环境配置文件
application-{test}.properties //测试环境配置文件
application-{prod}.properties //生产环境配置文件
1、在resource目录下分别创建application-dev.properties、application-test.properties、application-prod.properties多环境文件,并在各个配置文件中对服务端口进行不同的设置,示例如下
application-dev.properties --->server.port=8081
application-test.properties --->server.port=8082
application-prod.properties --->server.port=8083
2、在application.properties中指定要激活的多环境配置文件
#指定要激活的profiles多环境配置为dev的配置 spring.profiles.active=dev #指定要激活的profiles多环境配置为test的配置 #spring.profiles.active=test #指定要激活的profiles多环境配置为prod的配置 #spring.profiles.active=prod
3、启动SpringBoot启动类
从运行结果中可以看到,Tomcat已经被修改为我们在application-dev.properties中配置的8081(默认为8080)
二、使用@Profile注解进行多环境配置
@Profile注解主要作用于类,并通过value属性指定配置环境,等同于Profile文件application-{profile}.properties名称中的profile值,使用@Profile注解配置文件同样需要在全局文件中激活
与@Configuration搭配使用
1、在config包下创建datasource包,在该包下创建一个接口DBConnector
package com.chen.config.datasource; public interface DBConnector { public void dataConfig(); }
2、在detasource包下创建impl包,用于管理DBConnector的实现类
在该包下创建三个实现类分别DevDBConnector,TestDBConnector,ProdDBConnector
package com.chen.config.datasource.impl; import com.chen.config.datasource.DBConnector; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Profile; @Configuration// 表明当前类为一个配置类,保证SpringBoot可以自动扫描并识别 @Profile("dev")//指定多环境配置类标识 public class DevDBConnector implements DBConnector { @Override public void dataConfig() { System.out.println("开发环境"); } }
package com.chen.config.datasource.impl; import com.chen.config.datasource.DBConnector; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Profile; @Configuration// 表明当前类为一个配置类,保证SpringBoot可以自动扫描并识别 @Profile("test")//指定多环境配置类标识 public class TestDBConnector implements DBConnector { @Override public void dataConfig() { System.out.println("测试环境"); } }
package com.chen.config.datasource.impl; import com.chen.config.datasource.DBConnector; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Profile; @Configuration// 表明当前类为一个配置类,保证SpringBoot可以自动扫描并识别 @Profile("prod")//指定多环境配置类标识 public class ProdDBConnector implements DBConnector { @Override public void dataConfig() { System.out.println("生产环境"); } }
3、在application.properties中指定要激活的多环境配置文件
#指定要激活的profiles多环境配置为dev的配置 spring.profiles.active=dev #指定要激活的profiles多环境配置为test的配置 #spring.profiles.active=test #指定要激活的profiles多环境配置为prod的配置 #spring.profiles.active=prod
4、编写测试类
import com.chen.config.datasource.DBConnector; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; @RunWith(SpringRunner.class) @SpringBootTest public class datasourceTest { @Autowired private DBConnector dbConnector; @Test public void testDataSource(){ dbConnector.dataConfig(); } }
5、运行测试类
可以看到启动端口好为Profile文件配置的dev中8081
也调用了@Profile("dev")中的输出信息
项目结构
加载全部内容