RabbitMQ学习第七章:消息确认机制之事务机制
RabbitMQ消息确认机制之事务机制。
RabbitMQ中,我们可以通过持久化数据 解决RabbitMQ服务器异常
的数据丢失问题。
问题:生产者将消息发送出去,消息到底有没有到达RabbitMQ服务器
默认的情况下是不知道的。
两种方式:
1.AMQP实现了事务机制,类似mysql的事务。
事务机制三个方法:
txSelect:用于将当前changel设置成transation模式。
txCommit:用于提交事务。
txRollback:回滚事务。
通过txSelect开启事务后,便可以发送消息给RabbitMQ服务器,通过
txCommit提交成功,如果提交之前出现了异常,就txRollback回滚。
问题:开启-提交-回滚,每次提交,都相当于一次请求,降低了消息的吞吐量,
因为走的通信太多,大量消息就会大量请求服务器,很耗时。
例:
生产者
消费者:
图中发送消息逻辑没有问题,所以发送的消息会成功
如果生产者代码中执行了错误的逻辑,比如:
这时候再发送消息,就会失败,并回滚。
2.confirm模式。
生产者端confirm实现原理:生产者将信道设成confirm模式,一旦信道进入到
confirm模式,所有在该信道发布的消息都会指派一个唯一消息id,一旦消息被投
递到所匹配的队列之后,就会发送一个确认给生产者(包含消息id),
这就使得生产者知道了这个消息已经正确到达了队列。如果消息和队列是可持久
化的,确认消息会将消息写到磁盘后在发出。
Confirm模式最大的好处在于它是异步的。
开启confirm模式:channel.confirmSelect();
编程模式:
2.1.普通:发过去(一条)后会调用waitForConfirms()(串行)。
2.2.批量:发过去(一批)后会调用waitForConfirms()(串行)。
2.3.异步confirm:提供一个回调方法,服务端confirm一条或多条后客户端会调用。
例:
Confirm普通模式 生产者:
消费者:
Confirm批量模式(普通模式+for循环) 生产者:
消费者:
confirm模式-异步
channel对象提供的confirmListener()回调方法只包含deliveryTag(当前channel发出
的消息序号),我们需要自己为每一个channel维护一个unconfirm的消息序号集合,
每publish一条数据,集合中元素加1,每回调一次handleAck方法,unconfirm集
合删掉相应的一条(multiple=false)或多条(multiple=true)记录,从程序运行效
率上看,这个unconfirm集合最好采用有序集合SortedSed存储结构
RabbitMQ学习第七章:消息确认机制之事务机制的更多相关文章
- SpringBoot 整合 RabbitMQ(包含三种消息确认机制以及消费端限流)
目录 说明 生产端 消费端 说明 本文 SpringBoot 与 RabbitMQ 进行整合的时候,包含了三种消息的确认模式,如果查询详细的确认模式设置,请阅读:RabbitMQ的三种消息确认模式 同 ...
- 消息队列RabbitMQ(三):消息确认机制
引言 RabbitMQ的模型是生产者发送信息到 Broker (代理),消费者从 Broker 中取出信息.但是生产者怎么知道消息是否真的发送到 Broker 中了呢?Broker 又怎么知道消息到底 ...
- rabbitmq学习(七) —— springboot下的可靠使用
前面的学习都是基于原生的api,下面我们使用spingboot来整合rabbitmq springboot对rabbitmq提供了友好支持,极大的简化了开发流程 引入maven <depende ...
- Java基础知识二次学习--第七章 容器
第七章 容器 时间:2017年4月27日15:08:30 章节:07章01节~07章04节 视频长度:20:21 +12:38 +3:55 +2:57 内容:容器API 心得: Java API ...
- C#高级编程 (第六版) 学习 第七章:委托和事件
第七章 委托和事件 回调(callback)函数是Windows编程的一个重要方面,实际上是方法调用的指针,也称为函数指针. .Net以委托的形式实现了函数指针的概念,.Net的委托是类型安全的. 委 ...
- MQ确认机制之事务机制------tx
一:介绍 1.介绍 在前面的说的模式中会出现一个问题. 就是生产者将消息发送出去到底有没有到达rabbitMq,默认情况下是不知道. 有两种解决方式. AMQP实现事务机制 Confirm机制. 这里 ...
- JMS 基本可靠性机制 和 事务机制
4.3.1 基本可靠性机制4.3.1.1 控制消息的签收(Acknowledgment) 客户端成功接收一条消息的标志是这条消息被签收.成功接收一条消息一般包括如 下三个阶段:1.客户端接收消息:2. ...
- rabbitmq for C#的异步消息确认机制
代码: using (var conn = RabbitmqHelper.GetConnection()) { using (var channel = conn.CreateModel()) { / ...
- RabbitMQ学习笔记2-理解消息通信
消息包含两部分:1.有效载荷(payload) - 你想要传输的数据.2.标签(lable) - 描述有效载荷的相关信息,包含具体的交换器.消息的接受兴趣方等. rabbitmq的基础流程如下: Ra ...
- rabbitMQ学习笔记(七) RPC 远程过程调用
关于RPC的介绍请参考百度百科里的关于RPC的介绍:http://baike.baidu.com/view/32726.htm#sub32726 现在来看看Rabbitmq中RPC吧!RPC的工作示意 ...
随机推荐
- 用js实现元素两个元素位置对齐
一.问题描述 使得填表单位那一行字与下面的表格左对齐,对表格使用css中的margin:auto实现了居中,但是对那一行字(用div包裹的)使用margin:auto不生效:并且2021年下面对应的月 ...
- vue 使用mixin
mixin 混入 混入提供了一种非常灵活的方式,来分发Vue组件中可以复用的功能,一个混入对象可以包括任意的组件选项,当组件使用混入对象时,所有的混入对象的选项 将被'混合'进入该组件本身的选项,混入 ...
- js把一个数组的数据平均到几个数组里面
arr 原始数组数据 count 每个数组里面元素个数 function splitIpLit(arr,count) { let i = 0; let newArr = []; while(i &l ...
- java读取apk、ipa包名、版本名、版本号等信息
package com.gymexpress.exerciseservice.controller;import com.gymexpress.commonmodel.controller.BaseC ...
- QT-groupBox组件内的组件失去交互功能
属性设置: 首先 然后 可以实现.
- 【GROMACS】分子动力学模拟①——环境搭建
系统环境 Win11 22H2 企业版 开启虚拟化.window subsystem for liunx等虚拟机相关的功能 应用商店中安装WSL2 安装步骤 打开Ubuntu,输入sudo apt f ...
- [Docker-1自顶向下学习Docker
本文目录: 什么是DOCKER? 什么是容器? 什么是DOCKER镜像? DOCKER有什么使用场景和优势? 流程图一:从中央仓库拉取镜像并部署 流程图二:上传镜像到中央私库 结语 什么是DOCK ...
- 亲测:一个完整Vue开发环境搭建。
参考博客飞机: https://www.cnblogs.com/zhaomeizi/p/8483597.html
- 三、核心实战-服务Service-Ingress
Service 将一组Pods公开为网络服务的抽象方法. 暴露deployment只能在集群内访问是ClusterIP,可以集群外访问是NodePort,默认端口分配是30000-32767之间 ku ...
- sql 行转列分析 以后再也不用记了
表scores 请转成的横表是这样子的: // ::::我们来分析下:首先 姓名这一列肯定是不重复的姓名[重复也没办法了 这需求只能这样了] 因此 我们用group by [姓名] 然后姓名这一列就有 ...