文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

100W并发秒杀系统架构

2024-12-03 03:00

关注

在秒杀商品时候,可能出现超卖。

1.2 秒杀的业务流程

秒杀的商品有热点商品和非热点商品,热点商品可能流量占整个的90%.

后台商品管理可以将商品加入到秒杀商品,根据商品访问量分位热点商品和非热点商品。

用户抢到商品支付,发货商品。超时不付款,订单取消。

二 秒杀架构

秒杀系统架构图

Lua脚本对JWT校验:

用户请求到达nginx,用lua脚本进行jwt校验,减少非法请求对服务器的访问。从而减少服务器压力。

2.1 静态页面处理

1. 后台将设置商品成为秒杀商品流程:

2. 商品数量修改,静态页面的同步(canal数据同步):

3. 静态页面的生成和删除:

2.3 将秒杀热点数据隔离

2.3.1 日志收集

用户访问商品详情,首先请求经过nginx,然后使用nginx和lua脚本对请求商品详情路径进行拦截,然后将请求商品数据发送到kafka。数据库接受到kafka数据,完成商品浏览数据收集。

2.3.2 数据分析

Apache Druid订阅Kafka从而获取商品的访问日志,druid能实时获取商品访问记录。druid支持sql,对数据进行分析。找出热点数据。

  1. # lua脚本发送给kafka日志格式 
  2.    "actime""2020‐4‐10 9:50:30",   
  3.    "uri""http://192.168.211.137/items/S1235433012716498944.html",   
  4.    "ip""119.123.33.231",    
  5.    "token""Bearer ITHEIMAOOPJAVAITCAST"  

2.3.3 热点数据隔离

可以采用定时任务(elastic-job)实时查询Druid,把近期访问量最多的商品放入redis缓存中。缓存中数据如下:商品库存,价格,名称等。

备注:

用户进行下单时候,在redis中就是热点商品,走热点下单。不在redis中不是热点商品,走服务直接下单。

在将热点商品放到redis中,需要根据商品的锁定字段,将商品锁定。然后再将商品信息放到redis中。用户抢购商品和热点商品放到redis中同时进行,导致库存混乱。

2.4 热点商品和非热点商品抢购流程

需要判断当前用户对当前商品24小时内是否抢过。判断抢购商品是冷商品还是热门商品。判断库存是否充足。

1. 非热点商品秒杀:

2. 热点商品秒杀:

三 流量监控

在秒杀项目中需要集成Sentinel进行限流操作。在秒杀过程中冷门商品变为热门商品时候,访问服务流量瞬间激增,需要采用Sentinel进行限流,保护服务的稳定性。

 

来源:花花和Java内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