Apollo的前世今生

Apollo是什么

  • Apollo是携程开发的一款灵活配置的框架(配置中心)。
  • 分为Server端和Client端,Server端需要单独部署。
  • 通过用户名密码登录后在Server端配置参数,Client端引入依赖后获取配置
  • 部署一套Server端,可以为多应用配置多环境参数。

Apollo怎么使用

  • 引入maven依赖
xml 复制代码
<dependency>
    <groupId>com.ctrip.framework.apollo</groupId>
    <artifactId>apollo-client</artifactId>
    <version>${apollo-client.version}</version>
</dependency>
  • 在Starter类上添加@EnableApolloConfig注解
less 复制代码
@SpringBootApplication
@EnableApolloConfig
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}
  • 在yml或properties配置文件中
yaml 复制代码
app:
  id: test
apollo:
  meta: http://xx.xx.xx.xx:8080
  bootstrap:
    enabled: true
  • 好,那么此时,在服务端登录配置就可以通过@Value,@ApolloJsonValue获取到配置了。

Apollo怎么做到的?

初次加载

  1. 初始化Spring上下文时调用applyInitializers方法 ApolloApplicationContextInitializer 此阶段很早 还未初始化Spring Bean
  2. 初始化时会创建RemoteConfigRepository,在构造方法中会schedulePeriodicRefresh(固定时延调用trySync方法刷新配置),scheduleLongPollingRefresh长轮询循环调用apollo服务端,发http get请求获取配置
  3. 将配置添加进environment中,AutowiredAnnotationBeanPostProcessor处理器处理添加了@Autowired和@Value注解的方法或字段,将${xx.xx.xx}解析为xx.xx.xx然后通过PropertySourcesPropertyResolver的getProperty取到env环境变量里的参数
  • 加载流程
  • 图中红线框起来的是与Server端交互的核心方法

字段注入时

  1. SpringValueProcessor和ApolloJsonValueProcessor实现了BeanPostProcessor。
  2. SpringValueProcessor处理添加了@Value的字段或者添加了@Value或@Bean的方法,将这些bean封装成SpringValue与key对应存储到Registry中
  3. ApolloJsonValueProcessor处理添加了ApolloJsonValue注解的字段或方法。主要是通过google的gson解析成字段所属类型,转化完后赋值给对应字段,并将这些bean封装成SpringValue与key对应存储到Registry中。
  4. ApolloJsonValueProcessor多了将值注入给field或method的过程,因为此时没用@Value注解,Spring不会自动注入,只能这里手动设值。
  • 这是SpringValueProcessor和ApolloJsonValueProcessor的抽象父类ApolloProcessor,其中processField、processMethod是主要实现。此处用到了模板方法设计模式。

特有注解

  1. ApolloAnnotationProcessor 处理添加了@ApolloConfig的字段(注入config属性) 和 添加了@ApolloConfigChangeListener的方法(注册自定义监听)
  2. 当使用ApolloConfigChangeListener注解添加到方法上时,配置变更就会触发注册的方法,并将变更对象传入。
    Aopllo的注解包 com.ctrip.framework.apollo.spring.annotation

变更对比

  1. 当长轮询返回code为200并且响应体不为空时,会触发notify通知。
  2. 将拉取到的配置Properties与本地已存储的配置Properties对比,找新增、删除或者value变更的值。
  3. 配置数据变化后,根据发布订阅模式,发布事件调用监听器,由AutoUpdateConfigChangeListener更新之前注册过的SpringValue的值。
  4. 把新的配置更新到本地配置文件 C:\opt\data\xxx\config-cache中,防止server宕机。
  • 长轮询主方法截图
  • 判断链路
  • 对比过程,本质上就是两个Set的对比得出新增、删除、更新事件

  • 发布事件后,会反射更新文中提到的SpringValue对象中Spring对象的值

更新展望

  • Server采用push推变更到Client,减少长轮询操作。(新版本应该已支持)
  • 无法更新被Spring逻辑加载后的结果,例如定时任务。

思维拓展

基于此种思路,思考如何应用到自身开发工作中。

全文基于 apollo-client 1.3.0 有错误欢迎指正

相关推荐
我爱挣钱我也要早睡!8 分钟前
Java 复习笔记
java·开发语言·笔记
AD钙奶-lalala2 小时前
Mac OS上搭建 http server
java
皮皮林5516 小时前
SpringBoot 全局/局部双模式 Gzip 压缩实战:14MB GeoJSON 秒变 3MB
java·spring boot
weixin_456904276 小时前
Spring Boot 用户管理系统
java·spring boot·后端
趁你还年轻_6 小时前
异步编程CompletionService
java
DKPT6 小时前
Java内存区域与内存溢出
java·开发语言·jvm·笔记·学习
sibylyue6 小时前
Guava中常用的工具类
java·guava
奔跑吧邓邓子6 小时前
【Java实战㉞】从0到1:Spring Boot Web开发与接口设计实战
java·spring boot·实战·web开发·接口设计
专注API从业者7 小时前
Python/Java 代码示例:手把手教程调用 1688 API 获取商品详情实时数据
java·linux·数据库·python
奔跑吧邓邓子7 小时前
【Java实战㉝】Spring Boot实战:从入门到自动配置的进阶之路
java·spring boot·实战·自动配置