码迷,mamicode.com
首页 > 编程语言 > 详细

spring cloud实战与思考(一) spring config全局配置方案设计

时间:2018-05-17 18:52:25      阅读:174      评论:0      收藏:0      [点我收藏+]

标签:集中管理   期望   file   第一个   解决   修改   inf   其他   工具   

  “spring cloud”的配置中心工具“spring cloud config”提供了分布式系统配置文件集中管理解决方案。该工具功能强大,实现也很简单。网上可以搜索到很多开发教程和用例。本文并不是分享“spring cloud config”的开发方法,而是想聊一聊它的使用。

  任何一个工具不管多么强大和便利,如果用的不好,也达不到期望的效果。拿到“spring cloud config”后,我期望基于这个工具构建的配置文件管理系统能够实现:

  1. 微服务中各个实例的配置项都集中在配置中心。运维人员无需逐一链接到各个分布式节点,能够在配置中心完成微服务实例所有配置项的修改。
  2. 配置项信息源要单一。同一个配置项不会出现在两个源中。以免两个源中同一个配置项数值不一致,导致业务逻辑混乱。

  通常在网上看到的“spring cloud config”实例中,“config client”的本地配置文件“bootstrap.properties”如下:

   技术分享图片

  文件中微服务端口号8001”和实例名称“booking-server”配置项其实是有可能改动的。例如增减微服务实例、端口号已占用、新增微服务类型等场景。所以将它们放到本地配置文件中无法满足第一个需求。此外为了满足第二个需求,需要将配置项按照使用范围进行分类,分别放入不同的配置文件中:

  1) 所有微服务实例共享的配置项,例如common.properties

  2) 同类微服务实例共享的配置项,例如booking-common.properties

  3) 特定微服务实例独享的配置项,例如booking-server-a.properties、booking-server-b.properties

  这就要求微服务实例能够加载多个远端的配置文件。而上面这种配置方式是使用微服务名称“booking-server”映射到配置中心的“booking-server-dev.properties”配置文件。限制了加载的配置文件数量和名称。无法满足第二个需求。

  现在以booking微服务dev版本为例,修改上面的配置文件:

  1. 微服务端口号“server.port”是实例独享的配置项,将“server.port”放入“booking-server-a.properties”配置文件中。
  2. 微服务名称“spring.application.name”是booking类服务各个实例共享的配置项,将“spring.application.name”放入“booking-common.properties”配置文件中。
  3. 服务注册中心地址配置项“eureka.client.serviceUrl.deaultZone”只能保留在本地配置文件中。
  4. 配置中心微服务名称“spring.cloud.config.discovery.service-id”只能保留在本地配置文件中。
  5. 将微服务booking与其他微服务共享的配置项放入“common.properties”配置文件中。
  6. 使用“spring.cloud.config.name”配置项同时加载“common.properties”、“booking-common.properties”和“booking-server-a.properties”配置文件。

  修改后的配置文件如下:

  common-dev.properties配置文件:

   技术分享图片

  booking-common-dev.properties配置文件:

   技术分享图片

  booking-server-a-dev.properties配置文件:

        技术分享图片

  "booking-server-a"本地“bootstrap.properties”配置文件:

      技术分享图片

  现在“booking”微服务实例a的本地配置文件已经得到精简,只保留了必要的配置项。这些配置项是必须的,用来指示“config client”如何找到“config server”以及应该加载那些配置文件。此外配置项“spring.cloud.config.name”和“spring.cloud.config.profile”配置项可以放到启动微服务的命令行中。这样可以编译一个通用jar包,通过不同命令行参数启动为不同的微服务实例。

  再次精简的本地“bootstrap.properties”配置文件: 

     技术分享图片

  启动“booking”微服务a的命令:

      java -jar .\booking-server.jar --spring.cloud.config.name=common,booking-common,booking-server-a --spring.cloud.config.profile=dev

 

 本文讲的东西是比较简单的。主要是分享一下使用“spring cloud config”的一种思路。

 

spring cloud实战与思考(一) spring config全局配置方案设计

标签:集中管理   期望   file   第一个   解决   修改   inf   其他   工具   

原文地址:https://www.cnblogs.com/standup/p/9052593.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!