| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> Redis实战案例及问题分析之秒杀功能优化(异步下单、Redis消息队列) -> 正文阅读 |
|
[大数据]Redis实战案例及问题分析之秒杀功能优化(异步下单、Redis消息队列) |
原本存在问题原本的优惠券秒杀业务中,查询优惠券、查询订单、减库存、创建订单都是直接访问的MySQL数据库,其中减库存和创建订单是写操作,当高并发的时候会给数据库造成较大的压力。 基于阻塞队列的异步解决办法:?在redis中: 利用string结构保存优惠券的库存 利用set集合(可以存多个值且不可重复)来实现一人一单功能: ?同时利用lua脚本实现上述两个操作的原子性 ?基于Redis完成秒杀资格判断需求:
①
新增秒杀优惠券的同时,将优惠券信息保存到
Redis
中
②
基于
Lua
脚本,判断秒杀库存、一人一单,决定用户是否抢购成功
?基于阻塞队列实现秒杀异步下单
③
如果抢购成功,将优惠券
id
和用户
id
封装后存入阻塞队列
④
开启线程任务,不断从阻塞队列中获取信息,实现异步下单功能
?Redis消息队列实现异步秒杀基于JVM实现的异步秒杀存在两个问题,一个是JVM内存有限,当有大量并发的时候就有可能超过JVM内存上限,二是数据安全问题,JVM的阻塞队列没有持久化机制,当出现宕机或者发生异常时,订单就会丢失。所以使用消息队列解决这两个问题: ?基于List模拟消息队列?队列是入口和出口不在一边,因此我们可以利用:LPUSH 结合 RPOP、或者 RPUSH 结合 LPOP来实现。不过要注意的是,当队列中没有消息时RPOP或LPOP操作会返回null,并不像JVM的阻塞队列那样会阻塞并等待消息。因此这里应该使用BRPOP或者BLPOP来实现阻塞效果。 基于List的消息队列有哪些优缺点? 优点:
缺点:
?基于PunSub的消息队列消费者可以订阅一个或多个channel,生产者向对应channel发送消息后,所有订阅者都能收到相关消息。
?
SUBSCRIBE channel [channel]
:订阅一个或多个频道
?
PUBLISH channel msg
:向一个频道发送消息
?PSUBSCRIBE pattern[pattern]
:订阅与pattern格式匹配的所有频道
? 基于PubSub的消息队列有哪些优缺点? 优点:
缺点:
基于stream的消息队列?Stream 是 Redis 5.0 引入的一种新数据类型,可以实现一个功能非常完善的消息队列。 ? 注意:当我们指定起始ID为$时,代表读取最新的消息,如果我们处理一条消息的过程中,又有超过1条以上的消息到达队列,则下次获取时也只能获取到最新的一条,会出现漏读消息的问题。 STREAM类型消息队列的XREAD命令特点:
?基于stream的消息队列——消费者组?消费者组(Consumer Group):将多个消费者划分到一个组中,监听同一个队列。具备下列特点: ? ? ? STREAM类型消息队列的XREADGROUP命令特点:
?基于stream的消息队列实现异步秒杀下单?? |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/16 1:40:44- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |