• spring boot 使用profile来分区配置


    很多时候,我们项目在开发环境和生成环境的环境配置是不一样的,例如,数据库配置,在开发的时候,我们一般用测试数据库,而在生产环境的时候,我们是用正式的数据,这时候,我们可以利用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=cus3
    spring.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: testdb
    spring.profiles.include: proddb,prodmq
    • 1
    • 2

    以上就是spring boot用profile的作用

  • 相关阅读:
    JDBC批处理数据
    JSP+Servlet 无数据库模拟登录过程
    idea常用插件
    如何破解IntelliJ IDEA2018教程
    java在线工具
    mysql快捷修改密码
    jdk1.8新特性
    java基础感觉白学了
    论JDK源码的重要性:一道面试题引发的无限思考
    数组算法经典实例
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13317670.html
Copyright © 2020-2023  润新知