开发过程中有些细节容易被忽略,今天挑几个重点聊一聊。
系统设计 012:从用户系统出发,吃透缓存、数据库与高并发设计
- Bilibili 同步视频
- 一、用户系统,藏着后端设计的核心考点💡
- 二、4S 分析法:先读懂用户系统的流量挑战📊
- 1. Scenario:四大需求,查询为王🔥
- 2. 流量估算:亿级 DAU 的 QPS 压力💥
- 3. Service:职责拆分,让系统更清晰🧩
Bilibili 同步视频
系统设计 012:从用户系统出发,吃透缓存、数据库与高并发设计
在后端开发与系统设计的学习路径中,用户系统是最经典、最贴近实战的切入点📌。它不仅串联起注册、登录、信息管理、好友关系等核心业务场景,更能帮我们真正搞懂缓存是什么、缓存与数据库如何协同、SQL 与 NoSQL 怎么选、高并发 QPS 如何承载等关键问题。今天,我们就以用户系统为锚点,拆解这套从基础到实战的技术逻辑🚀。
一、用户系统,藏着后端设计的核心考点💡
一个完整的用户系统,绝非简单的信息存储,它覆盖了后端面试与工程实践的高频考点:
- 缓存的本质与工作机制🔍
- 缓存 + 数据库的经典协作模式
- 登录态的达成逻辑与持久化方案
- 好友关系的存储、查询与优化
- 关系型数据库 (SQL) vs 非关系型数据库 (NoSQL) 的场景边界
- 以 Cassandra 为代表的 NoSQL 实战用法
- 大厂系统设计面试真题:亿级用户系统设计思路
二、4S 分析法:先读懂用户系统的流量挑战📊
做系统设计,第一步永远是看清场景、算清流量。我们用 4S 分析法,快速定位用户系统的核心压力点。
1. Scenario:四大需求,查询为王🔥
用户系统的核心操作:注册、登录、信息查询、信息修改。
从真实使用场景看:
- 注册:低频行为,不会每日重复
- 登录:多为持久化态,手动输入账号密码频次极低
- 信息修改:昵称、头像等更新频率极低
- 信息查询:最高频! 自查询、好友查看、会话展示等,都会触发查询
2. 流量估算:亿级 DAU 的 QPS 压力💥
假设支撑1 亿日活跃用户 (DAU):
- 注册 / 登录 / 信息修改:每 10 天 1 次,日均 0.1 次 / 人
- 峰值 QPS ≈ 300
- 峰值 QPS ≈ 30 万(300K)
3. Service:职责拆分,让系统更清晰🧩
按照单一职责原则,用户系统可拆分为三大服务:
1. User Service:用户信息增删改查 → 核心数据载体
2. Authentication Service:登录态管理 → 达成 “一次登录、长期有效”
3. Friendship Service:好友关系存储与查询 → 社交场景必备
三、QPS 决定选型:数据库与缓存的性能边界⚡
为什么要精准估算 QPS?因为流量量级直接决定存储方案。不同存储组件的性能天花板,是系统设计的核心依据。
存储类型代表组件QPS 支撑量级核心特点关系型数据库MySQL/PostgreSQL百~千级功能强、事务完善、结构繁琐硬盘型 NoSQLMongoDB/Cassandra1K~10K 级结构简单、读写更快、灵活扩展内存型 NoSQLRedis/Memcached10 万级 +全内存操作、极致性能、高并发首选
简单总结:越简单的存储,跑得越快;越强大的数据库, overhead 越高。
四、用户系统存储选型:对症下药,高效支撑✅
结合前面的 QPS 数据,我们也能直接给出最优解:
1. 注册 / 登录 / 信息修改(QPS≈300) 完全也能用MySQL/PostgreSQL支撑,稳定、可靠、满足事务需求。
2. 用户信息查询(QPS≈30 万) 单机 MySQL/PostgreSQL完全扛不住!一定要引入Redis 等内存缓存,做查询层的流量削峰与加速。
这就是缓存与数据库最经典的配合逻辑:写请求走数据库,高并发读请求走缓存。
五、延伸思考:从用户系统到面试实战🎯
吃透用户系统,等于掌握了系统设计的通用方法论:
- 先定场景与流量,再拆服务,最后选存储
- NoSQL 不是 SQL 的替代品,而是场景互补
- Cassandra 这类分布式 NoSQL,更适合高写入、高吞吐、弱事务的场景
- 亿级用户系统的核心:缓存架构 + 分库分表 + 服务拆分
暂时整理到这里。以上都是个人理解,可能有疏漏,欢迎指正。
评论 (0)
暂无评论