• 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则会丢弃消息
  • 相关阅读:
    【数据结构】二叉树的顺序结构-堆
    在Unity中挂载C#脚本的三种方法
    volatile关键字在并发中有哪些作用?
    ts中的元组是什么有什么用
    物联网安防-园区周界安防技术实现
    一看就懂:这就是机器学习过程!
    机器学习过程&四要素
    ARM开发流程相关工具简介
    【JAVA基础】专题课(综合案例下)
    第十五章总结
  • 原文地址:https://blog.csdn.net/weixin_43944305/article/details/125870229