追前沿,领略SET化架构衍化与设计

BAT/TMD大厂单元化架构设计衍变之路分享

  • 随着大型互联网公司业务的多元化发展,就拿滴滴、美团等大厂来讲,如滴滴打车、单车、外卖、酒店、旅行、金融等业务持续高速增长,单个大型分布式体系的集群,通过加机器+集群内部拆分(kv、mq、Mysql等),虽然具备了一定的可扩展性。但是,随着业务量的进一步增长,这个集群规模琢渐变的巨大,从而一定会在某个点达到瓶颈,无法满足扩展性需要,并且大集群内核服务出现问题,会影响全网所有用户。

  • 以滴滴打车、美团外卖举例来说:
    打车业务体量巨大,尤其在早晚高峰期。全年订单量已越10亿。
    外卖业务体量庞大,目前单量突破1700w/天,对应如此庞大的单个大型分布式集群,会面临一下问题:

    1. 容灾问题
    2. 资源扩展性问题
    3. 大集群拆分问
  • 容灾问题
    核心服务(比如订单服务)挂掉,会影影响全网所有的用户,导致整个业务不可用;
    数据库主库集中在一个IDC,主机房挂掉,会影响全网所有用户,整个业务无法快速切换和恢复

  • 资源扩展问题
    单IDC的资源(机器、网络带宽等)已经没法满足,扩展IDC时,存在跨机房访问延时问题(增加异地机房,时延问题严重);
    数据库主库单点,连接数有限,不能支持应用程序的持续发展;

  • 大集群拆分问题
    核心问题:分布式集群规模扩大后,会响应的带来资源扩展、大集群拆分以及容灾问题
    所有处于对业务扩展性以及容灾需求的考虑,我们需要一套从底层架构彻底解决问题的方案,业界主流解决方案:

SET单元化架构方案(阿里、支付宝、饿了么、微信等)

  • 同城 "双活" 架构介绍
    目前很多大型互联网公司的业务架构可以理解为同城"双活"架构,注意这里的“双活"是加引号的,具体可以这样理解:

    1. 业务层面上已经做到的真正的双活(或者多活),分别承担部分流量;
    2. 存储层面比如定时任务、缓存、持久层、数据分析等都是主从架构,会有跨机房写的问题;
    3. 一个数据中心故障,可以手动切换流量,部分组件可以自动切换;
  • 两地三中心架构介绍

    使用灾备的思想,在同城“双活”的基础上,在异地部署一套灾备数据中心,每个中心都具有完备的数据处理能力,只有当主节点故障需要容灾时才会紧急启动备用数据中心;


    11464886-5c88f4707d1255ac.png
  • SET化方案目标:
    业务:解决业务遇到的扩展性和容灾等需求,支撑业务的高速方案
    通用性:架构侧形成统一通用的解决方案,方面各业务线接入使用

SET化架构设计:

11464886-837deb034bb2ee03.png

SET化架构策略

流量路由:

  • 按照特殊的key(通常为userid)进行路由,判断某次请求该路由到中心集群还是单元化集群;

中心集群:

  • 为进行单元化改造的服务(通常不在核心交易链路,比如供应链系统)称为中心集群,跟当前架构保持一致。

单元化集群:

  • 每个单元化集群只负责本单元内的流量处理,以实现流量拆分以及故障隔离;
  • 每个单元化集群前期只存储本单元产生的交易数据,后续会做双向数据同步,实现容灾切换需求;

中间件(RPC、KV、MQ等):

  • RPC:对于SET服务,调用封闭在SET内;对于非SET服务,沿用现有的路由逻辑;
  • KV:支持SET的数据生产和查询;
  • MQ:支持分SET的消息生产和消费;

数据同步:

  • 全局数据(数据量小且变化不大,比如商家的菜品数据)部署在中心集群,其他单元化集群同步全局数据到本单元化内;
  • 未来演变为异地多活架构时,各单元化集群数据需要进行双向同步来实现容灾需要

异地容灾:

  • 通过SET化架构的流量调度能力,将SET分别部署在不同地区的数据中心,实现跨地区容灾支持

高效的本地化服务:

  • 利用前端位置信息采集和域名解析策略,将流量路由到最近的SET,提供最高效的本地化服务;
  • 比如O2O场景天然具有本地生产,本地消费的特点,更加需要SET化支持

集装箱扩展:

  • SET的封装性支持更灵活的部署扩展性,比如SET一键创建/下线,SET一键发布等。
11464886-ca21a78a32d4b5cc.png
SET化架构

SET化架构落地原则

  • 对业务透明原则:
    SET化架构的实现对业务代码透明,业务代码层面不需要关系SET化规则,SET的部署等问题

  • SET化切分的规则:
    理论上,切分规则有业务层面按需定制;
    实际上,建议优先选最大的业务维度进行切分;
    比如海量用户的O2O业务,按用户位置信息进行切分。此外接入层、逻辑层和数据层可以由独立的SET切分规则,有利于实现部署和运维成本的最优化

  • 部署规范原则:
    一个SET并不一定只限制在一个机房,也可以跨机房或者跨地区部署;为保证灵活性,单个SET内机器数不宜过多(如不超过1000台物理机)。

RabbitMQ-SET化架构实现

  • SET化消息中间件架构实现(RabbitMQ双活):


    11464886-fa333e1481ec08c3.png
  • 使用RabbitMQ异步消息通信插件 Federation(节点和节点、集群和集群之间通信) 安装与配置:

  • 安装插件

rabbitmq-plugins enable rabbitmq_federation
rabbitmq-plugins enable rabbitmq_federation_management

