消费者正在订阅一个主题,当将主题权限修改为不可读或只是删除这个主题时,我们希望看到消费者不会向broker发送拉请求,但实际上拉请求将一直在进行,除非重新启动消费者。
异常堆栈跟踪如下所示:
2021-04-02 15:24:54.018 WARN [NettyClientPublicExecutor_2:RocketmqClient:130] execute the pull request exception org.apache.rocketmq.client.exception.MQBrokerException: CODE: 17 DESC: topic[topic-flash2] not exist, apply first please! See http://rocketmq.apache.org/docs/faq/ for further details. BROKER: 192.168.60.39:10911 at org.apache.rocketmq.client.impl.MQClientAPIImpl.processPullResponse(MQClientAPIImpl.java:794) ~[rocketmq-client-4.8.0.jar:4.8.0] at org.apache.rocketmq.client.impl.MQClientAPIImpl.access$200(MQClientAPIImpl.java:167) ~[rocketmq-client-4.8.0.jar:4.8.0] at org.apache.rocketmq.client.impl.MQClientAPIImpl$2.operationComplete(MQClientAPIImpl.java:745) [rocketmq-client-4.8.0.jar:4.8.0] at org.apache.rocketmq.remoting.netty.ResponseFuture.executeInvokeCallback(ResponseFuture.java:54) [rocketmq-remoting-4.8.0.jar:4.8.0] at org.apache.rocketmq.remoting.netty.NettyRemotingAbstract$2.run(NettyRemotingAbstract.java:319) [rocketmq-remoting-4.8.0.jar:4.8.0] at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) [?:1.8.0_211] at java.util.concurrent.FutureTask.run$$$capture(FutureTask.java:266) [?:1.8.0_211] at java.util.concurrent.FutureTask.run(FutureTask.java) [?:1.8.0_211] at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) [?:1.8.0_211] at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) [?:1.8.0_211] at java.lang.Thread.run(Thread.java:748) [?:1.8.0_211]
正如下面的代码所示,当一个主题没有队列时,AllocateStrategy会抛出一个异常, 则processQueueTable将不会更新
rocketmq 4.8.0
原提问者GitHub用户EZLippi
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
这种操作属于非标操作,既然有消费者在线,那么就应该知道执行的后果。因此我觉得这不是bug。 负载均衡这里是正常的,因为 mqSet和cidSet 是一直没有变的。 获取topic路由哪里,如果找不到topic的话,会抛出异常,并不会更新路由信息,那么mqSet也就不会变。 cidSet是根据ConsumerId来决定的。
原回答者GitHub用户panzhi33
阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。