• 【博学谷学习记录】超强总结,用心分享|架构师-RabbitMQ消息可靠性保障



    消息依靠三个对象:生产者、消费者、broker
    在这里插入图片描述

    一、生产者保证

    生产者发送消息到broker时,要保证消息的可靠性,主要的方案有:失败通知和发送方确认。

    1.1 失败通知

    当消息无法投递时会发送失败通知。在发送消息时设置mandatory标志,即可开启故障检测模式。

    在这里插入图片描述
    注意的点是,失败通知只会让 RabbitMQ 向你通知失败,而不会通知成功,如果消息正确路由到队列,则发布者不会受到任何通知,带来的问题是无法确保发布消息一定是成功的,因为通知失败的消息可能会丢失。

    1.2 发送方确认

    发送方确认是指生产者投递消息后,如果 Broker 接收到消息,则会给生产者一个应答,生产者进行接收应答,用来确认这条消息是否正常的发送到 Broker,这种方式也是消息可靠性投递的核心保障
    rabbitmq消息发送分为两个阶段:
    1、将消息发送到broker,即发送到exchage交换机
    2、消息通过交换机exchange被路由到队列queue
    一旦消息投递到队列,队列则会向生产者发送一个通知,如果设置了消息持久化到磁盘,则会等待消息持久化到磁盘之后再发送通知

    注意:发送发确认只有出现RabbitMQ内部错误无法投递才会出现发送发确认失败。

    1.3 Broker丢失消息

    假设有现在一种情况,生产者已经成功将消息发送到了交换机,并且交换机也成功的将消息路由到了队列中,但是在消费者还未进行消费时,mq挂掉了,那么重启mq之后消息还会存在吗?如果消息不存在,那就造成了消息的丢失,也就不能保证消息的可靠性传输了。

    	也就是现在的问题变成了如何在mq挂掉重启之后还能保证消息是存在的?
    
    • 1

    开启RabbitMQ的持久化,也即消息写入后会持久化到磁盘,此时即使mq挂掉了,重启之后也会自动读取之前存储的额数据。

    二、消费方消息可靠性

    2.1 消费者手动确认

    消费者接收到消息,但是还未处理或者还未处理完,此时消费者进程挂掉了,比如重启或者异常断电等,此时mq认为消费者已经完成消息消费,就会从队列中删除消息,从而导致消息丢失。

    那该如何避免这种情况呢?这就要用到RabbitMQ提供的ack机制,RabbitMQ默认是自动ack的,此时需要将其修改为手动ack,也即自己的程序确定消息已经处理完成后,手动提交ack,此时如果再遇到消息未处理进程就挂掉的情况,由于没有提交ack,RabbitMQ就不会删除这条消息,而是会把这条消息发送给其他消费者处理,但是消息是不会丢的。

  • 相关阅读:
    netty系列之: 在netty中使用 tls 协议请求 DNS 服务器
    最新自动定位版本付费进群系统源码
    一文总览元宇宙科技独角兽Animoca Brands投资版图
    直播课堂系统03-model类及实体
    Leetcode4.寻找两个正序数组的中位数 - 1/2+2种方法
    01-juc-入门概念
    解决所有二叉树路径问题
    2.6 动态规划—lc炒股系列
    解决BookxNotePro在linux下无法启动或GLIBC_2.29‘ not found的问题
    SpringBoot-7-对Web开发静态资源的处理
  • 原文地址:https://blog.csdn.net/qq_22043649/article/details/127999474