IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Nginx+lua实现秒杀系统架构 -> 正文阅读

[系统运维]Nginx+lua实现秒杀系统架构

能今天做好的事就不要等到明天。以梦为马,学习趁年华。


前言

没有任何文笔,都是写给自己看的,本篇是笔者在实践及学习对秒杀系统架构的思考,本篇没有任何废话,都是笔者在设计过程的遇到的问题及相关的解决方案

一、秒杀业务特点

1.瞬时高并发

秒杀商品库存一定是有限且价格超级优惠,一定会在秒杀开始的瞬间就会结束,如最近的武汉消费券,基本上在1s内就瞬间抢空了。

2.热点数据

秒杀商品一定会有很多人关注,访问频率会非常高,它一定属于热点数据。

3. 读多写少

秒杀业务是典型的读多写少的场景,假设秒杀商品是iPhone13秒杀价格是1000元,
但库存只有100个,来抢购的人一定是数以几十万计,但最后能成功下单的用户只有100个,
即订单系统实际写数据的次数只有100次。

二、技术难点

1 . 数据一致性

根据以上分析的3个业务特性,为了解决瞬时大量读及系统吞吐量问题,
秒杀商品必须要用缓存技术,那么该如何在不影响系统吞吐量情况下解决缓存和DB一致性问题?
这里缓存技术我会选用业界主流的redis,根据以下库存超卖解决方案,
当库存扣减成功后,采用MQ异步解耦方式发消息给订单服务处理实际下单扣减库存业务,
只要保证MQ消息可靠性(不丢消息)就可以实现缓存和DB数据的最终一致性。
这里我会选用RocketMQ(因为它能保证消息可靠性及消费端限流)。

2. 库存超卖

超大瞬时高并发下,如何保证库存不超卖?
扣减库存需要做2件事:1. 扣减库存;2. 判断库存是否足量。如果能保证这2件事的原子性就可以
保证库存不超卖问题,那么新问题来了如何在分布式环境下保证扣减库存和判断库存的原子性?
对此也有2个方案:1.分布式锁;2.redis+lua脚本(lua脚本在redis可以保证原子性)。
分布式锁是悲观锁会阻塞其他请求,如果考虑性能这块则我会选择redis+lua脚本的方案。

三、秒杀注意事项

1.数据预热

这里会选用redis的hash来作为热key存放秒杀商品(sku_id:库存数;start:0,布尔值表示活动是否开始),
会在活动开始前刷到存放热key的redis中,当活动时间开始后通过定时job将start值刷为1活动正式开始,
这里定时job我会选择xxl-job。

2.请求承载

对于超大流量下业务,需要考虑系统的负载均衡、并发承载数、最大连接、重试策略、熔断机制及系统的隔离等等问题,
这些需要调研数据来圈定负载均衡、并发承载数及最大连接数的边界,
这里可以将秒杀服务单独抽离出来,即可以保证服务隔离性又方便其横向扩展保证他的承载能力,
我会选择阿里的Sentinel来灵活保证秒杀服务的可靠性,它支持限流、熔断、服务降级等策略、业务完全解耦及可视化的web界面。

3.请求拦截

我思考的主要分为3部分:
1. 前端页面:页面缓存,减少对后端服务压力 ;按钮置灰,防止用户重复提交;验证码,流量错峰(这个就特殊业务会用,如12306)。
2. nginx:流控,防止比预期大流量直接冲垮系统;白名单,防止用工具模拟请求恶意抢单;缓存,静态资源缓存,如图片、js等。
3. gateway: token鉴权,过滤无效请求;验签,防止用工具模拟请求恶意抢单。
4. Sentinel:流控、熔断及服务降级,粒度更细保护秒杀服务,保证秒杀服务的可靠性。

大厂会有专门的风控团队帮忙处理请求拦截问题。

四、微服务秒杀设计

根据以上业务分析和技术思考,我画下了如下的架构设计图:
请添加图片描述

补充说明以上的架构设计图:
一、系统瓶颈点
	1. 秒杀微服务性能瓶颈,需要预估最大支撑的流量,以便更好规划申请资源做横向扩展,正常单台tomcat的吞吐量约在2000左右(具体还得看业务复杂度,如果是只有时间戳吞吐量可以到4000);
	2. redis性能瓶颈,虽然单台redis号称吞吐量可以达到10W左右,但实际上吞吐量超过5W后就会有一定性能问题,也是需要预估最大支撑的流量来规划和申请资源;
	3. 订单服务性能瓶颈,由于秒杀服务会瞬间将秒杀商品的库存清空,这部分流量压力会通过MQ来转接给订单服务,则也是有概率直接压垮或影响订单服务性能,这里给方案是在mq的消费者端做限流。
	
二、缓存和DB数据最终一致性
	1. 首先要保证MQ的消息不丢失(rocketMQ可以保证消息可靠性);
	2. redis扣减库存不超卖(在分布式环境下lua脚本可以实现扣减库存和库存判断的原子性来保证库存不超卖);
	3. 保证了前2点则可以实现缓存和DB数据的最终一致性(由于在MQ的消费端有限流,则DB数据会有一定的延迟),
	   由于DB数据有延迟那么前端需要做一下轮训来获取用户秒杀的订单数据。

三、lua脚本业务
	1. 扣减库存,直接用hash里面的sku_id字段对库存做自减;
	2. 判断库存,判断库存是否 > -1 (是否还有库存);
	3. 根据判断库存结果返回,是 则直接返回 1 , 否 则返回 0 并对sku_id做自增。
对于以上lua脚本业务设计的说明:
	为什么不先查库存?
		直接扣库存是为了让lua中执行的指令尽量少,假设库存有100个,那么它 100 次执行都是只做了3件事,
		库存超卖时才会额外做一次自增,这一次前端也能感知到库存为0了,提交按钮也会置灰因为,
		如果是先查库存、扣库存、判断库存、返回结果,则每次下单成功lua执行的指令都有4个没有以上高效。
	其他说明:判断库存时推荐使用 > -1 它的效率比 >=0 高。 

四、其他额外问题
	诸如 分布式事务(下单和减库存)、订单号生成(分布式下唯一id)、CDN内容分发、订单数据量大需要做分表分库策略、复杂数据检索等等问题,
	都不是由于秒杀服务导致(即便没有秒杀服务系统也会遇到的问题),则不在秒杀架构设计中涉及。

五、Nginx+lua秒杀设计

在B站上了解到大厂的秒杀架构基本上都是直接使用nginx+lua实现,追求最高的吞吐量,按照这个思路我将我之前画好的图改造一下(即是去掉链路中的gateway和秒杀微服务,让nginx集成lua),具体的架构图如下:
请添加图片描述

改造后的优点:
	1. 更加轻量,nginx能够非常好集成lua,不需要额外加上秒杀微服务;
	2. 链路更短,处理秒杀业务lua离客户请求更近了,优化了一些网络io消耗,性能也更优;
落地问题:
	1. 鉴权问题,去掉gateway如何鉴权? lua也是可以继承JWT做鉴权;
	2. 限流问题,去掉Sentinel如何限流? lua+redis可以更高效实现分布式漏桶算法限流;
	3. 消息投递问题,lua中有模块支持各种MQ的消息投递。

基于以上分析 nginx+lua的方式实现的秒杀是吞吐量最高的。

注意:这种本人没有实践过。

总结

以上就是我在设计秒杀系统的时候对业务、技术等多个维度的衡量和思考,以及我是如何做技术选型的。

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2021-12-23 16:04:59  更:2021-12-23 16:06:21 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 3:54:44-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码