MQ---第二篇

系列文章目录


文章目录

  • 系列文章目录
  • 一、RabbitMQ事务消息
  • 二、RabbitMQ死信队列、延时队列


一、RabbitMQ事务消息

通过对信道的设置实现

  1. channel.txSelect();通知服务器开启事务模式;服务端会返回Tx.Select-Ok
  2. channel.basicPublish;发送消息,可以是多条,可以是消费消息提交ack
  3. channel.txCommit()提交事务;
  4. channel.txRollback()回滚事务;
    消费者使用事务:
  5. autoAck=false,手动提交ack,以事务提交或回滚为准;
  6. autoAck=true,不支持事务的,也就是说你即使在收到消息之后在回滚事务也是于事无补的,队
    列已经把消息移除了
    如果其中任意一个环节出现问题,就会抛出IoException异常,用户可以拦截异常进行事务回滚,或决
    定要不要重复消息。
    事务消息会降低rabbitmq的性能

二、RabbitMQ死信队列、延时队列

  1. 消息被消费方否定确认,使用 channel.basicNack 或 channel.basicReject ,

你可能感兴趣的:(rabbitmq)