死信队列的作用
??使用 RabbitMQ 的时候可能会碰到以下几个问题:
- 消费者端调用了
basicNack 或者 basicReject ,并且没有进行 requeue ,如果没做其他措施的话,这个消息也就丢失了。 - 消息在队列的存活时间超过设置的
TTL 时间。 - 消息队列的消息数量已经超过最大队列长度。
??以上几个问题都会导致消息丢失,消息丢失的代价可大可小,视自己业务情况而定,有些业务如果消息丢失无所谓的话就不用理睬,相信大部分业务都是不允许丢失的。死信队列 的出现就可以解决以上三个问题,当以上三个问题出现时,消息不会丢失,会重新放入死信队列,至于如何处理死信队列中的消息就看自己公司的业务了。
如何配置死信队列
??死信队列其实本身也是普通的队列,只是在逻辑上赋予了它特殊的含义,需要绑定对应的死信交换机,与队列概念一样,也是普通的交换机,赋予了死信 的含义。那么整体流程如下:
-
创建死信交换机 data:image/s3,"s3://crabby-images/33120/33120ebaeae761ece8feb6cb2996709d024d5b76" alt="image-20210714152844371" -
创建死信队列 data:image/s3,"s3://crabby-images/662c1/662c1a423ba7fc348b0fddc55043d58216c9e01a" alt="image-20210714152945089" -
在死信交换机中绑定死信队列与死信交换机 data:image/s3,"s3://crabby-images/528e0/528e00defec061f66699bea8a29383236efdbe2e" alt="image-20210714153118816" -
创建业务交换机 data:image/s3,"s3://crabby-images/ef497/ef497d0bf6a5315682ada78a4994f191e57f04cf" alt="image-20210714153143466" -
创建业务队列并关联 死信交换机与死信队列 data:image/s3,"s3://crabby-images/6c731/6c73120be6f3701443828e3786b8dabb0954d851" alt="image-20210714153228905" -
在业务交换机中绑定业务队列与业务交换机 data:image/s3,"s3://crabby-images/c8c26/c8c26a84181eb6fe1aa14426c9f7f1d95692e2e0" alt="image-20210714153256693"
以上操作可以在 Web 上操作,亦可在项目中用代码实现。
??步骤 5 中的 x-dead-letter-exchange 指定死信交换机、x-dead-letter-routing-key 指定路由到指定 Queue 的路由 key,一般配置跟 Queue 一样。
??一般情况下会为每一个业务队列都配置一个相对应的死信队列,也可以多个业务队列共用一个死信队列。要注意的是业务队列和死信队列的交换机要区分开。
样例
??配置如下:
spring:
rabbitmq:
host: localhost
port: 5672
username: admin
password: 123456
virtual-host: 'example'
publisher-confirm-type: correlated
publisher-returns: true
listener:
simple:
acknowledge-mode: auto
prefetch: 100
default-requeue-rejected: false
retry:
enabled: true
max-attempts: 3
initial-interval: 3000
max-interval: 10000
multiplier: 2
??消费者端简单抛个异常:
data:image/s3,"s3://crabby-images/5b5d5/5b5d52789d0d9d047f06cb0729463841d0815288" alt="image-20210714154050624"
data:image/s3,"s3://crabby-images/9db78/9db784ebf0376a25997ace821f0d99ad4e0f53a6" alt="image-20210714154109810"
data:image/s3,"s3://crabby-images/ed2d2/ed2d25dd555b5f270698bba6597dbe2fb5e5c506" alt="image-20210714154121044"
??最终都跑到死信队列了。
|