在实际开发中,应用程序通常需要部署到不同的运行环境中如开发环境、测试环境、生产环境等。不同的环境可能使用不同的配置,如果每次部署都去手动修改配置文件,显然是一件非常麻烦的事。因此SpringBoot提供了两种多环境配置的方式,分别是使用profile文件进行多环境配置以及使用@Profile注解进行多环境配置
激活环境配置方式
1、在控制台运行下列命令激活环境配置
java -jar xxx.jar --spring.profiles.active=proflieName
2、在全局配置文件application.properties中配置激活环境属性(常用方式)
spring.profiles.active = proflieName
使用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注解主要作用于类,并通过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")中的输出信息
项目结构