备注:当你再一个cluster钟使用了federation插件,所有在集群中的 nodes都需要安装federation插件

  • 使用RabbitMQ通信插件Rederation:
    Federation插件是一个在不需要cluster进行数据同步的(选择一个cluster中的节点和另一个cluster节点同步),而brokers之间传输消息的高新性能插件。

  • Federation插件可以在brokers或者cluster之间传输消息,链接的双方可以使用不同的users和virtual hosts、或者双方的rabbitmq和erlang版本不一致,federation插件使用AMQP协议通信,可以接受不连续的传输。

  • SET化配置规则:

    • 第一,Federation Exchanges,可以看成Downstream(82节点)从Upstream(81节点)主动拉取消息,并不是拉取所有消息,必须是在Downstream上已经明确定义Bindings关系的Exchange,也就是有实际的物理Queue来接收消息,才会从Upstream拉取消息到Downstream。使用AMQP协议实施代理间通信,Downstream会将绑定关系组合在一起,绑定/解绑命令将发送到Upstream交换机。

    • 第二,经过配置后,Upstream节点已经可以把消息直接通过Federation Exchanges路由给我们的Downstream节点,然后进行消费。

      也就是说可以实现消息的转发,接下来也可以在Upstream添加具体的队列去进行消费Federation Exchanges里的消息,我们一条消息分别发送到2个RabbitMQ集群并且消费,这样我们可以实现SET化的关键要素,就是集群间的消息同步了。

    • 第三,可以根据自己的业务规则去规划不同的集群去监听不同的消息队列,从而达到SET化的手段,保障了性能、可靠性、数据一致性。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 《Go语言设计与实现》是一本专门介绍Go语言设计和实现原理的书籍,由Alan A. A. Donovan和Brian W. Kernighan联合撰写,共计460页。这本书分为五部分,分别是Go编程基础、Go语言编译器、运行时、标准库以及Go语言实践。 其中第一部分介绍了Go语言的基础知识,包括基本语法、数据类型、函数、指针等,适合新手入门学习,同时也会深入探讨一些高级的概念,如接口、协程和并发编程等。 第二部分主要介绍了Go语言编译器的结构和原理,包括词法分析器、语法分析器、类型检查器和代码生成器等,了解这些内容对于理解Go语言的底层原理和运行机制非常有帮助。 第三部分主要讲解了Go语言的运行时系统,包括垃圾回收机制、并发调度、信道和调试器等,这些内容对于编写高质量的Go程序非常有帮助。 第四部分则介绍了Go标准库的使用方法和实现原理,包括各种常用的包和工具,如IO、网络、加密、时间等。 最后一部分是针对Go语言的实践经验,介绍了常见的编程技巧和注意事项,让读者可以更加高效地使用Go语言进行编程。 总的来说,《Go语言设计与实现》这本书对于想要深入了解Go语言的开发者来说是一本非常优秀的参考书籍,不仅涵盖了Go语言的基础知识,更深入探讨了Go语言的底层原理和实现机制,对于提高开发者的编程能力和思维能力有着非常重要的作用。 ### 回答2: 《Go语言设计与实现》是一本介绍Go语言原理和实现的高水平著作。本书共分为4个部分,分别是语言结构、并发机制、包与工具、运行时。作者深入浅出地介绍了Go语言的设计理念和内部机制,探讨了其中的思考过程,分析了Go语言的实现细节和底层结构,以及Go语言执行和并发机制的工作原理。 本书的第一部分从基本语言构造开始,介绍语言的元素,包括类型定义、变量、常量、函数、程序流程控制等等,把Go语言的基础打牢,为后续学习打下坚实的基础。第二部分重点介绍了Go语言的并发模型,包括goroutine、channel等等,让读者深入理解Go语言优秀的并发特性。第三部分讲解了Go语言的包管理和工具,并讲解了编写、测试、部署的全流程。 第四部分讲解了Go语言的运行时机制,包括垃圾收集、内存管理等等,让读者明白Go语言是如何运行的。 此外,《Go语言设计与实现》还介绍了过程组合和错误处理的方法、数据结构、系统调用等,让读者领略到Go语言的强大和优雅之处。 总之,这本书很适合想深入学习Go语言的人阅读。它既介绍了Go语言如何应用,又剖析了Go语言内部机制。如果你希望更好地掌握Go语言的使用和原理,这本书值得一读。 ### 回答3: Go语言设计与实现是Go语言的正式指导性文档,首次发布于2012年。这个文档的目的是深入阐述Go语言的语法、语义、并发、类型、包、测试、编译、运行时和标准库等方面。Go语言的成功归因于其简洁、高效、可靠和易用的特性,这个文档展示了这些特性背后的原理和设计思想。 该文档被分为三个部分:语言规范、包实现和编译器实现。第一部分介绍了Go语言的语法和语义,包括基本类型、函数、变量、控制结构、方法、接口、通道,以及内存模型、类型转换和运算等。第二部分描述了Go语言包的机制和设计,包括包的导入、可见性、包初始、错误处理、包的生命周期、安全问题和包的组织等。第三部分为编译器的实现提供了详尽的说明,包括词法分析、语法分析、类型检查、代码生成和链接等过程。此外,该文档还包含了一些实例代码,可以帮助开发者更好地理解Go语言。 Go语言设计与实现的特点在于其详细描述了Go语言的底层实现,而不仅仅是语言的语法和库函数。这有助于开发者更好地理解Go语言的设计,更好地利用Go语言的特性编写高效的代码。同时,该文档也是Go语言社区的重要参考资料,为Go语言的发展和推广做出了巨大的贡献。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值