Préface
Regardez d'abord le mécanisme de rappel:
- Peu importe si le message est remis à l'échange ou non, le rappel ConfirmCallback est effectué et la livraison est réussie ack = true, sinon il est faux
- Si le commutateur correspond à la file d'attente avec succès, le rappel ReturnCallback ne sera pas effectué, sinon le rappel ReturnCallback sera effectué en premier, puis le rappel ConfirmCallback sera effectué
- Si le message est remis avec succès à l'échange mais ne correspond pas à la file d'attente, l'accusé de réception de rappel ConfirmCallback est toujours vrai
我的springboot版本springBootVersion = '2.2.1.RELEASE'
Confirmer le rappel
Vous devez d'abord configurer en yml:
publisher-confirm-type: correlated
/**
* 测试消息确认回调(必须在yml配置publisher-confirm-type: correlated)
*/
@GetMapping("sendConfirmCallback")
public Resp sendConfirmCallback() {
rabbitTemplate.setConfirmCallback((correlationData, ack, cause) -> {
System.out.println("ack:" + ack);
if (!ack) {
System.out.println("异常处理");
}
});
amqpTemplate.convertAndSend("test-queue", "测试ack确认模式");
return Resp.success("ok", null);
}
RetourRappel
Besoin d'être configuré en yml
publisher-returns: true
@Autowired
private AmqpTemplate amqpTemplate;
@Resource
private RabbitTemplate rabbitTemplate;
/**
* 启动消息失败返回,比如路由不到队列时触发回调
* 测试发布回调(必须在yml配置publisher-returns: true)
*/
@GetMapping("sendReturnCallback")
public Resp sendReturnCallback() {
RabbitTemplate.ReturnCallback returnCallback = (message, replyCode, replyText, exchange, routingKey) -> {
System.out.println("========returnCallback=============");
System.out.println("========returnCallback=============");
};
rabbitTemplate.setReturnCallback(returnCallback);
amqpTemplate.convertAndSend("test-", "测试发布回调模式");
return Resp.success("ok", null);
}