java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > SpringBoot Profile多环境配置

SpringBoot中的Profile多环境配置方法

作者:Tony_chenph

这篇文章主要介绍了SpringBoot中的Profile多环境配置,SpringBoot提供了两种多环境配置的方式,分别是使用profile文件进行多环境配置以及使用@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

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

项目结构

到此这篇关于SpringBoot中的Profile多环境配置的文章就介绍到这了,更多相关SpringBoot Profile多环境配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文