互联网架构中为什么需要配置中心

发布时间:2021-12-07 11:43:40 作者:小新
来源:亿速云 阅读:186

这篇文章主要介绍了互联网架构中为什么需要配置中心,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

配置中心是互联网架构体系中很重要的一块,但为什么会有配置中心,是不是一开始就要有配置中心,它究竟解决什么问题,这是今天要讨论的问题。

随着互联网业务的越来越复杂,用户量与流量越来越大,“服务化分层”是架构演进的必由之路。

互联网架构中为什么需要配置中心

如上图,站点应用会调用服务,上游服务调用底层服务,依赖关系会变得非常复杂。

对于同一个服务:

(1)它往往有多个上游调用;

(2)为了保证高可用,它往往是若干个节点组成的集群提供服务;

互联网架构中为什么需要配置中心

如上图,用户中心服务user-service有三个节点,ip1/ip2/ip3对上游提供服务,任何一个节点当机,都不影响服务的可用性。

那么问题来了:

初期:“配置私藏”架构

“配置私藏”是配置的最初级阶段,上游调用下游,每个上游都有一个专属的私有配置文件,记录被调用下游的每个节点配置信息。

互联网架构中为什么需要配置中心

如上图:

画外音:是不是很熟悉?绝大部分公司,初期都是这么玩的。

“配置私藏”架构的缺点是什么呢?

互联网架构中为什么需要配置中心

来看一个容量变化的需求:

此时要怎么做呢?

互联网架构中为什么需要配置中心

需要用户中心的负责人通知所有上游调用者,修改“私藏”的配置,并重启上游,连接到新的集群上去。在ip1上没有流量之后,通知运维将ip1节点下线,以完成整个缩容扩容过程。

这种方案存在什么问题呢?

当业务复杂度较高,研发人数较多,服务依赖关系较复杂的时候,就没这么简单了。

问题一:调用方很痛,容量变化的是你,凭啥修改配置重启的是我?这是一个典型的“反向依赖”架构设计,上下游通过配置耦合,不合理。

问题二:服务方很痛,ta不知道有多少个上游调用了自己,往往只能通过以下方式来定位上游:

画外音:是不是似曾相识?

不管哪种方式,都很有可能遗漏,导致ip1一直有流量难以下线,ip4/ip5的流量难以均匀迁移过来。该如何优化呢?

中期:“全局配置”架构

架构的升级并不是一步到位的,先来用最低的成本来解决上述“修改配置重启”的问题一。

互联网架构中为什么需要配置中心

“全局配置”架构:对于通用的服务,建立全局配置文件,消除配置私藏:

全局配置有什么好处呢?

全局配置有什么不足呢?

如果调用方一直不重启,就没有办法将流量迁移到新集群上去了。

有没有方面实现自动流量迁移呢?

互联网架构中为什么需要配置中心

答案是肯定的,只需要引入两个并不复杂的组件,就能实现调用方的流量自动迁移:

画外音:用锁来互斥,很容易实现。

引入了这两个组件之后:

终版:“配置中心”架构

“全局配置”架构是一个能够快速落地的,解决“修改配置重启”问题的方案,但它仍然解决不了,服务提供方“不知道有多少个上游调用了自己”这个问题。

如果不知道多少上游调用了自己:

等这类需求便难以实现,怎么办?

“配置中心”架构能够完美解决

互联网架构中为什么需要配置中心

对比“全局配置”与“配置中心”的架构图,会发现配置由静态的文件升级为动态的服务:

互联网架构中为什么需要配置中心

当下游服务需要扩容缩容时:

“配置中心”架构有什么好处呢?

痛点一、痛点二同时解决。

“配置中心”架构有什么不足呢?

感谢你能够认真阅读完这篇文章,希望小编分享的“互联网架构中为什么需要配置中心”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

推荐阅读:
  1. SpringCloud之配置中心Config
  2. zookeeper(5)配置中心

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

互联网

上一篇:Oracle 11g怎么收集多列统计信息

下一篇:Hyperledger fabric Chaincode开发的示例分析

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》