返回付费课程总览
Flagship Workshop

用现代 C++ 从零实现 Redis

约 1–3 周的深度工程课,从事件循环到集群与观测,完整手写 Redis 内核。 强调可复用脚手架、性能闭环与工程落地,让你能在团队中直接推广。

周期

约 1–3 周·自定进度

节奏

按任务拆分的深度 workshop 节奏

交付

核心功能代码库 + 性能报告

形式

结构化自学 + 代码评审

进阶计划
Code Review
阶段性性能评估与优化建议
核心功能代码 + 基准测试仓库
复盘文档模板,便于团队复用
小班答疑 + 1v1 点拨,确保节奏

交付场景

适合在中小型团队中推广:高性能 KV 服务、排行榜、计数器、配置中心、消息缓冲等。

Outcomes

你将收获

掌握基于 epoll 的事件循环与非阻塞 IO 实现

还原 Redis 核心数据结构:SDS、跳表、哈希、压缩列表

手写持久化与复制链路,理解一致性、复制延迟与恢复

搭建可观测性与压测方案,形成性能调优闭环

输出可复用的现代 C++ 项目脚手架与测试体系

Career Impact

学完之后,你大概会变成什么样?

能从零写出一个迷你版 Redis 服务

支持网络通信、RESP 协议、AOF 持久化、过期键、事务、核心数据结构等,从“会用现成 Redis”走到“敢自己实现一个简化版 Redis”。

敢给自己的 C++ 网络/后端能力背书

不再只是“写过一点业务 + 用现成框架”,而是亲手走完从阻塞 Echo 服务器 → epoll 并发 → 协议解析 → 持久化 → 工程化改造 → 数据结构演进的完整闭环。

多了一段能写进简历、能在面试里讲 20 分钟的项目

手里握着真实的压测数据、源码结构图和演进过程,而不是“照着网上抄了个 Demo”,可以从工程取舍、性能结果和演进路径三个维度向面试官展开讲解。

Program Modules

课程架构

Part 1 · 构建高性能核心

第一部分:从阻塞到并发,搭建能真正扛流量的 K/V 服务核心。

第 1 篇:我们要做什么?—— Redis 的动机与目标
第 2 篇:准备工作与第一个网络程序
第 3 篇:定义规则与核心存储
第 4 篇:迈向工业级!模块化的 K/V 服务
第 5 篇:王者归来 - 封装 epoll,实现高性能并发
Part 2 · 协议升级与工程化

第二部分:走向专业——协议升级与工程化基线。

第 6 篇:与世界对话 - 升级到 RESP 协议
第 7 篇:网络编程的专业武器 - 打造高性能缓冲区
第 8 篇:工程化基石 (上) - 日志与配置
第 9 篇:工程化基石 (下) - AOF 持久化
Part 3 · 功能迭代 · 让服务更强大

第三部分:在稳定核心之上按需迭代高级功能,让服务更强大。

第 10 篇:监控 - 为服务器装上仪表盘
第 11 篇:时间的管理者 - 引入定时器
第 12 篇:自动管理 - 实现 Key 的过期删除
第 13 篇:高级功能 - 实现事务
第 14 篇:告别面条代码 - 命令模式与 Redis 命令系统
Part 4 · 核心数据结构

第四部分:从字符串走向 LIST/HASH/SET 等核心数据结构,让服务真正“能用”。

第 15 篇:万物皆对象 - Redis 统一数据结构设计
第 16 篇:初探高级数据结构:实现 LIST 命令
第 17 篇:实现 HASH 数据结构
第 18 篇:实现 SET 数据结构
Part 5 · 从项目到面试

第五部分:从项目到面试,把 mini-Redis 变成职业筹码。

第 19 篇:项目亮剑:如何将 mini-redis 写进你的简历
第 20 篇:面试官想听什么?—— Redis 多线程模型深度解析

Learning Blueprint

进阶学习蓝图

1

阶段 1 · 构建高性能核心

目标:从零开始构建能实际运行的 K/V 服务,并用 epoll 将其改造成高性能并发服务器;产出:一个能够同时处理大量连接的高性能核心。

2

阶段 2 · 走向专业 · 协议升级与工程化

目标:将服务器从“业余作品”带向专业级别,升级为兼容 RESP 的服务并补齐工程化基建;产出:一个能被 redis-cli 识别、数据可持久化的核心服务。

3

阶段 3 · 功能迭代 · 让服务更强大

目标:在稳定核心之上迭代监控、定时器、Key 过期、事务与命令系统等高级特性;产出:一个具备真实线上系统管理能力的 mini-Redis。

4

阶段 4 · 架构进阶与展望

目标:在完成核心功能与数据结构后,结合真实 Redis 的多线程模型与高级架构,形成对工业级服务的宏观认识;产出:一套清晰的后续学习与演进方向。

Study Rhythm

推荐学习节奏

整体设计为约 1–3 周即可完成,你可以按自己的节奏拆分阶段,不需要一次性啃完整个课程。

  • 建议每次学习 1–2 小时,完整推进一个阶段,让每一次投入都有清晰的“通关感”。
  • 优先完成阶段 1–3,先打通从事件循环到持久化的完整闭环,再按精力补全后续阶段。
  • 在每个阶段结束时记录一次压测或复盘,为简历和面试持续积累可量化的成果。

Deliverables

交付物与模板

完整的现代 C++ Redis 迷你实现(含单测与基准测试)

性能剖析与优化报告,记录关键指标与调优策略

可复用的 C++ 服务端脚手架(日志、配置、观测、CI)

个人学习与复盘文档,形成团队可分享的最佳实践

Audience

适合人群

具备 1-2 年 C++ 开发经验,希望突破系统层/高性能方向

想从源码角度理解 Redis 工作原理,并能举一反三到自研服务

需要在团队内推广高性能、可观测、可复用的服务模板

我们会先了解你的背景与目标

确认你的技术栈、时间安排与期望产出,再给出个性化路线与席位确认方式。

FAQ

常见问题

Q&A

课程形式与产出是怎样的?

每周 2 次深度 workshop + 自主实践;每个阶段有代码评审与性能报告反馈,最终提交完整代码仓库与复盘文档。

Q&A

是否需要提前阅读 Redis 源码?

不强制,但建议熟悉网络编程基础与 C++11/14 语法。课程会提供精简的源码片段与讲解,帮助快速对齐。

Q&A

如何获得个性化辅导?

小班制搭配阶段性 1v1 评审与答疑,可针对你所在业务或项目场景给出改进方案。

Q&A

代码与资料可以在团队复用吗?

课程提供的脚手架、测试与优化方法可直接在团队内推广复用,便于建立统一工程基线。

Next Step

想要课程大纲、价格或开班时间?

扫描右侧二维码添加微信,备注「Redis 课程」,获取大纲、价格与开班时间。

微信二维码

微信扫码添加 · 备注「Redis 课程」