如何设计一个高可用、高并发秒杀系统 应该如何设计其高并发架构?

目录

(1)单块架构

(2)初步的高可用架构

(3)千万级用户量的压力预估

(4)服务器压力预估

(5)业务垂直拆分

(6)用分布式缓存抗下读请求

(7)基于数据库主从架构做读写分离

(8)总结

(1)单块架构

一般一个网站刚开始建立的时候,用户量是很少的,大概可能就几万或者几十万的用户量,每天活跃的用户可能就几百或者几千个。

这个时候一般网站架构都是采用单体架构来设计的,总共就部署3台服务器,1台应用服务器,1台数据库服务器,1台图片服务器。

研发团队通常都在10人以内,就是在一个单块应用里写代码,然后写好之后合并代码,接着就是直接在线上的应用服务器上发布。 很可能就是手动把应用服务器上的Tomcat给关掉,然后替换系统的代码war包,接着重新启动Tomcat。

数据库一般就部署在一台独立的服务器上,存放网站的全部核心数据。

然后在另外一台独立的服务器上部署NFS作为图片服务器,存放网站的全部图片。应用服务器上的代码会连接以及操作数据库以及图片服务器。如下图所示:

(2)初步的高可用架构

但是这种纯单块系统架构下,有高可用问题存在,最大的问题就是应用服务器可能会故障,或者是数据库可能会故障

所以在这个时期,一般稍微预算充足一点的公司,都会做一个初步的高可用架构出来。

对于应用服务器而言,一般会集群化部署。当然所谓的集群化部署,在初期用户量很少的情况下,其实一般也就是部署两台应用服务器而已,然后前面会放一台服务器部署负载均衡设备,比如说LVS,均匀的把用户请求打到两台应用服务器上去。

如果此时某台应用服务器故障了,还有另外一台应用服务器是可以使用的,这样就避免了单点故障问题。如下图所示:


对于数据库服务器而言,此时一般也会使用主从架构,部署一台从库来从主库同步数据,这样一旦主库出现问题,可以迅速使用从库继续提供数据库服务,避免数据库故障导致整个系统都彻底故障不可用。如下图:

(3)千万级用户量的压力预估

这个假设这个网站预估的用户数是1000万,那么根据28法则,每天会来访问这个网站的用户占到20%,也就是200万用户每天会过来访问。

通常假设平均每个用户每次过来会有30次的点击,那么总共就有6000万的点击(PV)。

每天24小时,根据28法则,每天大部分用户最活跃的时间集中在(24小时 * 0.2)≈ 5小时内,而大部分用户指的是(6000万点击 * 0.8 ≈ 5000万点击)

也就是说,在5小时内会有5000万点击进来。

换算下来,

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用RabbitMQ和Redis可以实现一个高并发高可用、高性能的秒杀系统的思路如下: 1. 架构设计: - 前端:使用负载均衡将请求分发给多个后端服务。 - 后端服务:处理秒杀请求,包括验证用户身份、检查库存、生成订单等。 - RabbitMQ:用于异步处理秒杀请求,将请求放入队列中,后端服务从队列中获取请求进行处理。 - Redis:用于存储商品库存信息,使用Redis的原子操作实现库存的减少和增加。 2. 系统流程: - 用户发起秒杀请求,请求经过负载均衡分发给后端服务。 - 后端服务先进行用户身份验证,确保请求的合法性。 - 后端服务从Redis中查询商品库存信息,如果库存不足,则返回秒杀失败。 - 如果库存充足,后端服务将秒杀请求放入RabbitMQ队列中。 - RabbitMQ将请求分发给多个消费者进行处理。 - 消费者从队列中获取请求,检查库存信息,并生成订单。 - 如果生成订单成功,则更新Redis中的库存信息,并返回秒杀成功。 - 如果生成订单失败,则返回秒杀失败。 3. 关键技术点: - 并发控制:可以通过设置每个商品的库存数量,使用Redis的原子操作对库存进行减少和增加,并通过库存数量判断秒杀的成功与否。 - 异步处理:使用RabbitMQ将秒杀请求放入队列中,后端服务异步处理请求,提高系统的并发能力和响应速度。 - 缓存:使用Redis作为缓存,存储商品的库存信息,减少数据库的访问压力。 - 分布式部署:将系统部署在多台服务器上,提高系统的可用性和性能。 这是一个基本的思路,在实际的开发中还需要考虑到更多的细节和技术选型,如数据库设计、接口设计、并发限流、防刷限制等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值