前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >阿里双十一秒杀系统架构设计,有哪些技术关键点?

阿里双十一秒杀系统架构设计,有哪些技术关键点?

作者头像
美的让人心动
发布于 2018-12-04 08:48:27
发布于 2018-12-04 08:48:27
1.5K0
举报
文章被收录于专栏:Java架构Java架构

马上要到双11了,就来谈谈如何设计一个秒杀系统架构

技术挑战

1. 对原有业务形成冲击

秒杀活动只是网站营销的一个附加活动,特点是:时间短、并发访问量大,如果和网站原有应用部署在一起,必然会对现有业务造成冲击。

解决方案:将秒杀系统独立部署,甚至使用独立域名,使其与网站完全隔离。

2. 高并发下数据库、应用负载

用户在秒杀开始前,通过不停刷新浏览器页面以保证不会错过秒杀,这些请求如果按照一般的网站应用架构,访问

应用服务器、连接数据库,

会对应用服务器和数据库服务器造成负载压力。

解决方案:重新设计秒杀商品页面,不使用网站原来的商品详细页面,页面内容静态化,用户请求不需要经过

应用服务

3. 突然增大的服务器和网络带宽

假设商品页面大小200K,10000个请求的带宽就是2G。

解决方案:因为秒杀新增的网络带宽,必须和运营商重新购买或者租借。为了减轻网站服务器的压力,

需要将秒杀商品页面缓存到CDN

4. 防止秒杀前下单

秒杀的游戏规则是到了秒杀才能开始对商品下单购买,在此时间点之前,只能浏览商品信息,不能下单。而下单页面也是一个普通的URL,如果得到这个URL,不用等到秒杀开始就可以下单了。

解决方案:为了避免用户直接访问下单页面URL,需要将改URL动态化,即使秒杀系统的开发者也无法在秒杀开始前访问下单页面的URL。办法是在下单页面URL加入由服务器端生成的随机数作为参数,在秒杀开始的时候才能得到。

应对策略

1. 独立部署

和原有业务部署在不同服务器,防止高并发拖垮整个网站

2. 页面静态化

将商品详情、描述静态化到页面

3. 租借秒杀网络带宽

向运营商租借带宽

4. 动态生成随机下单页面URL

无法在秒杀前访问下单页面的URL:加入服务器端生成的随机数作为参数,在秒杀开始前才能得到

架构设计

1. 控制秒杀购买页面的点亮

购买按钮只有在活动开始的时候才能点亮,在此之前是灰色的。如果是动态页面,可以很容易解决这个问题,但为了减轻服务器端负载压力,

更好的利用CDN、反向代理等性能优化手段,

该页面被设计为静态页面,缓存在CDN、反向代理服务器上,甚至用户浏览器上。秒杀开始时,用户刷新页面,请求根本不会到达应用服务器。

解决方案:秒杀商品页面加入一个javascript引用,该javascript中加入秒杀是否开始的标志和下单页面URL的随机数参数,该javascript使用随机版本号,不可被浏览器缓存

当秒杀开始时,生成一个新的javascript文件并被用户浏览器加载

2. 允许第一个订单提交

秒杀开始,由于最终能够成功秒杀到商品的用户只有一个,因此需要在用户提交订单时,检查是否已经有订单提交。

解决方案:为了减轻下单页面服务器的负载压力,可以控制进入下单页面入口,只有先提交的少数用户可进入,后边的用户直接进入秒杀结束页面

下单服务器检查本机已处理的下单请求数目

*如果超过10条,直接返回已结束页面给用户;

*如果未超过10条,则用户可进入填写订单及确认页面;

检查全局已提交订单数目

*已超过秒杀商品总数,返回已结束页面给用户;

*未超过秒杀商品总数,提交到子订单系统。

