SpringBoot学习之路(五)——Profile多环境配置

Profile多环境配置

      在实际开发中,应用程序通常需要部署到不同的运行环境中如开发环境、测试环境、生产环境等。不同的环境可能使用不同的配置,如果每次部署都去手动修改配置文件,显然是一件非常麻烦的事。因此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

SpringBoot学习之路(五)——Profile多环境配置_第1张图片

也调用了@Profile("dev")中的输出信息

项目结构

SpringBoot学习之路(五)——Profile多环境配置_第2张图片

 

你可能感兴趣的:(SpringBoot,spring,boot,maven,java)