欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

Java RocketMQ 路由注册与删除的实现

时间:2023-01-10 11:52:44|栏目:JAVA代码|点击:

简介

RocketMQ路由注册与删除是通过Broker与NameServer的心跳功能实现的。Broker启动时向集群中所有的NameServer发送心跳语句,每隔30s向集群中所有NameServer发送心跳包,NameServer收到Broker心跳包时会更新brokerLiveTable中的lastUpdateTimestamp,然后NameServer每隔10s扫描brokerLiveTable,如果连续120s没有收到心跳包,NameServer将移除该Broker的路由信息。

路由信息

路由实现类是org.apache.rocketmq.namesrv.routeinfo.RouteInfoManager

  • topicQueueTable:Topic消息队列路由信息,消息发送时根据路由表进行负载均衡。
  • brokerAddrTable:Broker基础信息,包含brokerName、所属集群名称、主备Broker地址。
  • clusterAddrTable:Broker集群信息,存储集群中所有Broker名称。
  • brokerLiveTable:Broker状态信息。NameServer每次收到心跳包会更新该信息。
  • filterServerTable:Broker上的FilterServer列表,用于类模式消息过滤。

路由注册

路由注册过程描述如下:

Broker启动时会向所有NameServer注册路由,然后启动一个定时任务,每隔30s发送心跳包;

BrokerOuterAPI中的registerBrokerAll实际上是通过Netty客户端将注册路由的请求发往NameServer的Netty服务端;

NameServer的Netty服务端接受到请求后,交给DefaultRequestProcessor的processRequest处理,最后委托给了RouteInfoManager的registerBroker方法,填充或者更新路由信息。

路由删除

在NamesrvController的initialize启动了个定时任务每隔10s扫描brokerLiveTable,如果连续120s没有收到心跳包,NameServer将移除该Broker的路由信息

上一篇:Java 正确终止线程的方法

栏    目:JAVA代码

下一篇:Java 中的静态字段和静态方法

本文标题:Java RocketMQ 路由注册与删除的实现

本文地址:http://www.codeinn.net/misctech/223398.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有