请教下使用Apache RocketMQ中mqadmin deleteTopic 命令只能在?

请教下使用Apache RocketMQ中mqadmin deleteTopic 命令只能在broker主机上执行吗?发现在非broker主机执行这个命令报错Caused by: org.apache.rocketmq.client.exception.MQClientException: CODE: 1 DESC: Can't modify topic or subscription group from slave broker, please execute it from master broker?

展开
收起
真的很搞笑 2023-05-23 20:06:05 398 分享 版权
2 条回答
写回答
取消 提交回答
  • 这个应该是代码写错了。
    org.apache.rocketmq.tools.admin.DefaultMQAdminExtImpl#deleteTopic
    这个方法里,用的是Set brokerAddressSet = CommandUtil.fetchMasterAndSlaveAddrByClusterName(this.defaultMQAdminExt, clusterName);获取主和从节点的address,应该是获取主节点的adderss。用fetchMasterAddrByClusterName。

    2023-08-25 09:09:23
    赞同 展开评论
  • 公众号:网络技术联盟站,InfoQ签约作者,阿里云社区签约作者,华为云 云享专家,BOSS直聘 创作王者,腾讯课堂创作领航员,博客+论坛:https://www.wljslmz.cn,工程师导航:https://www.wljslmz.com

    在Apache RocketMQ中,mqadmin deleteTopic命令只能在broker主机上执行,不支持在非broker主机上执行。如果在非broker主机上执行该命令,会出现类似于"Can't modify topic or subscription group from slave broker, please execute it from master broker" 的错误。

    这是因为,该命令会请求主节点进行相应的操作,而从节点是不能进行这些操作的。主节点是唯一拥有修改topic信息的权限的,从节点只负责数据同步,并不具备修改元数据信息的能力。因此,如果需要删除topic,必须在主节点所在的broker机器上执行mqadmin deleteTopic命令。

    2023-05-23 23:07:44
    赞同 展开评论

涵盖 RocketMQ、Kafka、RabbitMQ、MQTT、轻量消息队列(原MNS) 的消息队列产品体系,全系产品 Serverless 化。RocketMQ 一站式学习:https://rocketmq.io/

收录在圈子:
+ 订阅
阿里云 云原生应用平台 肩负阿里巴巴集团基础设施云化以及核心技术互联网化的重要职责,致力于打造稳定、标准、先进的云原生产品,成为云原生时代的引领者,推动行业全面想云原生的技术升级,成为阿里云新增长引擎。商业化产品包括容器、云原生中间件、函数计算等。
还有其他疑问?
咨询AI助理