【秒杀系统设计】

秒杀系统设计

一、访问层

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

二、中间转化层

复制代码
	1. nginx负载均衡,如果并发量超过了两三万的话,可以做nginx集群,一旦nginx集群,就得在其上层部署硬件级别的负载均衡器,比如F5或者LVS
	2. 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进行异步下单,完成后续的数据库更新,削峰填谷。
相关推荐
Da Da 泓2 小时前
LinkedList模拟实现
java·开发语言·数据结构·学习·算法
Larry_Yanan2 小时前
QML学习笔记(十五)QML的信号处理器(MouseArea)
c++·笔记·qt·学习·ui
Larry_Yanan4 小时前
QML学习笔记(十七)QML的属性变更信号
javascript·c++·笔记·qt·学习·ui
eqwaak05 小时前
Flask实战指南:从基础到高阶的完整开发流程
开发语言·后端·python·学习·flask
GilgameshJSS5 小时前
STM32H743-ARM例程9-IWDG看门狗
c语言·arm开发·stm32·单片机·嵌入式硬件·学习
月盈缺6 小时前
学习嵌入式的第四十一天——ARM——时钟与定时器
arm开发·学习
努力毕业的小土博^_^6 小时前
【深度学习|学习笔记】详细讲解一下 深度学习训练过程中 为什么 Momentum 可以加速训练?
人工智能·笔记·深度学习·学习·momentum
清风吹过6 小时前
少样本学习论文分享:多模态和类增量学习
论文阅读·人工智能·深度学习·学习·机器学习
Larry_Yanan6 小时前
QML学习笔记(十四)QML的自定义模块
开发语言·笔记·qt·学习·ui
wdfk_prog6 小时前
[Linux]学习笔记系列 -- lib/sort.c 通用的排序库(Generic Sorting Library) 为内核提供标准的、高效的排序功能
linux·运维·c语言·笔记·stm32·学习·bug