1. 事务
AMQP(高级消息队列协议)实现了事务机制,主要用于确保消息的原子性发布和确认。换言之,它允许你将多个操作(如发送消息、确认消息)绑定在一起,要么全部成功,要么全部失败。
发送消息示例
在 Spring Boot 中,我们可以结合 @Transactional 注解来实现本地事务与 RabbitMQ 事务的同步。注意,如果业务逻辑中抛出异常,整个事务(包括数据库和消息发送)都会回滚。
@RestController
@RequestMapping("/producer")
public class ProducerController {
@Resource(name = "transRabbitTemplate")
private RabbitTemplate transRabbitTemplate;
@Transactional
@RequestMapping("/trans")
public String trans() {
// 发送第一条消息
transRabbitTemplate.convertAndSend("", Constants.TRANS_QUEUE, "trans test ---> 1");
// 模拟业务异常,导致事务回滚,第二条消息不会发送
int num = 5 / 0;
transRabbitTemplate.convertAndSend("", Constants.TRANS_QUEUE, "trans test ---> 2");
return "发送成功";
}
}
注意: Spring Boot 的 RabbitMQ 自动配置默认会开启 Publisher Confirms(发布者确认),但 RabbitMQ 不允许同一个通道同时使用事务模式和确认模式。因此,必须显式禁用 Publisher Confirms。
spring:
rabbitmq:
publisher-confirm-type: none
publisher-returns:


