zoukankan      html  css  js  c++  java
  • RocketMQ概述

    一、RocketMQ概述

      RocketMQ 是一款分布式、队列模型的消息中间件,具有以下特点: 能够保证严格的消息顺序 提供丰富的消息拉取模式 高效的订阅者水平扩展能力 实时的消息订阅机制 亿级消息堆积能力

    二、RocketMQ包含的组件 

      NameServer:单点,供Producer和Consumer获取Broker地址

      Producer:产生并发送消息

      Consumer:接受并消费消息

      Broker:消息暂存,消息转发

      

    三、Name Server

      Name Server是RocketMQ的寻址服务。用于把Broker的路由信息做聚合。客户端依靠Name Server决定去获取对应topic的路由信息,从而决定对哪些Broker做连接。

      Name Server是一个几乎无状态的结点,Name Server之间采取share-nothing的设计,互不通信。

      对于一个Name Server集群列表,客户端连接Name Server的时候,只会选择随机连接一个结点,以做到负载均衡。

      Name Server所有状态都从Broker上报而来,本身不存储任何状态,所有数据均在内存。

      如果中途所有Name Server全都挂了,影响到路由信息的更新,不会影响和Broker的通信。

    四、Broker

      Broker是处理消息存储,转发等处理的服务器。

      Broker以group分开,每个group只允许一个master,若干个slave。

      只有master才能进行写入操作,slave不允许。

      slave从master中同步数据。同步策略取决于master的配置,可以采用同步双写,异步复制两种。

      客户端消费可以从master和slave消费。在默认情况下,消费者都从master消费,在master挂后,客户端由于从Name Server中感知到Broker挂机,就会从slave消费。

      Broker向所有的NameServer结点建立长连接,注册Topic信息。

    五、RocketMQ优点

      1.强调集群无单点,可扩展

      2.任意一点高可用,水平可扩展

      3.海量消息堆积能力,消息堆积后,写入低延迟。

      4.支持上万个队列

      5.消息失败重试机制

      6.消息可查询

      7.开源社区活跃

      8.成熟度(经过双十一考验)

  • 相关阅读:
    中国地区免费注册bitcointalk论坛教程
    Broken Keyboard (a.k.a. Beiju Text) 思路
    IE兼容性測試軟件
    HttpRunner接口自动化框架的使用
    在Linux服务器上安装Python3.7
    在Linux系统上安装Git
    在Linux系统上安装配置ant环境
    桥接模式:探索JDBC的接口
    Intelij Idea下的git使用
    SSM+Maven(教程二):Idea快速入门SSM+Maven框架。
  • 原文地址:https://www.cnblogs.com/Zzzzn/p/12321797.html
Copyright © 2011-2022 走看看