解决RabbitMQ的The channelMax limit is reached. Try later.

The channelMax limit is reached. Try later.顾名思义就是channel达到数量限制
查看源码得出
在这里插入图片描述
大概意思就是:
默认最大通道数;2047,因为它在服务器端是第2048个,每个连接用于协商和错误通信。
也可以在rabbitmq的管控台看出
在这里插入图片描述
总结:一个客户端连接(一个服务)默认只能有2047个通道数,也就是2047个消费者,在高并发的情况可能不够用,其实这个数字是可以修改。修改步骤如下:
第一:
创建rabbitmq配置文件rabbitmq.conf

default_user = guest
default_pass = guest
#最大通道数量
channel_max = 6114

在这里插入图片描述
第二:关闭rabbitmq镜像服务
docker stop 镜像名/镜像id

docker stop rabbitmq

第三:移除rabbitmq镜像服务
docker rm 镜像名/镜像id

docker rm rabbitmq

第四:启动rabbitmq镜像服务

docker run -d --name rabbitmq \
-p 5673:5672 \
-p 15673:15672 \
-v /etc/rabbitmq/rabbitmq.conf:/etc/rabbitmq/rabbitmq.conf \
-e RABBITMQ_CONFIG_FILE=/etc/rabbitmq/rabbitmq.conf \
--restart=always \
rabbitmq:3.11.1-management

第五:在消费者服务配置,不配置不生效
具体配置如下:

import org.springframework.amqp.rabbit.connection.CachingConnectionFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @author leishen
 */
@Configuration
public class RabbitMQConfiguration {

    @Value("${spring.rabbitmq.username}")
    private String username;

    @Value("${spring.rabbitmq.password}")
    private String password;

    @Value("${spring.rabbitmq.host}")
    private String host;

    @Value("${spring.rabbitmq.port}")
    private Integer port;

    @Value("${spring.rabbitmq.virtual-host}")
    private String virtualHost;



    /**
     * 设置最大通道数
     * @return
     */
    @Bean
    public CachingConnectionFactory cachingConnectionFactory(){
        CachingConnectionFactory cachingConnectionFactory=new CachingConnectionFactory();
        com.rabbitmq.client.ConnectionFactory rabbitConnectionFactory = cachingConnectionFactory.getRabbitConnectionFactory();
        //默认2047
        rabbitConnectionFactory.setRequestedChannelMax(6114);
        rabbitConnectionFactory.setUsername(username);
        rabbitConnectionFactory.setPort(port);
        rabbitConnectionFactory.setHost(host);
        rabbitConnectionFactory.setVirtualHost(virtualHost);
        rabbitConnectionFactory.setPassword(password);
        return cachingConnectionFactory;
    }

}

第六:打开管控台查看,结果配置生效
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: rabbitmq.4.lib 和 librabbitmq.4.lib 都是 RabbitMQ 的库文件,用于 Windows 平台开发者使用 RabbitMQ 的 C/C++ 客户端库。这两个库文件都是在 Windows 下编译时所生成的文件,主要用途是方便用户在 Visual Studio 开发环境下使用和编译 RabbitMQ 客户端。 这两个库文件也是 RabbitMQ 的一个重要组成部分,允许开发者将 RabbitMQ 的消息队列集成到他们的应用程序中,以便于实现跨平台的消息通信。其中,rabbitmq.4.lib 是 RabbitMQ 的 AMQP 协议 C++ 客户端库文件,包含了一系列的函数和类,使得开发者可以在他们的代码内部实现 RabbitMQ 消息队列。而 librabbitmq.4.lib 是 RabbitMQ 的 AMQP 协议 C 客户端库文件,一般在 Windows 系统下使用,用法与 rabbitmq.4.lib 类似,只是语言不同。 总之,这两个库文件都是实现 RabbitMQ 在 Windows 环境下的客户端库,它们允许开发者在 Windows 平台下更轻松地使用 RabbitMQ,并且在跨平台开发时更加方便快捷。 ### 回答2: RabbitMQ是一个开源的消息代理系统,通常用于分布式应用程序中的消息队列实现。librabbitmq是一个C语言客户端库,用于与RabbitMQ消息代理进行交互。librabbitmq.4.lib是librabbitmq库的一部分,是Windows操作系统下编译生成的动态库。这个库提供了一组API,可以实现基于RabbitMQ消息代理的消息传递。使用这个库,开发者可以在C语言中实现生产者、消费者模型,从消息队列中获取数据或发送数据到队列中等操作。此外,这个库还提供了诸如信道管理、连接管理等多个高级功能,为开发RabbitMQ应用程序提供了便利。RabbitMQ作为一款常用的消息代理系统,其在企业级应用、云计算等领域都有广泛的应用,而librabbitmq.4.lib作为RabbitMQ C语言客户端库,可以在Windows环境下提供高效的消息传递处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值