备份交换器,英文名称Alternate Exchange,简称AE,或者更直白的称之为“备胎交换器”。生产者发送消息的时候如果不设置mandatory参数,那么消息在路由失败的时候会被直接丢弃。如果设置了mandatory参数,就需要添加retrurnListener业务逻辑,增加生产者的代码负责度。如果既不想复杂生产代码,又不想消息丢失,那么可以使用备份交换器,可以将路由失败的消息存储在备份交换器队列里面,在需要的时候再去处理。
示例代码:
// 声明备份交换器和队列
channel.exchangeDeclare(alternateExchangeName, ExchangeTypes.FANOUT, true);
channel.queueDeclare(alternateQueueName, true, false, false, null);
channel.queueBind(alternateQueueName, alternateExchangeName, "");
// 声明主交换器和队列
// 给主交换设置备份交换器
Map<String, Object> map = new HashMap<>();
map.put("alternate-exchange", alternateExchangeName);
channel.exchangeDeclare(exchangeName, ExchangeTypes.DIRECT, true, false, map);
channel.queueDeclare(queueName, true, false, false, null);
channel.queueBind(queueName, exchangeName, "alternate.exchange");
// 发送消息routingKey和bindingKey不一致进入备份队列
channel.basicPublish(exchangeName, "alternate", null, "我要进入备份队列".getBytes());
对于备份交换器总结一下集中特殊情况:
1. 如果设置的备份交换器不存在,客户端和RabbitMQ服务器端都不会有异常,此时消息会丢失。
2.如果备份交换器没有绑定任何队列,客户端和RabbitMQ服务端都不会有异常,此时消息会丢失。
3.如果备份交换器没有任何匹配的队列(备份交换器类型为direct、topic、headers),客户端和RabbitMQ服务端都不会有异常,此时消息会丢失。
4.如果备份交换器和mandatory参数一起使用时,mandatory会失效。