你了解秒杀吗?怎么设计
1. 设计难点: 并发量大,应用、数据库都承受不了。另外难控制超卖。
2. 设计要点:
- 将请求尽量拦截在系统上游,html尽量静态化,部署到cdn上面。按钮及时设置为不可用,禁止用户重复提交请求。
- 设置页面缓存,针对同一个页面和uid一段时间内返回缓存页面。
- 数据用缓存抗,不直接落到数据库。
- 读数据的时候不做强一致性教研,写数据的时候再做。
- 在每台物理机上也缓存商品信息等等变动不大的相关的数据
- 像商品中的标题和描述这些本身不变的会在秒杀开始之前全量推送到秒杀机器上并一直缓存直到秒杀结束。
- 像库存这种动态数据会采用被动失效的方式缓存一定时间(一般是数秒),失效后再去Tair缓存拉取最新的数据。 - 如果允许的话,用异步的模式,等缓存都落库之后再返回结果。
- 如果允许的话,增加答题教研等验证措施。
3. 其他业务和技术保障措施:
- 业务隔离。把秒杀做成一种营销活动,卖家要参加秒杀这种营销活动需要单独报名,从技术上来说,卖家报名后对我们来说就是已知热点,当真正开始时我们可以提前做好预热。
- 系统隔离。系统隔离更多是运行时的隔离,可以通过分组部署的方式和另外 99% 分开。秒杀还申请了单独的域名,目的也是让请求落到不同的集群中。
- 数据隔离。秒杀所调用的数据大部分都是热数据,比如会启用单独 cache 集群或 MySQL数据库来放热点数据,目前也是不想0.01%的数据影响另外99.99%。另外需要复习缓存穿透、雪崩等等问题,主要的流量都落在了缓存数据库上,需要针对缓存数据库的高可用作保障。
4. 短链接生成 这个应该是比较公认的方案了:
1. 分布式ID生成器产生ID
2. ID转62进制字符串
3. 记录数据库,根据业务要求确定过期时间,可以保留部分永久链接 主要难点在于分布式ID生成。鉴于短链一般没有严格递增的需求,可以使用预先分发一个号段,然后生成的方式。看了下新浪微博的短链接,8位,理论上可以保存超过200万亿对关系,具体怎么存储的还有待研究。
猜你喜欢LIKE
相关推荐HOT
更多>>什么是XSS攻击,如何避免?
所以XSS攻击的核心就是浏览器渲染DOM的时候将文本信息解析成JS脚本从而引发JS脚本注入,那么XSS攻击的防御手段就是基于浏览器渲染这一步去做防...详情>>
2022-11-17 11:36:00java入门基础知识
新手学习java会有一定的难度,初期阶段可能会不知道如何规划学习路线,建议大家可以上网直接寻找一些成熟的java学习大纲,比如一些java培训机...详情>>
2022-10-19 14:04:00怎么保证缓存和数据库数据的一致性?
选择先淘汰缓存,再更新数据库,假如先更新数据库再淘汰缓存,如果淘汰缓存失败,那么后面的请求都会得到脏数据,直至缓存过期。假如先淘汰缓存...详情>>
2022-10-10 09:51:00请解释自动装配模式的区别?
有五种自动装配的方式,可以用来指导 Spring 容器用自动装配方式来进行依赖注入。 1. no 默认的方式是不进行自动装配,通过显式设置ref属性来...详情>>
2022-10-10 09:50:00如何搭建一个高可用的系统?
高可用系统,就是说要保证系统在几乎任务时候都要有正常运行,功能正常。 我们来看下哪些情况会造成系统不可用。- 单机系统下的可用性问题,从n...详情>>
2022-10-10 09:50:00Java培训问答更多>>
新Java行业疑惑解答:Java的内存管理是如何工作的?
新java script是什么?为什么要学java script
新java和大数据哪个好?未来哪个职业发展更好
新java培训班多久能学会?培训周期大概多久
新java script和java的区别有哪些?如何区分
新java script的数据类型主要有哪些?怎样学的更快
新c语言与java区别在哪里?去培训机构学哪个比较好
Java面试题库 更多>>
华为外包java面试题-Java实现单链表的逆序
Java程序员面试题
Java面试题及答案
什么是线程的上下文切换?
如何撤销已经推送(push)到远端仓库的提交(commit)信息?
你了解哪些加密算法?
- 北京校区
- 大连校区
- 广州校区
- 成都校区
- 杭州校区
- 长沙校区
- 合肥校区
- 南京校区
- 上海校区
- 深圳校区
- 武汉校区
- 郑州校区
- 西安校区
- 青岛校区
- 重庆校区
- 太原校区
- 沈阳校区
- 南昌校区
- 哈尔滨校区