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


![[附源码]Python计算机毕业设计Django的网上点餐系统](https://img-blog.csdnimg.cn/6aeb15d5074d4ac796003b50782decc1.png)















![[附源码]Python计算机毕业设计Django的高校课程知识库](https://img-blog.csdnimg.cn/e90ef7140082430a8e6b2640525a6b76.png)

