秒杀系统设计

场景

你的商城正在策划了一期秒杀活动,活动在第五天的 00:00 开始,仅限前 200 名,那么秒杀即将开始时,后台会显示用户正在疯狂地刷新 APP 或者浏览器来保证自己能够尽量早的看到商品。

现象

  • 只有固定人数的人可以购买成功
  • QPS典型的瞬间波峰
  • 用户对请求结果延迟感稍微放宽松

面对的挑战

  • 现有业务的影响(独立域名、服务解决)
  • 高并发时,应用服务器和数据库压力
  • 超卖,卖出产品数量多于已有数量
  • 刷单,每个用户抢到多个订单
  • 无效刷新点击,用户在系统卡顿时,会进行连续点击
  • 时延 ,需要2-3s内返回结果,不能直接返回404

设计核心关注点

  • 有效数据总是少量,需要在上层拦截住大部分无效数据
  • 使用队列,进行异步处理、解耦合、削峰填谷

数据流向图

image.png

各个层次优化方案

1 浏览器层面

  • 按钮置灰
  • 限时提交一次,x秒内只允许提交一次请求
  • 页面内容静态化
  • 下单URL动态化

2 Nginx层面

  • 由于登录属性,可对uid做请求计数和去重,限制访问次数,做页面缓存。(分布式中同uid多后端无法去重)

3 业务服务层面

  • 通过队列只接受固定请求数,每次透传固定数量到数据层进行请求
  • 多于固定数的请求,直接返回秒杀完毕
  • 业务逻辑异步,比如下单业务、支付业务、统计数据业务等

4 数据层面

  • 悠哉悠哉的工作即可

Q&A

1 架构中,其实压力最大的反而是站点层,假设真实有效的请求数有1000万,不太可能限制请求连接数吧,那么这部分的压力怎么处理?

  • 站点层是可以通过加机器扩。
  • 如果机器不够,进行降级,避免整个系统崩溃。

2 “控制了10w个肉鸡,手里有10w个uid,同时发请求” 这个问题怎么解决哈?

  • 服务层写请求队列控制

3 如果队列处理失败,如何处理?肉鸡把队列被撑爆了怎么办?

  • 队列失败概率很低。最坏的情况下,缓存了若干请求之后,后续请求都直接返回“结束”

4 站点层过滤的话,怎么处理多台服务器集群经过负载均衡器将相同用户的响应分布到不同服务器的情况呢?还是说将站点层的过滤放到负载均衡前?

  • 在nginx层做负载均衡,让一个uid的请求尽量落到同一个机器上

5 不同的用户浏览同一个商品 落在不同的缓存实例显示的库存完全不一样 请问怎么做缓存数据一致或者是允许脏读?

  • 目前的架构设计,请求落到不同的站点上,数据可能不一致(页面缓存不一样),这个业务场景能接受。但数据库层面真实数据是没问题的。

参考链接:

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