当前位置:网站首页>消息队列的技术选型

消息队列的技术选型

2022-08-02 14:14:00 zhangyu丶

消息队列企业级应用场景分析

  1. 消息队列:在消息的传输过程中保存消息的容器,生产者和消费者不直接通讯,依靠队列保证消息的可靠性,避免了系统间的相互影响。
  2. 消息队列主要角色:服务端、客户端<生产者、订阅者>
  3. 消息队列主要作用:业务解耦、异步调用、流量削峰
    • 解耦优点:提升系统稳定性、通过广播消息避免多次调用、对于无需关注调用结果的场景可以通过消息队列异步处理

消息队列选型对比分析,为什么使用RocketMQ

功能对比成熟度顺序消息延时消息事务消息消息过滤消息查询消费失败重试批量发送
kafka日志领域支持不支持不支持支持不支持不支持支持
RabbitMQ成熟支持不支持不支持不支持不支持支持不支持
RocketMQ成熟支持特定LV支持支持支持支持不支持
实用性部署方式集群管理选主方式主从切换数据可靠性性能可用性堆积能力
kafka集群Zookeeper自动选举自动切换非常高分布式、主从非常好
RabbitMQ集群Erlang天然支持最早加入的节点自动切换主从一般
RocketMQ集群Name Server不支持不支持自动切换分布式、主从非常好
  • Kafka:系统间的数据流通道
  • RabbitMQ:可靠消息传输
  • RocketMQ:高性能可靠消息传输

MQ高可用及高扩展解决方案剖析

  1. RocketMQ 架构
    • Broker主从部署,自身信息注册在 NameServer 中
    • Client 从 NameServer 中获取 Broker 信息
    • NameServer 节点相互独立,无数据交互
  2. 可靠性分析
    • 同步刷盘:性能低,可靠性高
    • 异步刷盘:性能高,可靠性低

image.png

  • 异步复制
  • 同步双写
  1. 可用性分析
    • 主从模式 Master 宕机:Broker 可读不可写
    • 集群搭建方式
      • 单 Master 模式
      • 多 Master 模式
      • 多 Maste r多 Slave 模式-异步复制
      • 多 Master 多 Slave 模式-同步双写

MQ服务注册与发现原理剖析

  1. 注册中心—NameServer设计
    • 服务注册:Broker 注册自身信息
    • 服务发现:Procucer/Consumer 寻找 Broker 信息
  2. 注册中心—NameServer设计优点
    • 设计目标简单高效
    • 高可用方案:相互独立多个节点
    • 数据存储设计
      • Cluster-<Broker1,Broker2>
      • Broker1 -<MasterIP,SlaveIP>
      • Topic-<Broker1,Broker2>
      • Broker-heartbeat
原网站

版权声明
本文为[zhangyu丶]所创,转载请带上原文链接,感谢
https://zhangyuw.blog.csdn.net/article/details/126069351