消息队列架构设计思路(消息队列框架有哪些)

技术消息队列Broker主从架构的设计方案是什么这篇文章将为大家详细讲解有关消息队列Broker主从架构的设计方案是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。今天

本文将详细阐述消息队列代理主从架构的设计方案。这篇文章的内容质量很高,所以边肖会分享给大家参考。希望你看完这篇文章后有所了解。

今天,我们来了解一下消息队列设计的底层模块,即Broker的架构设计。

Master Broker 与Slave Broker 消息如何同步

正如我们之前所知,如果您希望Broker支持高可用性,您应该将其设计为主从架构。前面的分布式存储也讲了很多这个架构,大家可以自己查历史文章。

首先我们来看第一个问题。为了确保我们的MQ中的数据不会丢失并支持可用性,我们将代理设计为主从模式,即一个主代理对应多个从代理。

这样做的好处是,当我们的主代理收到消息时,它会将消息同步到从代理,因此即使主代理关闭,从代理上仍然会有数据。

消息队列Broker主从架构的设计方案是什么

如上所述,让我们考虑一下这个主代理如何与从代理同步数据。一般有两种方案:

主代理主动向从代理推送消息。

从属代理向主代理发送一个请求,以提取消息数据。

我们采用了更可靠的二次拉取方案,让从代理不断向主代理发送请求,以拉取方式拉取消息。

消息队列Broker主从架构的设计方案是什么

MQ 实现读写分离吗?

从上面我们已经知道,Master Broker主要用于接收消息,然后与Slave Broker同步,所以Slave Broker也有一个相同的数据。

在这种情况下,我们的下一个问题是,消费者系统是从主代理还是从代理获取消息?

事实上,我们不能简单地从主人或奴隶那里得到它。我们应该更聪明。有可能从主人或奴隶那里得到它。

作为一个消费者系统,在获取消息时,首先会向Master Broker发送一个请求,然后Master Broker会向消费者系统返回一批消息。

消息队列Broker主从架构的设计方案是什么

然后,当主代理将消息返回给消费系统时,它将根据自己的负载和与从代理的同步,建议消费系统下次是从主代理还是从从代理获取消息。

例如,现在Master负载很重,它必须抵抗100,000个写并发。那你就得从它那里得到消息,这会给师父带来更重的负担。然后主代理会建议你去从代理获取消息。

比如现在Master Broker已经收到了100万条消息。结果,Slave Broker机器无缘无故就同步到了96万条消息,落后了4万条消息。此时作为一个消费系统,可能已经获取了96万条消息,所以下次只能从Master拉消息。因为Slave Broker太慢,无法同步消息,所以我们无法从那里获取最新消息。

因此,这一切都将由Master Broker根据实际负载情况决定从哪里获取消息。

消息队列Broker主从架构的设计方案是什么

如图所示:

写消息时,通常必须选择Master Broker来写。

当消费消息时,可以在主代理中拉它们或者转到从代理。

拉取的,视当时情况决定。

Slave Broker 挂了有何影响?

现在我们看下一个问题, 假如Slave Broker 挂掉了,会对我们整个系统有什么影响?影响是有一点的,但是不太大,无足畏惧。

因为消息在写入的时候是全部发到 Master Broker 上的,然后拉取消息的时候也可以走 Master Broker,只是有一些消息拉取可能是走  Slave Broker 上的。

所以,假如 Slave Broker 挂掉了,我们消息写入和获取都是可以走 Master Broker  的,是不会对我们整体系统造成大影响的。就是会可能导致Master Broker 读写压力增加。

Master Broker 挂掉了该怎么办?

上面我们分析了 Slave Broker 挂了并不影响整体系统,现在假设我们的 Master Brokker 抽风了挂掉了,会怎么样呢?

这个时候,对于消息的写入和获取就有一定影响了,但是就本质而言,Slave Broker 上是有一份数据的,只不过是有一些数据还没来得及从 Master  Broker 中同步,一般我们就要设计 Slave Broker 自动接管 Master Broker 机制了,可以有两种方案解决:

  • 人工运维,通过人手工切换

  • 利用工具自动切换

手动切换

在 RocketMQ4.5 版本之前,都是这样的人工运维方式,当Master Broker 挂掉之后,人为的去修改配置,将 Slave Broker  进行相关修改,然后重启机器就给调整为 Master Broker,期间就是有点麻烦,而且会造成短时间的不可用。

消息队列Broker主从架构的设计方案是什么

采用如上方式,并不能彻底的实现高可用,因为没办法自动将Slave Broker 升为 Master Broker。

基于Dledger 实现 MQ 自动切换

RocketMQ4.5 之后,开始引入新的机制,那就是Dledger,Dledger 是基于Raft  协议实现的机制,后面会单独对其底层原理进行详细讲解。我们先来看看基于Dledger 怎么实现 自动切换。

RocketMQ 引入 Dledger 之后,就可以让一个 Master Broker 对应多个 Slave Broker  也就是说一份数据会有多份副本。比如我们一个Master Broker 对应 两个 Slave Broker。

消息队列Broker主从架构的设计方案是什么

此时,如果一个Master Broker 宕机的话,还是会有多个 Slave ,然后通过Dledger 技术以及Raft 协议进行leader  选主,选主算法其实我前面有一篇专门讲了的,可以看看(面试是不是经常被问到分布式系统核心问题,这一次没人难倒你)。这样就会选出新的Master broker  对外提供服务。

如此一来,整个过程会很快,大概十几秒或者几十秒就能完成切换动作,完全的全自动的将Slave Broker 选为Master broker  对外提供服务,实现高可用模式。

消息队列Broker主从架构的设计方案是什么

关于消息队列Broker主从架构的设计方案是什么就分享到这里了,希望

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/157466.html

(0)

相关推荐

  • linux下常见问题有哪些

    技术linux下常见问题有哪些这篇文章将为大家详细讲解有关linux下常见问题有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.user ss is current

    攻略 2021年10月22日
  • 古诗竹里馆,《竹里馆》全诗内容是什么

    技术古诗竹里馆,《竹里馆》全诗内容是什么唐  王维 《竹里馆》 独坐幽篁里古诗竹里馆,弹琴复长啸。
    深林人不知,明月来相照。 译文 :
    独自闲坐幽静竹林,时而弹琴时而长啸。
    密林之中何人知晓我在这里?只有一轮明月静

    生活 2021年10月22日
  • JAVA并发容器有哪些

    技术JAVA并发容器有哪些这篇文章主要介绍“JAVA并发容器有哪些”,在日常操作中,相信很多人在JAVA并发容器有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JAVA并发容器有哪些”

    攻略 2021年11月17日
  • JDK源码阅读(7):ConcurrentHashMap类阅读笔记

    技术JDK源码阅读(7):ConcurrentHashMap类阅读笔记 JDK源码阅读(7):ConcurrentHashMap类阅读笔记JDK源码阅读(7):ConcurrentHashMap类阅读笔

    礼包 2021年11月25日
  • Java JUC多线程的Fork Join Pool怎么使用

    技术Java JUC多线程的Fork Join Pool怎么使用这篇文章主要介绍“Java JUC多线程的Fork Join Pool怎么使用”,在日常操作中,相信很多人在Java JUC多线程的Fork Join Po

    攻略 2021年11月24日
  • 我会游泳英语怎么说,我要去游泳用英语怎么说

    技术我会游泳英语怎么说,我要去游泳用英语怎么说现在时我会游泳英语怎么说: i go to swim .口语化一点: Lets go swimming! 去游泳吧!
    过去时:I went to swim yesterday

    生活 2021年10月27日