zoukankan      html  css  js  c++  java
  • 第十四章 springboot + profile(不同环境读取不同配置)

    具体做法:

    • 不同环境的配置设置一个配置文件,例如:dev环境下的配置配置在application-dev.properties中;prod环境下的配置配置在application-prod.properties中。
    • 在application.properties中指定使用哪一个文件

    1、application-dev.properties(dev环境下的配置)

    1 profile = dev_envrimont
    View Code

    2、application-prod.properties(prod环境下的配置)

    1 profile = prod_envrimont
    View Code

    3、application.properties

    1 spring.data.mongodb.uri=mongodb://192.168.22.110:27017/myfirstMongodb
    2 
    3 #spring.profiles.active
    4 spring.profiles.active=dev
    View Code

    说明:上边的配置表示使用dev环境下的配置。

    注意:spring.data.mongodb.uri=mongodb://192.168.22.110:27017/myfirstMongodb该配置是application-dev.properties没有的配置

    4、Controller

    1     @Autowired
    2     private Environment env;
    3         
    4     @RequestMapping("/testProfile")
    5     public String testProfile(){
    6         return env.getProperty("profile");
    7     }
    View Code

    测试

    • 上述代码执行后的结果是:dev_envrimont和mongodb://192.168.22.110:27017/myfirstMongodb
    • 如果application.properties的配置改为:spring.profiles.active=prod,则结果是:prod_envrimont
    • 如果application.properties的配置改为:spring.profiles.active=prod,而application.properties中也配置了profile=xxx(不管该配置配置在spring.profiles.active=prod的上方还是下方),这个时候结果是:prod_envrimont
    • 如果application.properties的配置改为:spring.profiles.active=prod,而application.properties中也配置了profile=xxx(不管该配置配置在spring.profiles.active=prod的上方还是下方),但是application-prod.properties删掉了profile = prod_envrimont,这个时候结果是:xxx

    结论:

    • 各个环境公共的配置写在application.properties中
    • 各个模块独有的配置配置在自己的application-{xxx}.properties文件中
    • 程序读取的时候优先读取application.properties中选中的profile的配置,若读不到才会从application.properties去读
  • 相关阅读:
    Megcup 2017 决赛第一题 规则
    折正方体-------------给你出道题
    论公平
    Vue 将一个组件嵌入到另一个组件中
    Vue下的index.html
    Vue下的package.json
    Vue 一些用法
    chkconfig 系统服务管理
    Windows和Linux下的 telnet命令 不是内部或外部命令的解决方案
    JSONPlaceholder
  • 原文地址:https://www.cnblogs.com/java-zhao/p/5469183.html
Copyright © 2011-2022 走看看