目录
百战程序员,全站22050+开发课程+文档 ,学习精选优质好课快人一步!观看视频 快捷键ALT+N

JAVA全系列 教程

3762个小节阅读:7095.4k

收藏
全部开发者教程

C语言快速入门

JAVA全系列 教程

面向对象的程序设计语言

Python全系列 教程

Python3.x版本,未来主流的版本

人工智能 教程

顺势而为,AI创新未来

大厂算法 教程

算法,程序员自我提升必经之路

C++ 教程

一门通用计算机编程语言

微服务 教程

目前业界流行的框架组合

web前端全系列 教程

通向WEB技术世界的钥匙

大数据全系列 教程

站在云端操控万千数据

AIGC全能工具班

A

A A

White Night

阅读(513)
赞(0)

NameServer剖析

image-20220316205808498

p68921

Broker集群:

Broker用于接收生产者发送消息,或者消费者消费消息的请求。一个Broker集群由多组Master/Slave组成,Master可写可读,Slave只可以读,Master将写入的数据同步给Slave。每个Broker节点,在启动时,都会遍历NameServer列表,与每个NameServer建立长连接,注册自己的信息,之后定时上报。

Producer集群:

消息的生产者,通过NameServer集群获得Topic的路由信息,包括Topic下面有哪些Queue,这些Queue分布在哪些Broker上等。Producer只会将消息发送到Master节点上,因此只需要与Master节点建立连接。

Consumer集群:

消息的消费者,通过NameServer集群获得Topic的路由信息,连接到对应的Broker上消费消息。注意,由于Master和Slave都可以读取消息,因此Consumer会与Master和Slave都建立连接。

NameServer的设计:

  • NameServer互相独立,彼此没有通信关系,单台NameServer挂掉,不影响其他 NameServer。
  • NameServer不去连接别的机器,不主动推消息。
  • 单个Broker(Master、Slave)与所有NameServer进行定时注册,以便告知NameServer自己还活着。
  • Consumer随机与一个NameServer建立长连接,如果该NameServer断开,则从 NameServer列表中查找下一个进行连接。
  • Producer随机与一个NameServer建立长连接,每隔30秒(此处时间可配置)从 NameServer获取Topic的最新队列情况,如果某个Broker Master宕机,Producer最多30秒才能感知,在这个期间,发往该broker master的消息失败。Producer向提供Topic服务的Master建立长连接,且定时向Master发送心跳。

RocketMQ 中Name Servers 被设计用来做简单的路由管理。其职责包括:

  • Brokers 定期向每个NameServer注册路由数据。
  • NameServer为客户端,包括生产者,消费者和命令行客户端提供最新的路由信息。

实时效果反馈

1.NameServer的功能不包括哪个?

A 转发消息

B 命名服务

C 发现broker

D 更新服务

答案

1=>A

北京市昌平区回龙观镇南店村综合商业楼2楼226室

©2014-2023 百战卓越(北京)科技有限公司 All Rights Reserved.

京ICP备14032124号-2