springBoot实现配置和实例的热更新,集成Apollo,方法通用

时间:2024-03-16 20:28:04

热更新会对两类Bean进行刷新,一种是使用了@ConfigurationProperties的对象,另一类是使用了@RefreshScope的对象 两者的更新机制也不同,前者通过rebind,所有的bean重新绑定来完成刷新;后者是通过RefreshScope的缓存和延迟加载机制,生成新对象

  1. 监听Apollo配置中心,配置发生变化的动作
    通过注解标明监听的配置文件
    springBoot实现配置和实例的热更新,集成Apollo,方法通用

  2. 发布 EnvironmentChangeEvent事件
    EnvironmentChangeEvent被发布后,会被两个监听者所捕获
    更新日志系统的相关配置,例如日志级别等
    springBoot实现配置和实例的热更新,集成Apollo,方法通用
    更新使用@ConfigurationProperties绑定的bean
    springBoot实现配置和实例的热更新,集成Apollo,方法通用

  3. refreshScope.refreshAll()
    在RefreshScope的类中
    springBoot实现配置和实例的热更新,集成Apollo,方法通用
    第一句话:super.destroy()
    在GenericScope中维护着一个cache,这是一个ConcurrentHashMap
    springBoot实现配置和实例的热更新,集成Apollo,方法通用
    所有被@RefreshScope标明的类都会被保存在cache中,在destroy()方法中会销毁掉所有bean的实例,这样缓存空了,在下次访问时就会创建新对象了
    在这个缓存中由四个bean会被预先被存储,当然你自定义类加上@RefreshScope也会北方进来
    springBoot实现配置和实例的热更新,集成Apollo,方法通用
    这四个是在源码中被预先注明@RefreshScope的,所以会被放入cache中,以下面的eurekaClient为例
    类RefreshableEurekaClientConfigurationspringBoot实现配置和实例的热更新,集成Apollo,方法通用
    第二句话:发布RefreshScopeRefreshedEvent事件
    这个事件会被一些cloud的组件中的监听,并作一些反馈
    例如zuul,Eureka
    在Eureka中的EurekaClientConfigurationRefresher 中会监听此事件
    springBoot实现配置和实例的热更新,集成Apollo,方法通用
    参考:
    https://www.jianshu.com/p/ee504c7b6fe2
    https://www.jianshu.com/p/188013dd3d02?tdsourcetag=s_pctim_aiomsg
    https://blog.csdn.net/cml_blog/article/details/78411312?tdsourcetag=s_pctim_aiomsg