zoukankan      html  css  js  c++  java
  • mq组件介绍

    作者:Jaskey Lam
    链接:https://zhuanlan.zhihu.com/p/25069846
    来源:知乎
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

    RocketMQ服务端的组件有三个,NameServer,Broker,FilterServer(可选,部署于和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信息。
  • 相关阅读:
    客户端发现响应内容类型为“text/html”,但应该是“text/xml”
    [转]AJAX Control Toolkit 介绍及构建开发环境
    kafka删除topic详解
    influxdb问题解决
    logback配置
    kafka环境搭建测试
    Hdu 1753 大明A+B <高精度小数相加>
    POJ 1966 <点连通度>
    POJ 2446 Chessboard 二分图的最大匹配 <建图>
    Hlg 1522 子序列的和 <单调队列>
  • 原文地址:https://www.cnblogs.com/panxuejun/p/8615587.html
Copyright © 2011-2022 走看看