rocketmq5.0版本,如果部署对了多个Controller,可能造成选举出来的BrokerRo[阿里云消息队列MQ]

rocketmq5.0版本,如果部署对了多个Controller,可能造成选举出来的BrokerRoler都是SLAVE?

「点点赞赏,手留余香」

    还没有人赞赏,快来当第一个赞赏的人吧!
=====这是一个广告位,招租中,联系qq 78315851====
2 条回复 A 作者 M 管理员
  1. 这个是必现的问题 感觉还是源码选举地方brokerRoler设置有点逻辑问题,此回答整理自钉群“群2-Apache RocketMQ 中国开发者钉钉群”

  2. 问题1:在RocketMQ 5.0版本中,如果部署了多个Controller,可能会导致选举出来的BrokerRole都是SLAVE。这是因为在选举过程中,Controller会根据Broker的状态、心跳等信息来进行判断,如果多个Controller都对同一个Broker进行了判断,就可能会出现选举混乱的情况。

    解决方案:可以通过在Broker的配置文件中设置brokerIP1、brokerIP2等参数来避免这种情况的发生,同时也可以通过调整Controller的心跳时间、重试次数等参数来优化选举过程。

    问题2:在dashboard上显示的是master,但是点击查看配置却是BrokerRole=SLAVE,可能是由于Broker的状态发生了变化,导致dashboard没有及时更新。

    解决方案:可以尝试刷新dashboard页面,或者在Broker的配置文件中手动设置BrokerRole为MASTER,然后重启Broker。

    问题3:dashboard集群没有配置按钮,可能是由于权限问题或者dashboard版本不兼容等原因导致的。

    解决方案:可以尝试升级dashboard的版本,或者检查dashboard的配置文件、权限等是否正确设置。

  3. 问题1:

    在 RocketMQ 5.0 版本中,如果部署了多个 Controller 节点且没有正确配置相关参数,可能会导致 Controller 选举出的 BrokerRole 都是 SLAVE。这是因为 Controller 在进行 Master 选举时,默认会将所有 Broker 都当作 SLAVE 进行处理,因为在 RocketMQ 中,每个 Broker 在启动时都默认是 SLAVE,只有选举出的 Master 才会变成 MASTER。

    为了解决这个问题,可以在启动 Controller 时添加以下参数进行配置:

    -Drocketmq.broker.longPollingTimeout=6000-Drocketmq.broker.slaveReadEnable=false

    其中,rocketmq.broker.slaveReadEnable 表示是否允许从 SLAVE 节点读取消息,默认为 true,需要设置为 false 才能避免 Controller 将所有 Broker 都当作 SLAVE 进行处理。

    问题2:

    在 Dashboard 中,如果显示的是 Broker 是 MASTER,但是在查看配置时显示是 BrokerRole 是 SLAVE,可能存在 Broker 的状态还没有同步至 Dashboard 上,也可能是因为在 Broker 选举时出现了异常。

    若 Broker 的状态还没有同步至 Dashboard 上,可以尝试等待一段时间后再次查看,或者手动刷新 Dashboard 页面。如果问题依然存在,可能需要修改相关配置并重启 Broker,或者检查 Broker 选举时是否出现异常情况。

    问题3:

    如果 Dashboard 集群没有配置按钮,可能是因为当前用户没有相应的权限,需要使用具有管理员权限的账号登录 dashboard 进行配置。如果已经使用管理员账号登录 Dashboard,但仍未看到配置按钮,可能是因为当前版本的 Dashboard 不支持在线配置,需要通过修改配置文件等方式进行配置。