91、RabbitMQ事务消息

RabbitMQ事务消息

通过对信道的设置实现

  1. channel.txSelect(); 通知服务器开启事务模式;服务端会返回Tx.Select-ok

  2. channel.basicPublish; 发送消息,可以是多条,可以是消费消息提交ack

  3. channel.txCommit() 提交事务

  4. channel.txRollback() 回滚事务

消费者使用事务:

  1. autoAck=false.手动提交ack,以事务提交或回滚为准:
  2. autoAck=true,不支持事务的,也就是说你即使在收到消息之后在回滚事务也是于事无补的,队列已经把消息移除了

如果其中任意一个环节出现问题,就会抛出IOException异常,用户可以拦截异常进行事务回滚,或决定要不要重复消息。

事务消息会降低rabbitmq的性能

相关推荐
DBWYX5 分钟前
MySQL 进阶 面经级
数据库·mysql
喝醉酒的小白19 分钟前
SQL Server:触发器
数据库
程序员 小柴1 小时前
RabbitMQ概述和安装
分布式·rabbitmq
银河金融数据库2 小时前
历史分钟高频数据
数据库·金融
男Ren、麦根2 小时前
MySQL 复制与主从架构(Master-Slave)
数据库·mysql·架构
嘉友3 小时前
Redis zset数据结构以及时间复杂度总结(源码)
数据结构·数据库·redis·后端
morganmin4 小时前
(一)MySQL常见疑惑之:select count(*)和select count(1)的区别
数据库·mysql
深圳厨神4 小时前
mysql对表,数据,索引的操作sql
数据库·sql·mysql
谁家有个大人4 小时前
数据分析问题思考路径
数据库·数据分析
小陈又菜4 小时前
MySQL-触发器
数据库·mysql·database·触发器