选对框架(Flask/FastAPI/Django REST)、分三层(API/领域/数据)、配四块底座(配置/日志/健康检查/错误处理)、模块化演进,让API服务随业务持续生长。

用Python写API服务端,核心是选对框架、分清层次、留好扩展点。不是堆功能,而是让代码能随着业务一起长。
选框架:从需求定轻重
小项目或内部工具,Flask足够轻快,路由和中间件自己搭,灵活不臃肿;中大型业务或需要开箱即用的鉴权、序列化、文档能力,FastAPI更合适——自带Pydantic校验、异步支持、自动生成OpenAPI文档;如果团队熟悉Django生态、还要配套管理后台,Django REST Framework仍是稳妥选择。
- 别为“新”而选FastAPI,若没异步IO瓶颈或前端不依赖Swagger,Flask维护成本反而更低
- 所有框架都建议统一用uvicorn(或gunicorn+uvicorn)部署,别用内置开发服务器上线
- 起步阶段就配好pyproject.toml,把依赖、格式检查(ruff)、类型检查(mypy)全管起来
分层设计:别把逻辑全塞进路由里
按职责切三层:API层(接收请求/返回响应)、领域层(核心业务规则)、数据层(数据库/缓存/外部API调用)。比如用户注册接口:
- API层只做参数解析、调用领域函数、包装返回结构,不碰密码哈希或发邮件
- 领域层实现“检查用户名唯一性→创建用户→触发欢迎邮件事件”,它不关心是HTTP还是CLI调用
- 数据层封装SQLAlchemy模型或Redis操作,对外暴露Repository接口,方便未来换数据库
这样改需求时,比如“注册后加实名认证步骤”,只动领域层;换MySQL为PostgreSQL,只改数据层。
立即学习“Python免费学习笔记(深入)”;
关键基建:上线前必须搭好的四件事
很多项目卡在“能跑”但“不敢上”,其实是缺这四块底座:
- 配置管理:用pydantic-settings加载环境变量+配置文件,区分dev/staging/prod,密钥绝不硬编码
- 日志规范:结构化日志(如JSON格式),记录trace_id、用户ID、耗时、错误堆栈,对接ELK或Sentry
-
健康检查与指标:提供
/health端点,用Prometheus Client暴露QPS、延迟、DB连接数等指标 - 错误统一处理:全局捕获异常,转成标准错误响应(含code/message/data),避免暴露内部路径或数据库错误
演进意识:从单体到可拆分
初期不用微服务,但要为将来留缝:
- 每个业务模块(如user、order、payment)单独建包,包内自包含API+领域+数据,边界清晰
- 跨模块调用走定义好的interface(如
user_service.get_user()),而非直接导入模型,未来可替换成RPC或HTTP客户端 - 数据库按模块分schema或分库,避免一张users表被所有服务强耦合
基本上就这些。架构不是图纸,是每次提交都在加固的习惯。










