讲讲 RocketMq 集群
时间: 2023-09-01 11:08:07 浏览: 111
RocketMQ 是一款开源的分布式消息中间件,支持高可用、高吞吐量的消息传递。RocketMQ 集群是由多个 RocketMQ 服务节点组成的,通过集群可以实现消息的高可靠性和水平扩展。
RocketMQ 集群架构中包含两种角色:Namesrv(名称服务)和Broker(消息存储和传递)。
1. Namesrv:Namesrv 是集群中的名称服务节点,负责维护整个集群的元数据信息,包括 Topic 的路由信息、Broker 的状态等。Namesrv 的集群通常采用主从模式部署,其中一个节点为主节点,其他节点为从节点,主节点负责处理客户端的请求,从节点则提供备份和故障转移支持。
2. Broker:Broker 是消息存储和传递的节点,负责接收、存储和传递消息。一个 RocketMQ 集群可以包含多个 Broker 节点,每个节点都可以存储一部分 Topic 的消息。Broker 也采用主从模式部署,其中一个节点为主节点,其他节点为从节点。主节点负责处理消息的读写请求,从节点则提供备份和故障转移支持。
RocketMQ 集群的工作流程如下:
1. Producer(消息生产者)向 Namesrv 发送消息发送请求,获取指定 Topic 的路由信息。
2. Producer 根据路由信息选择一个可用的 Broker 节点,发送消息到该节点。
3. Broker 负责将消息存储到磁盘,并将消息的元数据写入 CommitLog 和 IndexFile。
4. Consumer(消息消费者)向 Namesrv 发送消息拉取请求,获取订阅的 Topic 的路由信息。
5. Consumer 根据路由信息选择一个可用的 Broker 节点,从该节点拉取消息。
6. Broker 返回消息给 Consumer 并删除已经消费的消息。
通过集群的方式,RocketMQ 可以实现消息的高可靠性和水平扩展,提供高吞吐量的消息传递能力。同时,集群中的 Namesrv 和 Broker 节点可以通过主从模式部署来提供高可用性和故障转移支持。
阅读全文