RabbitMQ:通道关闭:连接错误回复代码=504,回复文本=CHANNEL_ERROR

问题描述

我们在 RabbitMQ 客户端日志中反复遇到以下错误,即通道关闭

通道关闭:连接错误;协议方法:#method(reply-code=504,reply-text=CHANNEL_ERROR - 处理 'tx.commit' 时出现意外命令,class-id=90,method-id=30)

大约在同一时间,RabbitMQ 日志显示以下错误

操作 tx.rollback 导致连接异常 channel_error: "unexpected command while processing 'tx.commit'"

根据 AMQP 规范,当客户端尝试使用未正确打开的通道时,会发生 504 错误

一些帖子指出应该增加通道缓存大小以避免这种情况,因为代码必须搅动大量通道

我们在 connectionfactory 对象中使用了 "channelCacheSize" value="25"。

问题

  1. 此问题的可能根本原因是什么?
  2. 如果我们需要进一步增加通道缓存大小,最佳数量是多少?
  3. 而且由于我们使用 RabbitMQ 事务发布,这里发送的消息会丢失吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)