Note
此仓库作为模板库公开,任何人或企业均可免费使用!
简体中文 | English
基于 FastAPI 框架的前后端分离中后台解决方案,遵循伪三层架构设计, 支持 python3.10 及以上版本
🔥持续更新维护中🔥
mvc 架构作为常规设计模式,在 python web 中也很常见,但是三层架构更令人着迷
在 python web 开发中,三层架构的概念并没有通用标准,所以这里我们称之为伪三层架构
但请注意,我们并没有传统的多应用程序结构(django、springBoot...),如果您不喜欢这种模式,可以使用模板对其进行随意改造!
工作流程 | java | fastapi_best_architecture |
---|---|---|
视图 | controller | api |
数据传输 | dto | schema |
业务逻辑 | service + impl | service |
数据访问 | dao / mapper | crud |
模型 | model / entity | model |
你可以在 fastapi_best_architecture_ui 中查看部分预览截图
幸运的是,我们现在有一个演示站点: FBA UI
测试员:tester / 123456
管理员:admin / 123456
- 使用 FastAPI PEP 593 Annotated 参数设计
- async/await + asgiref 的全局异步设计
- 遵循 Restful API 规范
- 全局 SQLAlchemy 2.0 语法
- Pydantic v1 和 v2 (不同分支)
- Casbin RBAC 访问控制模型
- 角色菜单 RBAC 访问控制模型
- Celery 异步任务
- JWT 中间件白名单认证
- 全局自定义时区时间
- Docker / Docker-compose 部署
- Pytest 单元测试
- 用户管理:系统用户角色管理,权限分配
- 部门管理:配置系统组织机构(公司、部门、小组...)
- 菜单管理:配置系统菜单,用户菜单,按钮权限标识
- 角色管理:角色菜单权限分配,角色路由权限分配
- 字典管理:维护系统内部常用固定数据或参数
- 代码生成:后端代码自动生成,支持预览,写入及下载
- 操作日志:系统正常和异常操作的日志记录与查询
- 登录认证:图形验证码后台认证登录
- 登录日志:用户正常和异常登录的日志记录与查询
- 服务监控:服务器硬件设备信息与状态
- 定时任务:自动化任务,异步任务,支持函数调用
- 接口文档:自动生成在线交互式 API 接口文档
├─📁 backend--------------- # 后端
│ ├─📁 alembic------------- # 数据库迁移
│ ├─📁 app----------------- # 应用
│ │ ├─📁 admin------------- # 系统后台
│ │ │ ├─📁 api------------- # 接口
│ │ │ ├─📁 crud------------ # CRUD
│ │ │ ├─📁 model----------- # 模型
│ │ │ ├─📁 schema---------- # 数据传输
│ │ │ ├─📁 service--------- # 服务
│ │ │ └─📁 tests----------- # 测试
│ │ ├─📁 generator--------- # 代码生成
│ │ └─📁 task-------------- # 任务
│ ├─📁 common-------------- # 公共资源
│ ├─📁 core---------------- # 核心配置
│ ├─📁 database------------ # 数据库连接
│ ├─📁 log----------------- # 日志
│ ├─📁 middleware---------- # 中间件
│ ├─📁 scripts------------- # 脚本
│ ├─📁 sql----------------- # SQL文件
│ ├─📁 static-------------- # 静态文件
│ ├─📁 templates----------- # 模版文件
│ └─📁 utils--------------- # 工具包
└─📁 deploy---------------- # 服务器部署
- Python 3.10+
- Mysql 8.0+
- Redis 推荐最新稳定版
- Nodejs 14.0+
-
进入
backend
目录cd backend
-
安装依赖包
pip install -r requirements.txt
-
创建一个数据库
fba
,选择 utf8mb4 编码 -
安装并启动 Redis
-
在
backend
目录下创建.env
文件touch .env cp .env.example .env
-
按需修改配置文件
core/conf.py
和.env
-
数据库迁移 alembic
# 生成迁移文件 alembic revision --autogenerate # 执行迁移 alembic upgrade head
-
启动 celery worker, beat 和 flower
celery -A app.task.celery worker -l info # 定时任务(可选) celery -A app.task.celery beat -l info # web 监控(可选) celery -A app.task.celery flower --port=8555 --basic-auth=admin:123456
-
初始化测试数据(可选)
-
启动 fastapi 服务
# 帮助
fastapi --help
# 开发模式
fastapi dev main.py
跳转 fastapi_best_architecture_ui 查看详情
Warning
默认端口冲突:8000,3306,6379,5672
建议在部署前关闭本地服务:mysql,redis,rabbitmq...
-
进入
deploy/backend/docker-compose
目录,创建环境变量文件.env
cd deploy/backend/docker-compose touch .env.server ../../../backend/.env cp .env.server ../../../backend/.env
-
按需修改配置文件
backend/core/conf.py
和.env
-
执行一键启动命令
docker-compose up -d --build
-
等待命令执行完成
使用 backend/sql/init_test_data.sql
文件初始化测试数据
(仅供参考)
- 定义数据库模型(model)
- 定义数据验证模型(schema)
- 定义视图(api)和路由(router)
- 编写业务(service)
- 编写数据库操作(crud)
通过 pytest
执行单元测试
-
创建测试数据库
fba_test
,选择 utf8mb4 编码 -
使用
backend/sql/create_tables.sql
文件创建数据库表 -
使用
backend/sql/init_pytest_data.sql
文件初始化测试数据 -
进入
backend
目录,执行测试命令cd backend/ pytest -vs --disable-warnings
如果此项目能够帮助到你,你可以赞助作者一些咖啡豆表示鼓励:☕ Sponsor ☕
本项目由 MIT 许可证的条款进行许可