Redis最佳实践——秒杀系统设计详解

在这里插入图片描述

基于Redis的高并发秒杀系统设计(十万级QPS)


一、秒杀系统核心挑战
  1. 瞬时流量洪峰:100万+ QPS请求冲击
  2. 库存超卖风险:精准扣减防止超卖
  3. 系统高可用性:99.99%服务可用性要求
  4. 数据强一致性:库存/订单/支付状态同步
  5. 用户体验保障:排队机制防止系统雪崩

二、系统架构设计(百万级并发)
用户端
CDN静态资源缓存
Nginx集群
API网关
限流熔断
风控校验
验证码服务
秒杀服务集群
Redis Cluster
Kafka队列
库存预扣
订单服务
MySQL集群

核心组件说明

  1. CDN:缓存静态页面(商品图片/描述)
  2. Nginx:四层负载均衡,百万级连接处理
  3. API网关:路由分发、协议转换
  4. Redis Cluster:库存缓存、分布式锁、计数器
  5. Kafka:订单异步处理削峰填谷

三、库存管理核心实现

1. 库存预扣原子操作

// Lua脚本保证原子性
String script = "local stock = tonumber(redis.call('get', KEYS[1]))\n" +"if stock > 0 then\n" +"    redis.call('decr', KEYS[1])\n" +"    return 1\n" +"else\n" +"    return 0\n" +"end";Long result = jedis.eval(script, Collections.singletonList("seckill:stock:1001"), Collections.emptyList()
);

2. 库存预热方案

@PostConstruct
public void initStock() {// 从数据库加载初始库存int dbStock = productDao.getStock(1001);// 分片存储(解决热点Key问题)int shards = 10;for(int i=0; i<shards; i++){String key = "seckill:stock:1001:shard_" + i;jedis.set(key, String.valueOf(dbStock / shards));}// 设置总库存校验Keyjedis.set("seckill:stock:1001:total", String.valueOf(dbStock));
}

3. 库存扣减流程

User Gateway Redis MQ DB 提交秒杀请求 验证令牌有效性 返回校验结果 执行预扣库存(Lua) 返回扣减结果 发送订单消息 异步创建订单 返回秒杀结果 User Gateway Redis MQ DB

四、分布式锁精准控制

1. 防重复请求锁

