RabbitMQ double ack 报错

部署运行你感兴趣的模型镜像

报错信息:

16:50:10.134 ERROR 17788 ---  o.s.a.r.c.CachingConnectionFactory       : 
Channel shutdown: channel error; protocol method: #method<channel.close>(reply-code=406, reply-text=PRECONDITION_FAILED - unknown delivery tag 1, class-id=60, method-id=80)

使用rabbitmq的时候总是报错信道关闭。网上查了原因,大多说的是因为没有配置RabbitAdmin,无法自动创建exchange的。但是我配置了RabbitAdmin,也能够自动创建exchange,还是报这个错,而且这个错居然不影响消息队列运行。
后来看到这篇文章https://www.cnblogs.com/zhjh256/p/6434093.html,其中提到double ack问题,联想到我配置了序列化为json格式,所以重新配置了rabbitmq,

@Configuration
public class RabbitMqConfig {

    @Bean
    public RabbitAdmin rabbitTemplate(ConnectionFactory connectionFactory) {
        return new RabbitAdmin(connectionFactory);
    }

    @Bean
    public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory, MessageConverter messageConverter) {
        RabbitTemplate template = new RabbitTemplate(connectionFactory);
        template.setMessageConverter(messageConverter);
        return template;
    }

    @Bean
    public SimpleRabbitListenerContainerFactory rabbitListenerContainerFactory(ConnectionFactory connectionFactory, MessageConverter messageConverter) {
        SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();
        factory.setConnectionFactory(connectionFactory);
        factory.setMessageConverter(messageConverter);
        return factory;
    }

    @Bean
    public MessageConverter messageConverter() {
        return new ContentTypeDelegatingMessageConverter(new Jackson2JsonMessageConverter());
    }
}

在yml配置文件中设置了手动ack


spring:
  rabbitmq:
    host: localhost
    port: 5672
    username: rabbit
    password: 123456
    virtual-host: /
    #生产端
    publisher-confirms: true
    publisher-returns: true
    template:
      mandatory: true
    #消费端
    listener:
      simple:
        acknowledge-mode: manual
        #初始连接数量
        concurrency: 5
        #最大连接数量
        max-concurrency: 10
        #限流
        prefetch: 1

yml中的签收模式失效,被注解注入的SimpleRabbitListenerContainerFactory覆盖,而它默认使用了自动签收。但是消费消息的时候又手动进行channel.basicAck(deliveryTag, false),于是导致了两次ack,所以报错。
解决方法是在rabbitmq的factory中指定ack模式。

 public SimpleRabbitListenerContainerFactory rabbitListenerContainerFactory(ConnectionFactory connectionFactory, MessageConverter messageConverter) {
      SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();
      factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);
      factory.setConnectionFactory(connectionFactory);
      factory.setMessageConverter(messageConverter);
      return factory;
  }
  ```

您可能感兴趣的与本文相关的镜像

Llama Factory

Llama Factory

模型微调
LLama-Factory

LLaMA Factory 是一个简单易用且高效的大型语言模型(Large Language Model)训练与微调平台。通过 LLaMA Factory,可以在无需编写任何代码的前提下,在本地完成上百种预训练模型的微调

### RabbitMQ STOMP 插件安装错误解决方案 当遇到RabbitMQ STOMP插件安装过程中出现问题时,可以按照以下方法排查并解决问题。 #### 验证权限 确保具有足够的权限来执行命令。通常情况下,这些操作需要超级用户权限。如果未以root身份运行命令,则可能会收到权限不足的错误消息。因此,在启用插件之前,请尝试使用`sudo`前缀再次运行命令[^1]: ```bash sudo rabbitmq-plugins enable rabbitmq_stomp ``` #### 检查网络连接 有时由于网络原因无法下载必要的依赖项而导致失败。确认主机能够访问互联网,并且没有任何防火墙阻止了到官方Erlang包存储库或其他必需资源的位置的流量。 #### 更新软件源列表 保持系统的软件源是最新的也很重要。对于基于Debian/Ubuntu的操作系统来说,可以通过下面这条指令更新APT缓存: ```bash sudo apt-get update ``` 而对于RedHat/CentOS系列则应使用yum工具做相同的事情: ```bash sudo yum makecache fast ``` 这有助于防止因过期或损坏的数据而引起的潜在冲突。 #### 清理旧版本残留文件 如果有先前不成功的安装尝试留下了一些临时文件或者部分解压的内容,那么清理它们可能有所帮助。移除 `/var/lib/rabbitmq/plugins` 下面所有的`.ez` 文件夹以及删除 `/usr/lib/rabbitmq/lib/rabbitmq_server-<version>/plugins/*stomp*.ez` 中的相关压缩包(其中 `<version>` 是实际安装的RabbitMQ服务器的具体版本号),然后再重新启动服务[^3]: ```bash service rabbitmq-server stop && rm -rf /var/lib/rabbitmq/plugins/*.ez \ && find /usr/lib/rabbitmq/lib/rabbitmq_server-* -name "*stomp*.ez" -exec rm {} \; ``` 之后再继续正常流程加载所需的STOMP支持功能模块。 #### 启用其他相关组件 除了核心的 `rabbitmq_stomp` 外,还可能存在一些辅助性的扩展也需要被激活才能让整个通信机制工作得更好。比如Web界面交互相关的部件就可以通过如下方式开启[^2]: ```bash sudo rabbitmq-plugins enable rabbitmq_web_stomp rabbitmq_web_stomp_examples ``` #### 查看日志记录 最后但同样重要的一步就是查看日志文件了解具体发生了什么异常情况。默认位置一般位于 `/var/log/rabbitmq/startup_log`, `/var/log/rabbitmq/startup_err` 和 `/var/log/rabbitmq/rabbit@hostname.log` 。利用grep或者其他文本处理工具快速定位关键字如“error”,从而更精准地分析根本原因所在。 完成上述步骤后记得重启一次RabbitMQ实例以便应用最新的更改设置。
评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值