一、前言
RabbitMQ我们经常的使用,但是它有很多高级的特性我们也需要熟练的掌握才能应对现实场景中复杂的业务逻辑。
二、面试
面试官:小奇是吧,我们开始面试吧
我:快点吧,早就饥渴难耐了
面试官:有用过RabbitMQ吗
我:用过
三、RabbitMQ发送消息长时间没人处理过期怎么办?
面试官:RabbitMQ发送消息长时间没人处理过期怎么办?
我:消息长时间没人处理过期了我们为了不影响正常的交换机使用,我们可以将过期的消息放到一个死信交换机中,然后这个交换机绑定一个队列就是死信队列,然后通过一个专门的消费者来处理这些过期的消息
面试官:只有消息到达过期时间没有被消费会进入死信交换机吗,还有其他的情况吗
我:消息成为死信一共有三种情况。
1:队列消息长度达到限制。
2:消费者拒收消息,并且不将消息放入原来的队列中让他重新发送。
3:原队列存在消息过期设置,消息达到超时时间未被消费。
面试官:我们怎么定义一个死信交换机和死信队列绑定呢?
我:我们可以通过x-dead-letter-exchange和x-dead-letter-routing-key两个参数来配置好死信交换机的名称,和死信交换机与死信队列之间的路由键名称。
四、TTL是什么?
面试官:TTL是什么?
我:TTL全称Time To Live(存活时间/过期时间),是mq中用来设置过期时间的。
面试官:我们一般怎么设置过期时间,用哪些方式?
我:我们有两种设置过期时间的方式,一个是对单个消息设置过期时间,一个是对一个队列设置过期时间,这样的话发送到队列中的消息都遵循那个过期时间。
1:队列设置过期时间:x-message-ttl,单位:ms(毫秒),这样的话进入队列的所有消息都遵循这个过期时间。
2:单个消息设置过期时间:expiration,单位:ms(毫秒),这样的话只有这条消息有过期时间。
面试官:那如果我即给单条消息设置了时间又给队列设置了时间会怎么样?
我:那样的话根据最短的那个时间来。
五、RabbitMQ延时队列怎么设计?
面试官:那你知道延时队列吗,一般都用来做什么场景下的需求呢?
我:知道,延时队列一般就是发送消息到MQ中后,消费者不要第一时间去处理,比如我们点外卖的时候我们下单成功了,这个时候库存已经减了,但是我们还没有支付,如果我们一直不支付的话,过30分钟订单就自动取消了,然后库存又恢复了。
面试官:那RabbitMQ有延时队列吗,如果让你自己设计一个延时队列怎么设计呢?
我:RabbitMQ中没有提供延时队列的功能,但是我们可以使用TTL+死信队列来实现延时队列的功能。
面试官:可以呀小伙子,这块掌握的不错
我:还行还行,都是日常的积累
面试官:小伙子真厉害啊,RabbitMQ掌握的非常棒,你面试通过了,明天上岗吧
我:啊,这么急吗,我后面还有好多东西没有讲呢。
面试官:不着急,进来了以后慢慢听你讲,加班让你跟我讲
我:啊。。。这也太难了吧
六、总结
这里关于RabbitMQ还没有整理完毕,文章后面持续更新,建议收藏。
文章中涉及到的命令大家一定要像我一样每个都敲几遍,只有在敲的过程中才能发现自己对命令是否真正的掌握了。