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

相关推荐
2301_80387561几秒前
如何高效实现多用户通知系统而不造成数据库冗余
jvm·数据库·python
Chasing__Dreams1 分钟前
Redis--基础知识点--29--HyperLogLog
数据库·redis·缓存
weixin_580614001 分钟前
SQL如何统计分组内的最高和最低值_MAX与MIN聚合应用
jvm·数据库·python
baidu_340998824 分钟前
JavaScript中函数调用的四种模式及其this绑定优先级表
jvm·数据库·python
吕源林5 分钟前
SQL在JOIN语句中过滤非必要字段_减少传输开销与查询执行时间
jvm·数据库·python
gududexiao6 分钟前
RabbitMQ 的介绍与使用
分布式·rabbitmq·ruby
Kristrina8 分钟前
RabbitMQ高级特性----生产者确认机制
分布式·rabbitmq
qq_424098568 分钟前
如何在 Go 方法中正确修改切片类型
jvm·数据库·python
qq_3345635510 分钟前
如何利用分区进行并行DML_开启会话并行针对不同分区同时执行更新
jvm·数据库·python
绩隐金10 分钟前
SQL Server 开发系列(第八期):事务与并发控制(开发视角)——避免死锁与数据异常
数据库