MQ高级 有点累了 没有具体操作 只是大概的写一下自己的理解
具体文档day07-MQ高级
可靠性
如果要实现消息队列的可靠性 那么就得保证这三个 生产者 消息队列 消费者各自可靠
很简单的概念就没解释
LazyQueue 懒队列 就是不加载到内存 直接写入磁盘 更稳定 有点类似于在word里边自动保存 如果写入内存 就像写word 没保存但是突然卡退了 就会导致不可靠 感觉就像是解决这种问题的
消费者失败重试到最大次数后 会进行失败处理策略
1.直接丢了
2 重新入队
3 转给专人处理
所谓幂等性 就是x平方=x 就是多次执行结果不变 比如 查询 但是更新 显然不满足幂等性
解决幂等性(不让这个业务重复执行)有俩解决办法
一个就是写入唯一的消息id 但是这个不好 会改数据库
另一个就是自己写业务逻辑(代码判断)
兜底方案
简单 就是用定时器 定时查询状态 防止出现异常
延迟消息
死信交换机:收集无效消息
利用死信交换机完成延迟消息:就是比如我要延时5分钟 我就把消息设置5分钟的TTL 然后过了时间就会转入死信交换机 通过交换机在转给消费者
缺点就是 很明显 无法控制时间 通过死信交换机在转发的时间没法控制
DelayExchange:RabbitMQ社区提供了一个延迟消息插件来实现相同的效果。就是为了解决上边完成延迟消息缺点的更优解。
超时订单 就是利用mq 发延时消息15分钟 然后设置监听