设计 Craigslist 系统的技术架构与实践
1. API 与数据存储特性
API 相关操作具有以下特性:
- 帖子手动创建,存储增长缓慢,不处理程序生成的数据,且帖子一周后可能自动删除。
- 低存储需求使得数据可存于单个主机,无需分布式存储。假设平均每个帖子 1KB 文本,一个大城市 1000 万人中有 10% 发帖,平均每人每天发 10 个帖子(即每天 10GB),SQL 数据库可轻松存储数月的帖子。
API 端点分为管理帖子和管理用户两类:
| 操作类型 | 端点 | 说明 |
| ---- | ---- | ---- |
| CRUD 帖子 | GET 和 DELETE /post/{id} | 获取或删除指定 ID 的帖子 |
| | GET /post?search={search_string} | 获取所有帖子,可通过 search 参数搜索帖子内容,还可实现分页查询 |
| | POST 和 PUT /post | 创建或更新帖子 |
| | POST /contact | 联系相关操作 |
| | POST /report | 举报相关操作 |
| | DELETE /old_posts | 删除旧帖子 |
| 用户管理 | POST /signup | 用户注册 |
| | POST /login | 用户登录 |
| | DELETE /user | 删除用户 |
| 其他 | GET /health | 检查系统健康状态,通常由框架自动生成 |
2. 过滤条件与数据库架构
过滤条件可在前端
超级会员免费看
订阅专栏 解锁全文
762

被折叠的 条评论
为什么被折叠?



