数据流
SpringCloudConfig 的 工作流程:
- 将修改的配置信息提交到Git,触发 WebHook。WebHook用 Http 的形式向 ConfigServer 发送 refresh 请求。
- ConfigServer 将这个消息发送给 spring cloud bus(用kafka或者rabbitMQ实现)
- 每个应用实例中有一个 config-client,将会收到这个 refresh 消息
- 如果 destination 和自己匹配,就执行刷新动作。 向 config-server 请求配置
- config-server 拉取配置仓库中的最新配置文件并转成相应的json格式
- 回传给 config-client,随后 config-client 将内容更新到上下文中。
配置刷新原理
当触发热更新的时候,会调用 ContextRefresher 的 refresh()。方法的实现如下:
public synchronized Set<String> refresh() {
Set<String> keys = refreshEnvironment();
this.scope.refreshAll();
return keys;
}
public synchronized Set<String> refreshEnvironment() {
//1
Map<String, Object> before = extract(
this.context.getEnvironment().getPropertySources());
//2
addConfigFilesToEnvironment();
//3
Set<String> keys = changes(before,
extract(this.context.getEnvironment().getPropertySources())).keySet();
//4
this.context.publishEvent(new EnvironmentChangeEvent(this.context, keys));
return keys;
}
extract方法
这个方法接收了环境中所有的 PropertySource ,并将其中的非标准属性源
的所有属性汇总到一个 Map 。
这里的标准属性源
如下所示:
- systemProperties
- systemEnvironment
- servletContextInitParams
- servletConfigInitParams
- configurationProperties
- jndiProperties
StandardEnvironment 会注册系统变量(System Properties
)和环境变量(System Environment
)
StandardServletEnvironment 会注册 Servlet 环境下的 Servlet Context
和 Servlet Config 的初始参数(Init Params
)和JNDI
的属性。
###addConfigFilesToEnvironment方法
addConfigFilesToEnvironment()
的实现逻辑:
- 创建新的SpingBoot来获取新的属性源
- 对比新旧数据源: 1、将旧的数据源替换成新的数据源;2、将全新的数据源添加到 this.context.getEnvironment中。
ConfigurableApplicationContext addConfigFilesToEnvironment() {
ConfigurableApplicationContext capture = null;
try {
//复制得到的 environment 主要包含
//systemProperties、systemEnvironment、refreshArgs和defaultProperties
StandardEnvironment environmen