redis实现秒杀场景

    秒杀活动是绝大部分电商选择的低价促销,推广品牌的方式。不仅可以给平台带来用户量,还可以提高平台知名度。一个好的秒杀系统,可以提高平台系统的稳定性和公平性,获得更好的用户体验,提升平台的口碑,从而提升秒杀活动的最大价值。

秒杀的特征

    秒杀活动对稀缺或者特价的商品进行定时,定量售卖,吸引成大量的消费者进行抢购,但又只有少部分消费者可以下单成功。因此,秒杀活动将在较短时间内产生比平时大数十倍,上百倍的页面访问流量和下单请求流量。

秒杀活动可以分为3个阶段:

    秒杀前:用户不断刷新商品详情页,页面请求达到瞬时峰值。

    秒杀开始:用户点击秒杀按钮,下单请求达到瞬时峰值。

    秒杀后:一部分成功下单的用户不断刷新订单或者产生退单操作,大部分用户继续刷新商品详情页等待退单机会。

    消费者提交订单,一般做法是利用数据库的行级锁。只有抢到锁的请求可以进行库存查询和下单操作。但是在高并发的情况下,数据库无法承担如此大的请求,往往会使整个服务blocked,在消费者看来就是服务器宕机。

秒杀前:

    将页面静态化,通过CDN缓存静态页面并通过浏览器缓存将用户点击页面请求流量拦截。

秒杀中:

    活动开始前将商品库存数据缓存到redis中,结构如图片所示,实行读写分离模式,服务机群读取redis中秒杀开始标志位goodsId_start,当等于0时直接返回,说明没有开始,活动开始后,数据控制模块将goodsId_start设为1,此时秒杀开始,读到的请求将goodsId_access+1,并进行后续操作。当goodsId_access数量等于goodsId_count时继续拦截请求,说明已无商品供下单。(可借助openresty,通过lua操作redis,达到更高的qps,redis缓存可以是json格式也可以是三个单独的key)。

秒杀拦截缓存结构

秒杀成功后:

    秒杀成功的请求进入到下一层服务,进行订单信息校验和库存扣除,实行主从模式,保证高可用。(秒杀前将商品库存数据提前写入缓存,结构如下图所示)。(此层是微服务架构)

redis库存缓存数据结构,hash结构

    订单校验通过并库存扣除成功的请求成功下单,redis lua代码如下,此代码通过redis.eval执行,当返回是传进去的参数时说明扣除成功。

扣库存redis脚本

库存扣除成功后异步操作数据库生成订单,通过redis list结构保存订单信息,入队命令为lpush。list结构如下图所示。

订单list数据结构

订单消息发送到list后,通过定时任务timer监听list消息,命令为brpop,阻塞出队命令,代码如下图所示。

接收订单消息并入库代码示例

数据模块:

    管理redis数据以及和mysql同步

    1,用户流量拦截层,用到redis读写分离,如果这一层借助openresty的话需要通过lua的redis客户端执行eval命令,确保原子性。

    2,问题1提到的流量拦截,可以适当多放行一些流量,比如设置成1.5倍,这样订单生成层操作redis的话可以做一些冗余,防止有失败情况导致库存剩余,抢购不完。

    3,借助redis进行流量拦截和扣减库存,需要保证redis的高可用,一般一主多从形式,从需要分布在不同机器上,通过sential机制确保自动主从切换。客户端需要支持主从切换。

    4,redis扣减库存成功后,定时任务处理消息并生成订单信息入库,此时redis和mysql会存在一定的延迟,比如一分钟左右,此时缓存和数据库不同步。

    5,当缓存无流量进入(库存扣减完)并且消息队列无消息时需要解决用户的订单取消问题,此时需要将释放的库存从新刷入缓存,供用户抢购。

    6,redis消息取出后就会删除,如果订单生成失败,库存就会不一致,需要通过步骤5实现库存回填(将可用库存刷入redis)。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 161,326评论 4 369
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,228评论 1 304
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 110,979评论 0 252
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,489评论 0 217
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,894评论 3 294
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,900评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,075评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,803评论 0 205
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,565评论 1 249
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,778评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,255评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,582评论 3 261
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,254评论 3 241
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,151评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,952评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,035评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,839评论 2 277

推荐阅读更多精彩内容