Apollo(阿波罗)[参考附录1]是携程框架部研发并开源的一款生产级的配置中心产品,它能够集中管理应用在不同环境、不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限、流程治理等特性,适用于微服务配置管理场景。
Apollo目前在国内开发者社区比较热,在Github上有超过5k颗星,在国内众多互联网公司有落地案例,可以说Apollo是目前配置中心产品领域Number1的产品,其成熟度和企业级特性要远远强于Spring Cloud体系中的Spring Cloud Config产品。
Apollo采用分布式微服务架构,它的架构有一点复杂,Apollo的作者宋顺虽然给出了一个架构图,但是如果没有一定的分布式微服务架构基础的话,则普通的开发人员甚至是架构师也很难一下子理解。为了让大家更好的理解Apollo的架构设计,我花了一点时间把Apollo的架构按我的方式重新剖析了一把。只有完全理解了Apollo的架构,大家才能在生产实践中更好的部署和使用Apollo。另外,通过学习Apollo的架构,大家可以深入理解微服务架构的一些基本原理。
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GLljP0X9-1581484435082)(http://jskillcloud.com/img/post/20180705/apollo_by_songshun.png#pic_center)]](https://1000bd.com/contentImg/2024/04/22/eed5df7291642abb.png)
Apollo架构图by宋顺
下面是Apollo的七个模块,其中四个模块是和功能相关的核心模块,另外三个模块是辅助服务发现的模块:
1、ConfigService
2、AdminService
3、Client
4、Portal
Eureka
MetaServer
NginxLB
最终的Apollo架构全貌,如下图所示:
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VgghFQa1-1581484435088)(http://jskillcloud.com/img/post/20180705/apollo_arch_v5.png#pic_center)]](https://1000bd.com/contentImg/2024/04/22/a07b9ee21a4ad5bd.png)
Admin Service发布配置后,发送ReleaseMessage给各个Config Service
官方文档:Config Service有一个线程会每秒扫描一次ReleaseMessage表,看看是否有新的消息记录,参见ReleaseMessageScanner。


我们的应用获取配置更新有apollo服务端主动推送(3.4点),也有客户端定时轮询。为什么要有客户端定时轮询,个人理解:服务端主动推送可能因为网络中断或者其他原因而导致配置更新通知不到应用,这时客户端定时轮询就能保证应用一定能收到配置更新。
参考文献: