MQ高级 可靠性-兜底-延迟消息

MQ高级 有点累了 没有具体操作 只是大概的写一下自己的理解

具体文档day07-MQ高级

可靠性

如果要实现消息队列的可靠性 那么就得保证这三个 生产者 消息队列 消费者各自可靠

很简单的概念就没解释

LazyQueue 懒队列 就是不加载到内存 直接写入磁盘 更稳定 有点类似于在word里边自动保存 如果写入内存 就像写word 没保存但是突然卡退了 就会导致不可靠 感觉就像是解决这种问题的

消费者失败重试到最大次数后 会进行失败处理策略

                 1.直接丢了

                 2 重新入队

                 3 转给专人处理

所谓幂等性 就是x平方=x 就是多次执行结果不变 比如 查询 但是更新 显然不满足幂等性

解决幂等性(不让这个业务重复执行)有俩解决办法

                 一个就是写入唯一的消息id 但是这个不好 会改数据库

                另一个就是自己写业务逻辑(代码判断)

兜底方案

简单 就是用定时器 定时查询状态 防止出现异常

延迟消息

死信交换机:收集无效消息

利用死信交换机完成延迟消息:就是比如我要延时5分钟 我就把消息设置5分钟的TTL 然后过了时间就会转入死信交换机 通过交换机在转给消费者

        缺点就是 很明显 无法控制时间 通过死信交换机在转发的时间没法控制

DelayExchange:RabbitMQ社区提供了一个延迟消息插件来实现相同的效果。就是为了解决上边完成延迟消息缺点的更优解。

超时订单 就是利用mq 发延时消息15分钟 然后设置监听

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值