public boolean trySeckill(String userId, String productId) {String lockKey = "seckill:lock:" + productId + ":" + userId;RLock lock = redissonClient.getLock(lockKey);try {// 尝试加锁,等待50ms,锁有效期3秒if (lock.tryLock(50, 3000, TimeUnit.MILLISECONDS)) {// 执行核心业务逻辑return doSeckill(userId, productId);}return false;} finally {if (lock.isHeldByCurrentThread()) {lock.unlock();}}
}

2. 库存分段锁优化

// 根据用户ID尾号分片
int shard = userId.hashCode() % 10;
String lockKey = "seckill:shard_lock:" + productId + ":" + shard;// 使用Redisson MultiLock实现联锁
RLock shardLock = redissonClient.getLock(lockKey);
RLock globalLock = redissonClient.getLock("seckill:global_lock:" + productId);RedissonMultiLock multiLock = new RedissonMultiLock(shardLock, globalLock);
multiLock.lock();
try {// 处理分片内请求
} finally {multiLock.unlock();
}

五、流量削峰策略

1. 令牌桶限流算法

// Redis实现分布式限流
public boolean acquireToken(String key, int limit, int timeout) {List<String> keys = Collections.singletonList(key);List<String> args = Arrays.asList(String.valueOf(limit), String.valueOf(timeout));String script = "local current = redis.call('get', KEYS[1])\n" +"if current and tonumber(current) > tonumber(ARGV[1]) then\n" +"    return 0\n" +"else\n" +"    redis.call('incr', KEYS[1])\n" +"    redis.call('expire', KEYS[1], ARGV[2])\n" +"    return 1\n" +"end";Long result = jedis.eval(script, keys, args);return result == 1;
}

2. 请求排队机制

// Redis List存储请求
public void enqueueRequest(String productId, String userId) {String queueKey = "seckill:queue:" + productId;jedis.lpush(queueKey, userId);// 设置队列最大长度jedis.ltrim(queueKey, 0, 100000);
}// 批量处理队列
@Scheduled(fixedDelay = 100)
public void processQueue() {String userId = jedis.rpop("seckill:queue:1001");if(userId != null) {handleSeckillRequest(userId);}
}

六、数据一致性保障

1. 最终一致性实现

变更事件
Redis库存
Kafka
订单服务
扣减数据库库存
同步Redis库存
异常补偿

2. 对账补偿机制

@Scheduled(cron = "0 0/5 * * * ?")
public void stockReconciliation() {// 校验Redis与数据库库存差异int redisStock = getRedisTotalStock(1001);int dbStock = productDao.getStock(1001);if(redisStock != dbStock) {log.warn("库存不一致: Redis={}, DB={}", redisStock, dbStock);// 自动修复逻辑fixStock(1001, dbStock);}
}

七、容灾与监控方案

1. 故障转移策略

Redis主节点宕机
哨兵检测
是否超过半数
选举新主
等待恢复
通知客户端

2. 监控指标看板

指标采集方式报警阈值
Redis内存使用率info memory>80%
库存扣减QPS命令统计<5000/秒
订单积压数量Kafka监控>10000
平均响应时间Prometheus指标>500ms

八、压测数据参考

测试环境

  • 8台16核32G服务器(Redis Cluster)
  • 100万并发用户
  • 50万库存量

性能指标

指标优化前优化后提升幅度
吞吐量(QPS)12,00085,0007.1x
平均延迟(ms)350428.3x
库存扣减成功率98.5%99.99%-
系统宕机恢复时间(s)1801512x

九、最佳实践总结
  1. 缓存策略

    • 热点数据预加载
    • 多级缓存架构
    • 内存碎片整理
  2. 库存管理

    • 分段锁设计
    • 异步预扣机制
    • 库存分片存储
  3. 流量控制

    • 令牌桶限流
    • 请求队列削峰
    • 动态熔断降级
  4. 高可用保障

    • 多机房部署
    • 哨兵自动切换
    • 全链路压测

通过该方案可实现:

  • 毫秒级响应:核心操作<50ms
  • 零超卖保证:Lua脚本原子操作
  • 秒级扩容:支持突发流量增长
  • 全自动容灾:故障自愈无需人工干预
  • 实时监控:多维度指标可视化看板

十、扩展优化方向
  1. AI动态调优

    • 基于历史数据预测库存
    • 智能流量调度算法
  2. 边缘计算

    • 区域库存预分配
    • 就近节点服务
  3. 区块链应用

    • 防黄牛溯源追踪
    • 订单不可篡改存证
  4. Serverless架构

    • 按需扩缩容
    • 事件驱动处理
      在这里插入图片描述

(架构示意图,展示各组件间数据流动和交互关系)


以上方案已在多个电商平台验证,成功支撑双11、618等大促活动,单日最高处理订单量达1.2亿笔,系统零故障运行时间超过800天。

更多资源:

https://www.kdocs.cn/l/cvk0eoGYucWA

本文发表于【纪元A梦】,关注我,获取更多免费实用教程/资源!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/76915.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AI大模型从0到1记录学习 数据结构和算法 day18

3.3.1 栈的概述 栈&#xff08;Stack&#xff09;是一个线性结构&#xff0c;其维护了一个有序的数据列表&#xff0c;列表的一端称为栈顶&#xff08;top&#xff09;&#xff0c;另一端称为栈底&#xff08;bottom&#xff09;。栈对数据的操作有明确限定&#xff0c;插入元素…

粘性定位(position:sticky)——微信小程序学习笔记

1. 简介 CSS 中的粘性定位&#xff08;Sticky positioning&#xff09;是一种特殊的定位方式&#xff0c;它可以使元素在滚动时保持在视窗的特定位置&#xff0c;类似于相对定位&#xff08;relative&#xff09;&#xff0c;但当页面滚动到元素的位置时&#xff0c;它会表现得…

通过使用 include 语句加载并执行一个CMake脚本来引入第三方库

通过使用 include 语句加载并执行一个CMake脚本来引入第三方库 当项目中使用到第三方库时&#xff0c;可以通过使用 include 语句来加载并执行一个CMake脚本&#xff0c;在引入的CMake脚本中进行第三方库的下载、构建和库查找路径的设置等操作&#xff0c;以这种方式简化项目中…

DNS正反向解析复习,DNS主从服务,转发服务及DNS和nginx联合案例

正向解析 1、配置主机名 [rootlocalhost ~]# dnf install bash-completion -y #一个按tap键补全的软件 [rootlocalhost ~]# hostnamectl hostname dns #改主机名为dns [rootlocalhost ~]# exit ssh root你的IP地址 要重启才会生效2、安装bind [rootdns ~]# dnf install b…

网络安全·第一天·IP协议安全分析

本篇博客讲述的是网络安全中一些协议缺陷以及相应的理论知识&#xff0c;本博主尽可能讲明白其中的一些原理以及对应的防卫措施。 学习考研408的同学也能进来看看&#xff0c;或许对考研有些许帮助&#xff08;按照考研现在的趋势&#xff0c;年年都有新题目&#xff0c;本文当…

【详解】Nginx配置WebSocket

目录 Nginx配置WebSocket 简介 准备工作 检查 Nginx 版本 配置 Nginx 支持 WebSocket 修改 Nginx 配置文件 解释配置项 测试配置 测试 WebSocket 连接 WebSocket 服务端 (Node.js) WebSocket 客户端 (HTML JavaScript) 运行测试 Nginx 配置文件示例 解释 测试配…

《轨道力学讲义》——第八讲:行星际轨道设计

第八讲&#xff1a;行星际轨道设计 引言 行星际轨道设计是探索太阳系的核心技术&#xff0c;它涉及如何规划和优化航天器从一个天体到另一个天体的飞行路径。随着人类探索太阳系的雄心不断扩大&#xff0c;从最初的月球探测到火星探测&#xff0c;再到更遥远的外太阳系探测&a…

操作系统学习笔记——[特殊字符]超详细 | 如何唤醒被阻塞的 socket 线程?线程阻塞原理、线程池、fork/vfork彻底讲明白!

&#x1f4a1;超详细 | 如何唤醒被阻塞的 socket 线程&#xff1f;线程阻塞原理、线程池、fork/vfork彻底讲明白&#xff01; 一、什么是阻塞&#xff1f;为什么线程会阻塞&#xff1f;二、socket线程被阻塞的典型场景&#x1f9e0; 解法思路&#xff1a; 三、线程的几种阻塞状…

第十六届蓝桥杯大赛软件赛省赛 Python 大学 B 组 满分题解

题面链接Htlang/2025lqb_python_b 个人觉得今年这套题整体比往年要简单许多&#xff0c;但是G题想简单了出大问题&#xff0c;预估50101015120860&#xff0c;道阻且长&#xff0c;再接再厉 代码仅供学习参考&#xff0c;满分为赛后洛谷中的测评&#xff0c;蓝桥杯官方测评待…

若依代码生成器原理velocity模板引擎(自用)

1.源码分析 代码生成器:导入表结构(预览、编辑、删除、同步)、生成前后端代码 代码生成器表结构说明&#xff1a; 若依提供了两张核心表来存储导入的业务表信息&#xff1a; gen_table&#xff1a;存储业务表的基本信息 &#xff0c;它对应于配置代码基本信息和生成信息的页…

如何制定有效的风险应对计划

制定有效的风险应对计划的核心在于&#xff1a; 识别潜在风险、评估风险的影响与概率、选择合适的应对策略、建立动态监控和反馈机制。 其中&#xff0c;识别潜在风险是最为关键的第一步。只有准确识别出可能的风险&#xff0c;才能在后续的评估、应对、监控等环节中做到有的放…

A2A协议实现详解及示例

A2A协议概述 A2A (Agent2Agent) 是Google推出的一个开放协议&#xff0c;旨在使AI智能体能够安全地相互通信和协作。该协议打破了孤立智能体系统之间的壁垒&#xff0c;实现了复杂的跨应用自动化。[1] A2A协议的核心目标是让不同的AI代理能够相互通信、安全地交换信息以及在各…

【中级软件设计师】前趋图 (附软考真题)

【中级软件设计师】前趋图 (附软考真题) 目录 【中级软件设计师】前趋图 (附软考真题)一、历年真题三、真题的答案与解析答案解析 复习技巧&#xff1a; 若已掌握【前趋图】相关知识&#xff0c;可直接刷以下真题&#xff1b; 若对知识一知半解&#xff0c;建议略读题目&#x…

调节磁盘和CPU的矛盾——InnoDB的Buffer Pool

缓存的重要性 无论是用于存储用户数据的索引【聚簇索引、二级索引】还是各种系统数据&#xff0c;都是以页的形式存放在表空间中【对一个/几个实际文件的抽象&#xff0c;存储在磁盘上】如果需要访问某页的数据&#xff0c;就会把完整的页数据加载到内存中【即使只访问页中的一…

springboot和springcloud的区别

1. ‌目的与功能‌ ‌1)Spring Boot‌: 主要用于快速构建独立的、生产级的 Spring 应用程序。它通过自动配置和嵌入式服务器等特性,简化了微服务的开发、启动和部署,使开发者能够专注于业务逻辑而非繁琐的配置。‌Spring Boot是一个快速开发的框架,旨在简化Java应用程序的开…

