电商项目_秒杀_初步分析

秒杀的特点:

1. 不能超卖,库存要求严格

  1. 参加的人越多越好

秒杀的挑战:

  • 巨大的瞬间流量
  • 热点数据
  • 刷子流量:刷子的高频次请求,会挤占正常用户的抢购通道,同时,刷子也获得了更高的秒杀成功率。破获抢购环境。

秒杀初步分析

普通的电商场景,为了提高三高性能,使用的各种手段更多的都是协调各种硬件资源,而秒杀场景,简单的协调硬件资源是不够的,还需要软件更极致的挖掘硬件资源。

商品抢购过程:

一次HTTP调用经过的节点:

和秒杀相关的:

  • 秒杀活动数据
  • 提供结算页:参与抢购的商品信息
  • 下单

秒杀流量隔离

业务隔离:秒杀商户业务上会提前进行准备,技术人员就可以评估处大致流量

系统隔离:⽐较常⻅的实践是对会被流量冲击⽐较⼤的核⼼系统进⾏物理隔离,⽽相对链路末端的⼀些系统,经过前⾯的削峰之后,流量⽐较可控了,这些系统就可以不做物理隔离。

  1. 秒杀详情页域名独立
  2. 独立的Nginx负载均衡器
  3. 独⽴的详情⻚后端服务

⼀般来说,秒杀中流量冲击⽐较⼤的核⼼系统就是秒杀详情⻚、秒杀结算⻚、秒杀下单库存扣减是需要我们重点关注的对象

数据隔离:

数据层的专有部署,需要结合秒杀的场景来设计部署拓扑结构,⽐如 Redis缓存,⼀般的场景⼀主⼀从就够了,但是在秒杀场景,需要⼀主多从来扛读热点数据。

相关推荐
ciku2 分钟前
Spring AI Starter和文档解读
java·人工智能·spring
程序猿阿越12 分钟前
Kafka源码(三)发送消息-客户端
java·后端·源码阅读
whitepure17 分钟前
万字详解Java中的运算
java
AAA修煤气灶刘哥19 分钟前
搞定 Redis 不难:从安装到实战的保姆级教程
java·redis·后端
MrSYJ22 分钟前
全局和局部AuthenticationManager
java·后端·程序员
界面开发小八哥26 分钟前
「Java EE开发指南」如何使用MyEclipse中的Web Fragment项目?
java·ide·java-ee·eclipse·myeclipse
Tadas-Gao1 小时前
Java设计模式全景解析:从演进历程到创新实践
java·开发语言·微服务·设计模式·云原生·架构·系统架构
励志成为架构师2 小时前
跟小白一起领悟Thread——如何开启一个线程(上)
java·后端
anlogic2 小时前
Java基础 8.16
java·开发语言