当前位置: 首页 > news >正文

【秒杀系统设计】

秒杀系统设计

一、访问层

	1. (秒杀商品页)秒杀页面为静态页面,从而减少服务器的压力,服务端只需要一心的解决秒杀的请求即可2. (秒杀按钮)(1)活动前禁用按钮(2)点击后禁用按钮(3)增加滑动验证码(防止羊毛党)(4)排队机制,提高用户体验

二、中间转化层

	1. nginx负载均衡,如果并发量超过了两三万的话,可以做nginx集群,一旦nginx集群,就得在其上层部署硬件级别的负载均衡器,比如F5或者LVS2. nginx负载均衡到网关之后,网关(也可以做集群)可以根据客户端的负载均衡器比如rabbion,来进行客户端的负载均衡分发请求3. redis缓存(1)热点商品数据预热,防止大量请求访问,压垮数据库(2)lua脚本管理库存:用户秒杀下单时分好几步,第一步判断库存是否大于0,第二步减去业务库存,第三步替换库存三步,用lua脚本写成原子性的,防止线程不安全(3)防重复下单,利用redis的setNX命令,ip+token+商品信息作为key(4)分布式锁,setNX给锁加过期时间,为了如果锁一直不释放的话,不会出现死锁的情况。最终使用Redisson框架。Redisson的使用,引入依赖,连接redis,加有效时间锁,锁续期都没问题。5. 总结:3层负载均衡器:F5/LVS=>nginx=>网关=>客户端  就可以处理每秒10万以上的QPS的并发量6. 注意:限流(在nginx层做好限流、网关层设置限流、熔断机制)

三、mq消息队列

	mq消息队列秒杀成功之后,发送mq消息,再用mq进行异步下单,完成后续的数据库更新,削峰填谷。
http://www.lqws.cn/news/453853.html

相关文章:

  • Logback 在java中的使用
  • VS2022 C#【自动化文件上传】AutoFileUpload 新需求 V13
  • 从“数据困境”到“数据生态”:DaaS重塑三甲医院医疗数据治理
  • android 渲染流水线中的两个重要阶段:swapBuffers 和 DrawFrames
  • Unity技能编辑器深度构建指南:打造专业级战斗系统
  • 项目开发中途遇到困难的解决方案
  • 跑步还是快速走,瘦身分享
  • 【unitrix】 3.4 类型级逻辑运算(bit.rs)
  • 广州AR公司诚推广州华锐互动​
  • 常用 Docker 命令整理
  • 设置vscode使用eslint
  • SynchronizedMap 和 ConcurrentHashMap 的区别
  • EfficientVLA:面向视觉-语言-动作模型无训练的加速与压缩
  • Xilinx XC7A12T‑1CPG238I Artix‑7 FPGA
  • 08-Python文件处理
  • MySQL EXPLAIN中的key_len终极指南:精准掌握索引使用情况
  • 【unitrix】 3.5 类型级别的比较系统(cmp.rs)
  • 【机器学习实战笔记 12】集成学习:AdaBoost算法
  • 分布式系统中的 Kafka:流量削峰与异步解耦(二)
  • 高性能群集部署技术-Nginx+Tomcat负载均衡群集
  • Docker Swarm
  • 如何轻松地将音乐从 iPhone 传输到 Mac?
  • Element UI 表格中实现搜索关键字高亮的
  • 华为OD机考-亲子游戏-BFS(JAVA 2025B卷 200分)
  • OCCT基础类库介绍:Modeling Algorithm - Sewing
  • 如何正确处理音频数据:16位整数与32位浮点数
  • Agent轻松通-P3:分析我们的Agent
  • CppCon 2017 学习:Mocking Frameworks Considered
  • 您的元服务存在问题,不符合元服务UX设计规范
  • 从零开始:飞牛云NAS+Docker搭建WordPress全流程