PHP实现秒杀设计


1. 查看接口是否仍有优化空间, 确保接口性能达到单机最佳
2. 若已达到最佳状态, 还需要对接口进行限流, 确保服务不会因为流量暴增而雪崩


### 特点


###### 抢购人数远多于库存, 读写并发巨大


###### 库存少, 有效写少 ( 抢购虽多, 但是形成有效订单少 )


###### 写需强一致性, 商品不能卖超 ( 确保库存和订单数一致 )


###### 读强一致性要求不高


### 难点


###### 稳定性难


1. 高并发下, 某个小依赖可能直接造成雪崩
2. 流量预期难精准, 过高也造成雪崩
3. 分布式集群, 机器多, 出故障概率高  
 减少第三方依赖, 同时自身服务部署也需做到隔离  
 压测, 降级, 限流方案, 确保核心服务可用  
 需健康度的检查机制, 整个链路避免单点


###### 准确性难


库存, 抢购成功数, 创建订单数之间的一致性


###### 高性能难


有限成本下需要做到极致的性能  
 缩短单请求访问路径, 减少IO  
 减少接口数, 降低吞吐数据量, 请求次数减少


### 需求


###### 扣库存


![在这里插入图片描述](https://img-blog.csdnimg.cn/20201208184544160.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)  
 预扣库存实现方案:


1. 先扣库存, 然后创建订单, 支付
2. 10分钟内不支付则取消订单, 避免不支付库存卖不出问题


![在这里插入图片描述](https://img-blog.csdnimg.cn/2020120818514146.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)  
 无IO:


1. 拆解, 扣库存与写订单分开
2. 用内存
3. 用本地内存  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20201208185809980.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)


###### 读商品信息


![在这里插入图片描述](https://img-blog.csdnimg.cn/20201209100720427.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)


###### 排队进度查看


![在这里插入图片描述](https://img-blog.csdnimg.cn/20201209101921111.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)


###### 读库存


![在这里插入图片描述](https://img-blog.csdnimg.cn/20201209102948449.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)


### 原理


##### 减而治之


###### CDN原理


![在这里插入图片描述](https://img-blog.csdnimg.cn/20201208173736755.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20201208173752248.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)


CDN, 内容分发网络 ( Content Delivery Network)


1. 缩短访问路径, 减少源站压力, 提高内容响应速度
2. 为源站提高安全保护  
 减少读的压力( 把订单详情页内容通过CDN下发到不同的节点 )  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20201208174029308.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20201208174119550.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20201208174213172.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20201208174258636.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)


###### Nginx限流


1. 按连接数限速, 即并发数 ( ngx\_http\_limit\_conn\_module )
2. 按请求速率限速, 根据IP限制单位时间内的请求数 ( ngx\_http\_limit\_req\_module )



配置

vim /etc/nginx/nginx.conf

在http模块里

http {

# 创建规则, 名称mylimit, 以用户的IP地址为key来限制请求速率1r/s, 申请空间为10m
limit_req_zone KaTeX parse error: Expected '}', got '#' at position 74: …rver { ... #̲ 应用规则, 在locatio… {
# burst缓存空间, 若没有该参数, 则会严格按照上面限制来执行, 超过其限制速率就会拒绝访问, 返回503错误, 若有该参数, 即设置了缓存空间, 超过其限制速率不会直接拒绝而是排队等待, 若缓存空间设置的比较大, 后边的请求会一直排队, nodelay参数就是应对突发流量时, 减少后边等待时间, 即1s允许2个请求
limit_req_zone=mylimit burst=1 nodelay;
}
}
}

重启 nginx

/usr/sbin/nginx -s reload

查看进程

ps aux | grep nginx

错误日志

tail -f /var/log/nginx/error.log


限流算法


1. 令牌桶算法  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/2020120817261787.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)
2. 漏桶算法  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/2020120817315729.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MjYxMTMw,size_16,color_FFFFFF,t_70)
3. 计数器  
 单位时间计数器计数即可, 一般在应用程序中写的较多


###### 异步队列


消息队列实际为链表, 头插尾出, 先进先出, 高并发下容易发生堵塞, 为避免消息丢失, 可通过写入实时消息队列进行延时处理  
 实时队列: 根据数据插入的前后顺序, 依次取出  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20201208180002504.png)  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值