这样就大大地减少了数据库的负载压力。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.10.29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
秒杀系统的技术挑战、应对策略以及架构设计总结一二!
秒杀是电商常见的一种营销手段:将少量的商品,以极低的价格,在特定的时间点开始出售,网站通过这种营销手段,制造某种轰动效应,从而达到网站推广的目的,秒杀虽然对网站推广有很多好处,但是对网站技术却是极大的挑战:网站是为正常运营设计的,而秒杀活动带来的并发访问用户却是平时的数百倍甚至上千倍,网站如果为秒杀时的最大并发访问量去设计部署,就需要比正常运营多很多服务器,而这些服务器在大多数时候都是用不上的,对于成本而言就比较浪费了,所以秒杀业务不能使用正常的网站业务流程,也不能和正常的网站交易业务公用一台服务器,必须设计部署专门的秒杀系统,进行专门应对。
Java后端技术
2018/08/09
7970
秒杀系统的技术挑战、应对策略以及架构设计总结一二!
网购秒杀系统架构设计
本文是「大型网站技术架构 - 核心原理与案例分析」 第 12 章的学习笔记,感兴趣的朋友可以去购买
柳公子
2018/09/17
1.4K0
纯干货--秒杀系统架构分析与实战
(1)查询商品;(2)创建订单;(3)扣减库存;(4)更新订单;(5)付款;(6)卖家发货
后端技术探索
2018/08/09
1.2K0
秒杀系统设计:你的系统可以应对万人抢购盛况吗?
秒杀是电子商务应用常见的一种营销手段:将少量商品(常常只有一件)以极低的价格,在特定的时间点出售。比如,周日晚上 8 点整,开售 1 部 1 元钱的手机。 因为商品价格诱人,而且数量有限,所以用户趋之若鹜,在秒杀活动开始前涌入系统, 等到秒杀活动开始的一瞬间,点下购买按钮(在此之前购买按钮为灰色,不可以点击),抢购商品。
小熊学Java
2023/12/13
3090
秒杀系统设计:你的系统可以应对万人抢购盛况吗?
如何设计一个秒杀系统
最近在部门内部分享了原来在电商业务做秒杀活动的整体思路,大家对这次分享反馈还不错,所以我就简单整理了一下,分享给大家参考参考。
Bug开发工程师
2018/07/23
1.2K0
如何设计一个秒杀系统
设计一个秒杀系统架构
秒杀架构的设计方案就是一个不断过滤请求的过程,从系统架构层面来说,秒杀系统的分层思路如下。
NeilNiu
2023/03/06
4350
《大型网站技术架构》学习笔记-03案例篇
最后一篇案例篇,"愿站在巨人的肩膀上",加油熊二同学。 常见案例 淘宝网架构演进 2017年5月18日,阿里巴巴集团公布2016财年的全年业绩,集团收入为1582.73亿元人民币,同比增长56%
用户1216676
2018/01/24
9190
java高并发设计:秒杀架构设计,实际项目使用过
业务优化思路:业务上适当规避 技术优化思路:尽量将请求拦截在数据库的上游,因为一旦大量请求进入数据库,性能会急剧下降 架构原则:合适、简单、演化(以上内容是最终版本,初版可以说没有用到队列,直接使用缓存-数据库这样的架构)
用户1289394
2020/11/06
1.8K0
如何设计一个秒杀系统?
这篇分享源自之前购买的极客时间课程《如何设计一个秒杀系统》,以及书籍《亿级流量网站架构核心技术》。
BookSea
2024/06/18
2840
如何设计一个秒杀系统?
6000多字 | 秒杀系统设计注意点【理论】
首先是指用户请求的数据能少就少。请求的数据包括上传给系统的数据和系统返回给用户的数据(通常就是网页)。
田维常
2020/12/14
4260
如何设计一个高性能的秒杀系统
秒杀系统要如何架构,在做技术方案时要注意哪些问题,搞了个秒杀专辑,专门收集秒杀系列文章。
微观技术
2020/08/20
9060
《大型网站技术架构》笔记
WEB前端性能优化:减少http请求,合并CSS、合并JavaScript、合并图片。使用浏览器缓存。启用压缩。CSS放页面最上面,JS放页面最下面。减少Cookie传输。CDN加速。反向代理。
用户5760343
2022/05/24
6890
《大型网站技术架构》笔记
秒杀系统解决方案
感谢于霆霖的投稿,本文摘自:http://yutinglin.cn/2017/08/01/秒杀系统解决方案/ 我看了二十篇左右的秒杀系统设计及解决方案的文章,从架构、产品、前端、后端四个层面分别总结了一些解决方案。 要点总结: 1.架构:扩容,业务分离,数据分离 2.产品:下单按钮控制,秒杀答题削峰,简化页面设计 3.前端:限流(反作弊) 静态化 4.后端:内存 队列 一、秒杀一般会带来2个问题: 1、高并发 比较火热的秒杀在线人数都是10w起的,如此之高的在线人数对于网站架构从前到后都是一种考验。 2、超
程序猿DD
2018/02/01
1.7K0
阿里双十一购物节背后的技术问题
一年一度的双十一购物狂欢节又要来临了,你准备好剁手了吗?我每年都要购买好几百,有时候甚至是一千多的东西。不过以前我还没有考虑过这背后的技术问题,直到最近我做了一个烂项目以及和同事谈论双十一购物效率问题时才思考了一下这个问题。
三哥
2018/12/05
9.7K0
解密 Redis 助力双十一背后电商秒杀系统
秒杀活动是绝大部分电商选择的低价促销、推广品牌的方式。不仅可以给平台带来用户量,还可以提高平台知名度。一个好的秒杀系统,可以提高平台系统的稳定性和公平性,获得更好的用户体验,提升平台的口碑,从而提升秒杀活动的最大价值。
搜云库技术团队
2019/10/18
4780
如何设计属于你自己的秒杀系统?
其实,整个秒杀的业务场景并不复杂,可即查看参与秒杀的商品信息,加上购买和支付的动作,如下图所示。
Rude3Knife的公众号
2022/12/10
1K0
如何设计属于你自己的秒杀系统?
秒杀网站如何用云支撑?
我们的互联网客户经常用“秒杀”营销技巧吸引客户的观注,比如秒杀购房优惠券、秒杀汽车使用权等活动。正是巨大的优惠,让很多平常没有需求的客户也集中在一个时间点关注这个营销活动网页,对后台的IT支撑能力带来巨大的挑战。今天我们用实际案例看一看上云后,如何承接秒杀业务。
希望的田野
2019/09/24
1.3K0
秒杀网站如何用云支撑?
如何设计一个秒杀系统
秒杀已经成为电商不可缺少的一步分了,所谓 买到就是赚到,可以成功吸引到一大堆用户,那程序员面对这些用户该怎么办呢。我们该如何设计秒杀呢?
憧憬博客
2020/10/09
7920
5分钟了解系统架构设计(6)
最近梳理了之前学习的架构设计相关的一些课程学习总结,将其整理成了一个大纲脑图,以每篇5分钟系列展现出来,希望对你有所帮助。
Edison Zhou
2023/03/06
7300
5分钟了解系统架构设计(6)
相关推荐
秒杀系统的技术挑战、应对策略以及架构设计总结一二!
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档