码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • RabbitMQ 入门系列:6、保障消息:不丢失:发送方、Rabbit存储端、接收方。


    系列目录

    RabbitMQ 入门系列:1、MQ的应用场景的选择与RabbitMQ安装。

    RabbitMQ 入门系列:2、基础含义:链接、通道、队列、交换机。

    RabbitMQ 入门系列:3、基础含义:持久化、排它性、自动删除、强制性、路由键。

    RabbitMQ 入门系列:4、基础编码:官方SDK使用:链接创建、单例改造、发送消息、接收消息。

    RabbitMQ 入门系列:5、基础编码:交换机的进阶介绍及编码方式。

    RabbitMQ 入门系列:6、保障消息:不丢失:发送方、Rabbit存储端、接收方。

    RabbitMQ 入门系列:7、保障消息:不重复消费:产生消息的唯一ID。

    RabbitMQ 入门系列:8、扩展内容:接收信息时:可否根据RoutingKey过滤监听信息,答案是不能。

    RabbitMQ 入门系列:9、扩展内容:死信队列:真不适合当延时队列。

    RabbitMQ 入门系列:10、扩展内容:延时队列:延时队列插件及其有限的适用场景。

    前言:

    本篇简单介绍如何保障消息不丢失的处理方式。

    1、保障消息不丢失:发送方

    主要是通过消息确认或事务,来保障这个过程,下面见具体代码:

    1、通过确认机制处理的代码:

    复制代码
    using RabbitMQ.Client;
    using System.Text;using (var channel = Rabbit.Instance.DefaultConnection.CreateModel())
    {
        channel.ConfirmSelect();//开启确认
        channel.QueueDeclare("FirstQueue", false, false, false);
        channel.BasicPublish("", "FirstQueue", false, null, Encoding.UTF8.GetBytes("这是要发送的内容"));
        if (channel.WaitForConfirms(TimeSpan.FromSeconds(10)))//设置最长超时时间
        {
            //发送确认成功
        }
        else
        {
            //超时或失败,需要处理是否重发消息。
        }
    }
    复制代码

    2、通过事务机制处理的代码:

    复制代码
    using RabbitMQ.Client;
    using System.Text;
    
    using (var channel = Rabbit.Instance.DefaultConnection.CreateModel())
    {
        channel.TxSelect();
        channel.QueueDeclare("FirstQueue", false, false, false);
        channel.BasicPublish("", "FirstQueue", false, null, Encoding.UTF8.GetBytes("这是要发送的内容"));
        try
        {
            channel.TxCommit();
        }
        catch (Exception)
        {
            channel.TxRollback();
            //处理事务提交失败的逻辑。
        }
    }
    复制代码

    2、保障消息不丢失:RabbitMQ端

    对于RabbitMQ端的消息保障,我们人为可以处理的是,设置创建的队列或消息是否持久化。

    通过创建持久化的队列或消息,可以保障消息写入硬盘,重启时仍能还原信息。

    //第二个参数:是否持久化
    channel.QueueDeclare("FirstQueue", true, false, false);

    3、保障消息不丢失:接收方

    接收方主要是通过消息确认,来指示是否收到信息。

    复制代码
    var channel = Rabbit.Instance.DefaultConnection.CreateModel();
    
    var consumer = new EventingBasicConsumer(channel);
    consumer.Received += (model, ea) =>
    {
        var message = Encoding.UTF8.GetString(ea.Body.ToArray());
        Console.WriteLine("收到默认消息 {0}", message);
    };
    channel.BasicConsume(queue: "FirstQueue",
                          autoAck: true,
                          consumer: consumer);
    复制代码

    在以上代码中,通过指定autoAck可以自动回应收到信息,但这种自动模式,不一定能保证确认信息发回服务端。

    因此,要100分百保证,需要手动回应:

    复制代码
    var channel = Rabbit.Instance.DefaultConnection.CreateModel();
    
    var consumer = new EventingBasicConsumer(channel);
    consumer.Received += (model, ea) =>
    {
        var message = Encoding.UTF8.GetString(ea.Body.ToArray());
        Console.WriteLine("收到默认消息 {0}", message);
      try
        {
         //先处理业务,这里会有重复消费的问题,下一篇介绍。 channel.BasicAck(ea.DeliveryTag,
    false); } catch (Exception err) { //处理确认失败的情况。 } }; channel.BasicConsume(queue: "FirstQueue", autoAck: false, consumer: consumer);
    复制代码

    说明:

    为了避免消息丢失问题,消息的确认,最好在是业务处理完再进行确认。
    
    否则会出现第三方中介出问题时,或业务处理出问题时,或刚确认好消息,业务还没处理就系统异常,导致消息未消费就丢失的问题。

     

    4、发送方:补充:还有一种情况:通过交换机发送过去,但交换机没送到指定的队列时

    这时候应答也是正常的,但数据丢失,这种情况,是这样处理的:

     

    就两点:

    1、发送信息BasicPublish方法的第三个参数:mandatory设置为true。
    
    2、定义接收的回调:BasicReturn事件。

    总结:

    本篇简单介绍如何使用RabbitMQ消息时,做到消息的可靠性,不丢失。

  • 相关阅读:
    在node.js项目中安装配置mysql模块并进行增删改查
    OneDrive打不开了,怎么办?使用管理员身份也无效,分享解决办法如下
    GEE开发之Modis_NDVI的数据分析
    【云原生】Secret敏感信息存储
    1.6 泛化能力
    做室内装修设计需要什么资质,办理装修设计资质办理标准是怎样的
    JAVAEE初阶相关内容第十六弹--网络编程
    Linux下安装lrzsz/JDK/Tomcat/MySQL/Git/Maven/Redis
    Java面向对象三大特征 <2> -【继承】_ Java SE
    前端图片文件压缩方案
  • 原文地址:https://www.cnblogs.com/cyq1162/p/16603046.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号