FastAPI框架为什么在启动时建表

一般采用的框架是使用FastAPI+sqlalchemy来进行数据库部分的操作,其中主要是分为以下几步:

  1. 使用脚本来进行建表(推荐)/直接在fastapi启动时进行建表(小项目)

为什么不采用fastapi的create_all方法来进行建表:

  • 如果是大项目有多个表多个实例,每个实例服务都去遍历一遍表导致速度缓慢
    • 会导致职责混淆,数据库建表按道理来说是运维部分的工作,fastapi启动服务是指可以使用整个服务了,所以无需再fastapi实例启动时建表

    • 如果大项目有多个实例服务,如果同时启动fastapi时使用create_all方法会出现对数据库进行锁的竞争导致卡死

    • fastapi的create_all方法只是会判断有没有表再进行判断,不会更新表的信息,如果添加/删除字段了更新表会出现ORM与数据库不对应的情况,并且在运行时没有报错,在运行时才会报错

    • fastapi启动时建表会导致数据库的版本无法管理,没办法进行回退

    • 采用fastapi建表没办法使用CI/CD(自动化集成/自动化部署)的整体流程,

      CI:
      ├─ lint # 代码检查,一般采用ruff
      ├─ test # 自动化测试
      ├─ migrate # 数据库迁移
      └─ build image # 打包成镜像

      CD:
      ├─ deploy # 部署
      └─ start app # 启动服务

  1. 数据库的配置,可以采用同步/异步的方式去进行实现,异步的话在同时操作数据库时就需要添加相关的锁/采用事务的方式防止出现同时操作一批数据导致出现脏数据
  2. 定义数据库的model,即ORM部分,要求ORM部分是与数据库进行对接的
相关推荐
羊小猪~~5 分钟前
【QT】--文件操作
前端·数据库·c++·后端·qt·qt6.3
coding-fun1 小时前
电子发票批量提取导出合并助手
大数据·数据库
leo_2321 小时前
备份&恢复--SMP(软件制作平台)语言基础知识之三十九
数据库·数据安全·开发工具·smp(软件制作平台)·应用系统
何以不说话1 小时前
mysql 的主从复制
运维·数据库·学习·mysql
二二牧人1 小时前
qemu arm64 linux开发环境搭建
linux·运维·数据库
茁壮成长的露露1 小时前
导出导入工具mongoexport、mongoimport
数据库·mongodb
Coder_Boy_1 小时前
基于SpringAI的在线考试系统-考试系统DDD(领域驱动设计)实现步骤详解
java·数据库·人工智能·spring boot
workflower2 小时前
软件需求规约的质量属性
java·开发语言·数据库·测试用例·需求分析·结对编程
橘子132 小时前
MySQL库的操作(二)
数据库·mysql·oracle
todoitbo2 小时前
多模数据库技术解析:以KingbaseES MongoDB兼容版为例
数据库·mongodb·kingbasees·金仓数据库