死信:无法被消费的消息,称为死信。
如果死信一直留在队列中,会导致一直被消费,却从不消费成功,专门有一个存放死信的队列,称为死信队列(DDX, dead-letter-exchange)。
死信的几种来源:
消息TTL过期(time to live,存活时间,可以用在限时支付消息)
队列达到最大长度(队列满了,无法路由到该队列)
消息被拒绝(basic.reject / basic.nack),并且requeue = false
准备环境配置
准备MQ的队列和环境
正常交换机
★正常队列(最长队列5) ----正常消费者,拒绝消息
★tt队列(过期时间60秒) ----没有消费者
死信交换机
★死信队列
主要配置文件如下:
@Configuration
public class DeadConfig {
/* 正常配置 **********************************************************************************************************/
/**
* 正常交换机,开启持久化
*/
@Bean
DirectExchange normalExchange() {
return new DirectExchange("normalExchange", true, false);
}
@Bean
public Queue normalQueue() {
// durable: 是否持久化,默认是false,持久化队列:会被存储在磁盘上,当消息代理重启时仍然存在,暂存队列:当前连接有效
// exclusive: 默认也是false,只能被当前创建的连接使用,而且当连接关闭后队列即被删除。此参考优先级高于durable
// autoDelete: 是否自动删除,当没有生产者或者消费者使用此队列,该队列会自动删除。
Map<String, Object> args = deadQueueArgs();
// 队列设置最大长度
arg