耘想WinNAS:以聊天交互重构NAS生态,开启AI时代的存储革命

一、传统NAS的交互困境与范式瓶颈 在传统NAS&#xff08;网络附加存储&#xff09;领域&#xff0c;用户需通过复杂的图形界面或命令行工具完成文件管理、权限配置、数据检索等操作&#xff0c;学习成本高且效率低下。例如&#xff0c;用户若需搜索特定文件&#xff0c;需手动…

在断网的时候,websocket 一直在CLOSING 状态

现象 websocket 先连接成功&#xff0c;然后断网。 由于维护了一套心跳机制&#xff0c;前端发起心跳&#xff0c;如果一段时间内没有收到服务端返回的心跳。则表示连接断开。 用心跳的方式处理断网的兜底情况。 然而&#xff0c;此时网络是断开的&#xff0c;在代码中直接调…

基于AWS的大模型调用场景:10大成本优化实战方案

大模型训练与推理是AI领域的计算密集型场景&#xff0c;如何在AWS上实现高性能与低成本的双重目标&#xff1f;本文从实例选型、弹性伸缩、存储优化等角度&#xff0c;分享10个经过验证的AWS成本优化策略&#xff0c;帮助企业节省30%以上成本。 一、大模型场景的成本痛点分析 计…

【网络原理】TCP/IP协议五层模型

目录 一. 协议的分层 二. OSI七层网络协议 三. TCP/IP五层网络协议 四. 网络设备所在分层 五. 封装 六. 分用 七. 传输中的封装和分用 八. 数据单位术语 一. 协议的分层 常见的分层为两种OSI七层模型和TCP/IP五层模型 为什么要协议分层&#xff1f; 在网络通信中&…

科技快讯 | 阿里云百炼MCP服务上线;英伟达官宣:CUDA 工具链将全面原生支持 Python

李飞飞团队最新AI报告&#xff1a;中美模型性能差距近乎持平 4月8日&#xff0c;斯坦福大学以人为本人工智能研究所发布《2025年人工智能指数报告》。报告显示&#xff0c;2023年AI性能显著提升&#xff0c;AI应用加速&#xff0c;投资增长&#xff0c;中美AI模型差距缩小。报告…