微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

AmqpResourceNotAvailableException:已达到 channelMax 限制稍后再试

如何解决AmqpResourceNotAvailableException:已达到 channelMax 限制稍后再试

我知道在其他帖子中提到了这个错误 (https://github.com/spring-projects/spring-amqp/issues/999https://github.com/spring-projects/spring-amqp/issues/853),但我还没有找到适合我的解决方案。

我的项目定义了一组按队列发布和消费消息的微服务。当我 以每秒 200 个事务运行我的压力测试我收到此错误

已达到 channelMax 限制。稍后再试

错误仅在余下的一个微服务中显示

我在我的项目中使用:

spring-boot-starter-amqp.2.3.4.RELEASE
 spring-rabbit:2.2.11

我的兔子设置是:

  public ConnectionFactory publisherConnectionFactory() {
    final CachingConnectionFactory connectionFactory = new 
    CachingConnectionFactory(rabbitMQConfigProperties.getHost(),rabbitMQConfigProperties.getPort());
    connectionFactory.setUsername(rabbitMQConfigProperties.getUser());
    connectionFactory.setPassword(rabbitMQConfigProperties.getpass());
    connectionFactory.setPublisherReturns(true);
    connectionFactory.setPublisherConfirms(true);
    connectionFactory.setConnectionNameStrategy(connecFact -> rabbitMQConfigProperties.getNameStrategy());
    connectionFactory.setRequestedHeartBeat(15);
    return connectionFactory;
}


@Bean(name = "firstRabbitTemplate")
public RabbitTemplate firstRabbitTemplate(MessageDeliveryCallbackService messageDeliveryCallbackService) {
    final RabbitTemplate template = new RabbitTemplate(publisherConnectionFactory());
    template.setMandatory(true);
    template.setMessageConverter(jsonMessageConverter());
    template.setReturnCallback((msg,i,s,s1,s2) -> {
        log.error("Publisher Unable to deliver the message {},Queue {}: --------------",s2);
        messageDeliveryCallbackService.returnedMessage(msg,s2);
    });
    template.setConfirmCallback((correlationData,ack,cause) -> {
        if (!ack) {
            log.error("Message unable to connect Exchange,Cause {}: ack{}--------------",cause,ack);
        }
    });
    return template;
}

enter image description here

我的问题是:

我应该设置 ChannelCacheSize 和 setChannelCheckoutTimeout 吗?。我做了一个将 channelCacheSize 增加到 50 的测试,但问题仍然存在。根据我之前提到的,这些参数的最佳值是多少?我读到 channelCheckoutTimeout 应该高于 0 但我不知道我必须设置什么值。

现在我每秒处理大约 200 个事务,但这个数字会逐渐增加

提前致谢。

解决方法

channel_max 在客户端和服务器之间协商并应用于连接。默认值为 2047,因此您的经纪人似乎施加了下限。

https://www.rabbitmq.com/channels.html#channel-max

使用发布者确认时,将通道返回到缓存会延迟,直到收到确认;因此,当音量较大时,通常需要更多的通道。

您可以重新配置代理以允许更多通道,或者将 CacheMode 更改为 CONNECTION 而不是默认值 (CHANNEL)。

https://docs.spring.io/spring-amqp/docs/current/reference/html/#cachingconnectionfactory

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?