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的性能

相关推荐
星期天要睡觉19 小时前
MySQL 综合练习
数据库·mysql
Y40900119 小时前
数据库基础知识——聚合函数、分组查询
android·数据库
零千叶20 小时前
【面试】RabbitMQ 常见问题
面试·职场和发展·rabbitmq
kobe_OKOK_20 小时前
rabbitmq 入门知识点
分布式·rabbitmq·ruby
王嘉俊92520 小时前
深入浅出 全面剖析消息队列(Kafka,RabbitMQ,RocketMQ 等)
分布式·kafka·消息队列·rabbitmq·rocketmq
JosieBook20 小时前
【数据库】MySQL 数据库创建存储过程及使用场景详解
数据库·mysql
处女座_三月20 小时前
改 TDengine 数据库的时间写入限制
数据库·sql·mysql
酷ku的森20 小时前
Redis中的hash数据类型
数据库·redis·哈希算法
Arva .20 小时前
Redis
数据库·redis·缓存