千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > 你了解秒杀吗?怎么设计?

你了解秒杀吗?怎么设计?

来源:千锋教育
发布人:qyf
时间: 2022-09-21 15:53:56 1663746836

你了解秒杀吗?怎么设计?

 

  你认为项目中最重要的过程是那些?

 

  分析、设计阶段 尽量找出进度的优先级。

  1.设计难点:

  并发量大,应用、数据库都承受不了。另外难控制超卖。

  2.设计要点:

  将请求尽量拦截在系统上游,html尽量静态化,部署到cdn上面。按钮及时设置为不可用,禁止用户重复提交请求。

  设置页面缓存,针对同一个页面和uid一段时间内返回缓存页面。

  数据用缓存抗,不直接落到数据库。

  读数据的时候不做强一致性教研,写数据的时候再做。

  在每台物理机上也缓存商品信息等等变动不大的相关的数据

  像商品中的标题和描述这些本身不变的会在秒杀开始之前全量推送到秒杀机器上并一直缓存直到秒杀结束。

  像库存这种动态数据会采用被动失效的方式缓存一定时间(一般是数秒),失效后再去Tair缓存拉取最新的数据。

  如果允许的话,用异步的模式,等缓存都落库之后再返回结果。

  如果允许的话,增加答题教研等验证措施。

  其他业务和技术保障措施:

  业务隔离。把秒杀做成一种营销活动,卖家要参加秒杀这种营销活动需要单独报名,从技术上来说,卖家报名后对我们来说就是已知热点,当真正开始时我们可以提前做好预热。

  系统隔离。系统隔离更多是运行时的隔离,可以通过分组部署的方式和另外 99% 分开。秒杀还申请了单独的域名,目的也是让请求落到不同的集群中。

  数据隔离。秒杀所调用的数据大部分都是热数据,比如会启用单独 cache 集群或 MySQL 数据库来放热点数据,目前也是不想0.01%的数据影响另外99.99%。

  另外需要复习缓存穿透、雪崩等等问题,主要的流量都落在了缓存数据库上,需要针对缓存数据库的高可用作保障。

  短链接生成

  这个应该是比较公认的方案了:

  分布式ID生成器产生ID

  ID转62进制字符串

  记录数据库,根据业务要求确定过期时间,可以保留部分永久链接

  主要难点在于分布式ID生成。鉴于短链一般没有严格递增的需求,可以使用预先分发一个号段,然后生成的方式。

  看了下新浪微博的短链接,8位,理论上可以保存超过200万亿对关系,具体怎么存储的还有待研究。

tags:
声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT