• 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.成熟度(经过双十一考验)

  • 相关阅读:
    oracle里某列插入多行数据
    子类与父类的一些关系
    math.round()的值怎么取的
    oracle replace函数
    spring5.1.5使用的jackson依赖版本
    eclipse设置新建jsp页面的默认编码为utf-8
    c3p0启动失败
    sql的左联右联合内联的区别
    eclipse安装spring tools插件的问题
    HTML点击按钮button跳转页面的四种方法
  • 原文地址:https://www.cnblogs.com/Zzzzn/p/12321797.html
Copyright © 2020-2023  润新知