• rabbitmq消费端auto和manual区别;处理mq的requeue


    概述

    automanual区别其实就如字面意思一般,auto代表自动确认消息,只要消费者的方法执行完了,就自动告诉mq当前消息确认.manual则是需要手动通知mq。不需要想的很复杂就是这么直接.

    auto自动确认

    1. 消息成功被消费,没有抛出异常,则自动确认,回复ack。
    2. 当抛出ImmediateAcknowledgeAmqpException异常,则视为成功消费,确认该消息。
    3. 当抛出AmqpRejectAndDontRequeueException异常的时候,则消息会被拒绝丢弃,并且不会重新入队。
    4. 其他的异常,则消息会被拒绝,且requeue = true(默认就是true)时会重新入队

    manual人工确认

    无论有没有异常,标准只有是否主动调用basicAck()、basicNack()等方法,没有调用则一直阻塞.

    因此有异常时,(有重试就重试),抛出异常后,没有调用时,还是会一直阻塞。即使是auto模式的那两个特殊的异常,在manual中都是一样的,不会有特殊处理.

    关于default-requeue-rejected(重新入队)属性的优先级

    server:
      port: 9009
    spring:
      rabbitmq:
        host: xxxx
        port: 5672
        username: xxxx
        password: xxxx
        virtual-host: /fchan
        listener:
          simple:
            #(默认值为true)在消费者出现异常时是否丢弃该消息还是重新入队,true:重新入队,入队后在队首
            #default-requeue-rejected: true
            #qos = concurrency * prefetch
            #concurrency: 1 
            #max-concurrency: 5
            #qos = concurrency * prefetch
            prefetch: 2
            #acknowledge-mode: auto
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    1. 最高优先级:AmqpRejectAndDontRequeueException处理的requeue = false(剩下那个特殊异常视为成功,与此处无关),抛出这个异常的时候直接就是拒绝并且丢弃。
    2. 其次是手动确认时basicNack()boolean requeue 参数
    3. 接着便是这个参数定义的重新入队default-requeue-rejected
    4. auto模式中,处理其他异常时,拒绝消息,此时如果配置了default-requeue-rejected=false则会丢弃消息
  • 相关阅读:
    Docker 部署 Geoserver
    如何获取obs视频帧的二进制数据
    jxTMS设计思想之权限
    【事故】记一次意外把企业项目放到GitHub并被fork,如何使用DMCA下架政策保障隐私
    设计模式之策略模式
    2022年音视频面试题 C/C++/Linux/FFmpeg/webRTC/rtmp/hls/rtsp/ffplay/srs
    在 Linux 操作系统中使用locate 命令快速定位文件和目录
    【Java8新特性】- Stream流
    常见的四种电阻之间有什么不同?
    显示器配置信息删除
  • 原文地址:https://blog.csdn.net/weixin_43944305/article/details/125870229