JAVA进阶之路-rabbitMQ 可靠性

rabbitMQ 可靠性的保证就由三个点保证,confrim retrun ack 三个 rabbitmq 有三个流程 如下:
在这里插入图片描述
三个流程通过不同的机制保证数据丢失后能重新发送,保证可靠性。
对应java代码:
confrim:

    //Confirm重发
        rabbitTemplate.setConfirmCallback((correlationData, ack, cause) -> {
        		//虽然需要判断ack 但是有点不理解 如果进了confirm 那不就是需要重发嘛?难道还有进了confirm ack还是为true情况吗?
   				if(!ack){
   				 //重发 
   				 rabbitTemplate.convertAndSend(exchangeName, routingKey, JSONUtils.toString(correlationData.getReturnedMessage()), correlationData);
				// correlationData 这个参数 需要再提供者发送消息时候进行创建并发送过来 这时候confirm就能接收到你提供者发送时候创建的correlationData 
   				}else{
   				
   				}
        });

return:

		// return 重发
        rabbitTemplate.setReturnCallback((message, replyCode, replyText, exchange, routingKey) -> {   			logger.error("进入callback{}_{}", exchange, routingKey);
                CorrelationData correlationData = new CorrelationData();
                correlationData.setReturnedMessage(message);
                correlationData.setId("1");// 在做这个重发时  有些消息是不需要去做重发得 所以可以通过id 自己设置标识来跳过这次消息重发
                rabbitTemplate.convertAndSend(exchange, routingKey, JSONUtils.toString(message.getMessageProperties()), correlationData);

        });

ack:

// ack 完成此次消息消费
channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);
// nack 拒绝此次消息消费 并需要重新发送进行消费
channel.basicNack(message.getMessageProperties().getDeliveryTag(), false,true);
```x


由此三步可以保证 rabbitmq 得可靠性
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值