`
y806839048
  • 浏览: 1091398 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

springboot 不同环境不同的配置

阅读更多

前言

     我们在开发Spring Boot应用时,通常同一套程序会被应用和安装到几个不同的环境,比如:开发、测试、生产等。其中每个环境的数据库地址、服务器端口等等配置都会不同,如果在为不同环境打包时都要频繁修改配置文件的话,那必将是个非常繁琐且容易发生错误的事。

      对于多环境的配置,各种项目构建工具或是框架的基本思路是一致的,通过配置多份不同环境的配置文件,再通过打包命令指定需要打包的内容之后进行区分打包,Spring Boot也不例外,或者说更加简单。

 

 

摘要:

配置类区分环境

springboot用注解@configuration生成配置的时候如果需要区别环境用@profile(""),如果是常规项目用xml配置单的话是通过文件的路径区别(在pom.xml定好profile值和路径的关系),可以同时用这两套

另:

在pom.xml中区别的是不同的环境用不同的文件夹中的文件

 

在properties中设置的是此文件夹中又根据文件的-dev这种特征区别include不同的子属性文件,但是只对这个文件中application-{profile}.properties这种命名规则的选择有效,其他命名的属性文件是全部累加加载

spring.properfile.actives=dev;

 

属性文件区分环境

1,不同的文件命名格式

   application-dev.properties:开发环境

 

   application-test.properties:测试环境

 

   application-prod.properties:生产环境

 

2, application.properties中设置spring.profiles.active=dev  就是用dev的意思

   或者打包的时候配置java -jar xxx.jar --spring.profiles.active=test

1. springboot多环境配置

在Spring Boot中多环境配置文件名需要满足application-{profile}.properties的格式,其中{profile}对应你的环境标识,比如:

   application-dev.properties:开发环境

   application-test.properties:测试环境

   application-prod.properties:生产环境

 至于哪个具体的配置文件会被加载,需要在application.properties文件中通过spring.profiles.active属性来设置,其值对应{profile}值。

如:spring.profiles.active=test就会加载application-test.properties配置文件内容

 

2.样例

 

针对各环境新建不同的配置文件application-dev.propertiesapplication-test.propertiesapplication-prod.properties

       在这三个文件均都设置不同的server.port属性,如:dev环境设置为8080,test环境设置为9090,prod环境设置为80

       application.properties中设置spring.profiles.active=dev,就是说默认以dev环境设置

  

测试不同配置的加载:

       执行java -jar xxx.jar,可以观察到服务端口被设置为8080,也就是默认的开发环境(dev)

 

       执行java -jar xxx.jar --spring.profiles.active=test,可以观察到服务端口被设置为9090,也就是测试环境的配置(test)

 

       执行java -jar xxx.jar --spring.profiles.active=prod,可以观察到服务端口被设置为80,也就是生产环境的配置(prod)

 

3.总结

   application.properties中配置通用内容,并设置spring.profiles.active=dev,以开发环境为默认配置

   application-{profile}.properties中配置各个环境不同的内容

   通过命令行方式去激活不同环境的配置。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics