Spring Cloud Config——原理解析
springCloud config项目,用来为分布式的微服务系统中提供集成式外部配置支持,分为客户端和服务端可以让你把配置放到远程服务器,目前支持本地存储、Git以及Subversion。spring官方如下介绍:简而言之: 通过配置服务(Config Server)来为所有的环境和应用提供外部配置的集中管理,这些概念都通过spring的Environment和PropertySourc...
springCloud config项目,用来为分布式的微服务系统中提供集成式外部配置支持,分为客户端和服务端
可以让你把配置放到远程服务器,目前支持本地存储、Git以及Subversion。
spring官方如下介绍:
简而言之: 通过配置服务(Config Server)来为所有的环境和应用提供外部配置的集中管理,这些概念都通过spring的Environment和PropertySource来抽象,所以他可以适用于各类Spring应用,它也能对应用的开发环境、测试环境、生成环境的配置做切换、迁移
原理介绍
-
springCloudConfig分服务端和客户端,服务端负责将本地,git或者svn中存储的配置文件发布成REST风格的接口,客户端可以从服务端REST接口获取配置。但客户端并不能主动感知到配置的变化,从而主动去获取新的配置,这需要每个客户端通过POST方法触发各自的/refresh接口。而我们上面说的SpringCloudBus就发挥了其作用了
-
SpringCloudBus通过一个轻量级消息代理连接分布式系统的节点(有点像消息队列那种)。这可以用于广播状态更改(如配置更改)或其他管理指令。SpringCloudBus提供了通过post方法访问的endpoint/bus/refresh(spring boot 有很多监控的endpoint,比如/health),这个接口通常由git的钩子功能(监听触发)调用,用以通知各个SpringCloudConfig的客户端去服务端更新配置。
git服务器会从远程git拉取配置文件,并存入到本地git文件库,当远程git不可用时,会从本地git文件库拉取配置信息
下面是一张spring cloud config结合bus的一张工作流图
2.第二个就是去访问配置文件时的,优先级关系的问题,请看下面的图(是自己尝试的数据,直接从server访问的)
配置的优先级自上而下,上面的最高
更多推荐
所有评论(0)