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部分是与数据库进行对接的
相关推荐
陌上丨7 小时前
Redis的Key和Value的设计原则有哪些?
数据库·redis·缓存
AI_56787 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
ccecw8 小时前
Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错
数据库·mysql
JH30738 小时前
达梦数据库与MySQL的核心差异解析:从特性到实践
数据库·mysql
数据知道8 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
麦聪聊数据9 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务9 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
Goat恶霸詹姆斯11 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七11 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
曾经的三心草11 小时前
redis-9-哨兵
数据库·redis·bootstrap