spring boot 使用profile来分区配置

来源:互联网 发布:1月8日制造业数据 编辑:程序博客网 时间:2024/05/16 23:59

很多时候,我们项目在开发环境和生成环境的环境配置是不一样的,例如,数据库配置,在开发的时候,我们一般用测试数据库,而在生产环境的时候,我们是用正式的数据,这时候,我们可以利用profile在不同的环境下配置用不同的配置文件或者不同的配置

spring boot允许你通过命名约定按照一定的格式(application-{profile}.properties)来定义多个配置文件,然后通过在application.properyies通过spring.profiles.active来具体激活一个或者多个配置文件,如果没有没有指定任何profile的配置文件的话,spring boot默认会启动application-default.properties。

profile的配置文件可以按照application.properyies的放置位置一样,放于以下四个位置,

  1. 当前目录的 “/config”的子目录下
  2. 当前目录下
  3. classpath根目录的“/config”包下
  4. classpath的根目录下

在这里我们就定义俩个profile文件,application-cus1.properties和application-cus2.properties,并在俩个文件中都分别写上变量cusvar=cus1和cusvar=cus2

这里写图片描述

我们在application.properyies也写上,并把profile切换到application-cus1.properties的配置文件

cusvar=cus3spring.profiles.active=cus1
  • 1
  • 2

可以通过这样子来测试

@RestController@RequestMapping("/task")public class TaskController {    @RequestMapping(value = {"/",""})    public String hellTask(@Value("${cusvar}")String cusvar ){        return "hello task !! myage is " + cusvar;    }}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

在这里可以看到spring.profiles.active激活的profile不同,打印出来的结果也不一样。

除了可以用profile的配置文件来分区配置我们的环境变量,在代码里,我们还可以直接用@Profile注解来进行配置,例如数据库配置,这里我们先定义一个接口

public interface DBConnector {    public void configure();    }
  • 1
  • 2
  • 3

分别定义俩个实现类来实现它

/**  * 测试数据库  */@Component@Profile("testdb")public class TestDBConnector implements DBConnector {    @Override    public void configure() {        System.out.println("testdb");    }}/** * 生产数据库 */@Component@Profile("devdb")public class DevDBConnector implements DBConnector {    @Override    public void configure() {        System.out.println("devdb");    }}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32

通过在配置文件激活具体使用哪个实现类

spring.profiles.active=testdb
  • 1

然后就可以这么用了

@RestController@RequestMapping("/task")public class TaskController {    @Autowired DBConnector connector ;    @RequestMapping(value = {"/",""})    public String hellTask(){        connector.configure(); //最终打印testdb             return "hello task !! myage is " + myage;    }}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

除了spring.profiles.active来激活一个或者多个profile之外,还可以用spring.profiles.include来叠加profile

spring.profiles: testdbspring.profiles.include: proddb,prodmq
  • 1
  • 2

以上就是spring boot用profile的作用

原创粉丝点击