• FastAPI, 一个神奇的 Python 库

FastAPI, 一个神奇的 Python 库

2025-06-09 10:37:03 栏目:宝塔面板 100 阅读

FastAPI 是一个用于构建 API 的现代、快速(高性能)的 web 框架,使用 Python 并基于标准的 Python类型提示。

安装

安装 FastAPI 很简单,这里我们使用 pip 命令来安装。

pip install fastapi

另外我们还需要一个 ASGI 服务器,生产环境可以使用 Uvicorn 或者 Hypercorn

pip install uvicorn[standard]

资料:

  • FastAPI 文档:https://fastapi.tiangolo.com/zh/
  • FastAPI 源码:https://github.com/tiangolo/fastapi

简单示例

# main.py

from fastapi import FastAPI

app = FastAPI()

@app.get("/")
def read_root():
    return {"Hello": "World"}

启动服务:

uvicorn main:app --reload
  • --reload:开发时自动重载(生产环境移除)
  • 访问:http://localhost:8000

关键功能

(1) 路径参数和查询参数

  • {user_id}:路径参数(必须)
  • limit 和 skip:查询参数(可选,带默认值)
@app.get("/users/{user_id}")
async def read_user(user_id: int, 
                    limit: int = 10, 
                    skip: int = 0):
  return {"user_id": user_id, "limit": limit, "skip": skip}

(2) 请求体(POST/PUT)

使用 Pydantic 模型验证数据:

from pydantic import BaseModel

class Item(BaseModel):
    name: str
    description: str = None
    price: float
    tax: float = None

@app.post("/items/")
async def create_item(item: Item):
    return {"item": item.dict()}

(3) 自动文档

  • Swagger UI:http://localhost:8000/docs
  • ReDoc:http://localhost:8000/redoc

(4) 异步支持

@app.get("/slow-endpoint")
async def slow_operation():
    # 如数据库查询
    await some_async_task() 
    return {"status": "done"}

进阶功能

(1) 依赖注入

复用代码逻辑(如认证、数据库连接)。

from fastapi import Depends

def common_params(q: str = None, skip: int = 0, limit: int = 100):
    return {"q": q, "skip": skip, "limit": limit}

@app.get("/items/")
async def read_items(commons: dict = Depends(common_params)):
    return commons

(2) 中间件

处理请求前/后的逻辑(如 CORS、日志)。

from fastapi.middleware.cors import CORSMiddleware

app.add_middleware(
    CORSMiddleware,
    allow_origins=["*"],
    allow_methods=["*"],
)

(3) WebSocket 支持

@app.websocket("/ws")
async def websocket_endpoint(websocket: WebSocket):
    await websocket.accept()
    while True:
        data = await websocket.receive_text()
        await websocket.send_text(f"Message: {data}")

(4) 后台任务

执行无需即时响应的操作(如发送邮件、短信)

from fastapi import BackgroundTasks

def log_task(message: str):
    with open("log.txt", "a") as f:
        f.write(message)

@app.post("/send-email")
async def send_email(background_tasks: BackgroundTasks):
    background_tasks.add_task(log_task, "Email sent")
    return {"status": "ok"}

适用场景

  • 构建高性能 REST API
  • 微服务后端
  • 实时应用(WebSocket)
  • 结合sqlalchemy进行 web 开发

本文地址:https://www.yitenyun.com/277.html

搜索文章

Tags

数据库 API FastAPI Calcite 电商系统 MySQL Web 应用 异步数据库 数据同步 ACK 双主架构 循环复制 JumpServer SSL 堡垒机 跳板机 HTTPS TIME_WAIT 运维 负载均衡 HexHub Docker JumpServer安装 堡垒机安装 Linux安装JumpServer Deepseek 宝塔面板 Linux宝塔 生命周期 esxi esxi6 root密码不对 无法登录 web无法登录 服务器 管理口 序列 核心机制 Windows Windows server net3.5 .NET 安装出错 HTTPS加密 服务器性能 宝塔面板打不开 宝塔面板无法访问 查看硬件 Linux查看硬件 Linux查看CPU Linux查看内存 开源 PostgreSQL 存储引擎 Windows宝塔 Mysql重置密码 Oracle 处理机制 无法访问宝塔面板 InnoDB 数据库锁 连接控制 机制 监控 Spring Redis 异步化 Serverless 无服务器 语言 group by 索引 SQL 优化 万能公式 ES 协同 技术 Undo Log 缓存方案 缓存架构 缓存穿透 分页查询 动态查询 高可用 机器学习 GreatSQL 连接数 工具 响应模型 查询 日志文件 MIXED 3 SVM Embedding scp Linux的scp怎么用 scp上传 scp下载 scp命令 R edis 线程 R2DBC 锁机制 数据 主库 Netstat Linux 服务器 端口 openHalo 加密 场景 Postgres OTel Iceberg 云原生 Linux 安全 RocketMQ 长轮询 配置 Recursive AI 助手 自定义序列化 存储 ​Redis 推荐模型 SQLite-Web SQLite 数据库管理工具 共享锁 SQLark PG DBA Hash 字段 向量数据库 大模型 电商 系统 OB 单机版 Ftp 架构 启动故障 国产数据库 MySQL 9.3 修改DNS Centos7如何修改DNS • 索引 • 数据库 数据分类 流量 防火墙 黑客 人工智能 推荐系统 sftp 服务器 参数 磁盘架构 Rsync 同城 双活 信息化 智能运维 Python 线上 库存 预扣 redo log 重做日志 分库 分表 向量库 Milvus mini-redis INCR指令 业务 不宕机 传统数据库 向量化 行业 趋势 MVCC Canal 缓存 聚簇 非聚簇 Redisson 锁芯 高效统计 今天这篇文章就跟大家 PostGIS INSERT COMPACT 网络架构 网络配置 Doris SeaTunnel 数据备份 prometheus Alert filelock 事务 Java 开发 Web 窗口 函数 ZODB 语句 虚拟服务器 虚拟机 内存 RDB AOF MongoDB 数据结构 数据脱敏 加密算法 读写 引擎 性能 容器 失效 OAuth2 Token 核心架构 订阅机制 Go 数据库迁移 数据类型 频繁 Codis B+Tree ID 字段 IT运维 容器化 分布式 集中式 模型 崖山 新版本 Redis 8.0 发件箱模式 自动重启 网络故障 DBMS 管理系统 聚簇索引 非聚簇索引 播客 SpringAI SSH 微软 SQL Server AI功能 MCP 开放协议 Web 接口 QPS 高并发 Entity 数据页 JOIN 原子性 数据集成工具 网络 部署 Pottery 工具链 速度 服务器中毒 StarRocks 数据仓库 排行榜 排序 Testcloud 云端自动化 Redka 事务隔离 分布式架构 分布式锁​ 分页方案 排版 大表 业务场景 Caffeine CP 1 悲观锁 乐观锁 池化技术 连接池 dbt 数据转换工具 主从复制 代理 日志 sqlmock LRU 优化器 EasyExcel MySQL8 单点故障 AIOPS 仪表盘 分页 Order 意向锁 记录锁 事务同步 InfluxDB 数据字典 兼容性 对象 UUIDv7 主键 RAG HelixDB Ansible ReadView UUID ID Crash 代码 订单 双引擎 单线程 IT 字典 LLM Valkey Valkey8.0 恢复数据 Weaviate 产业链 编程 分布式锁 Zookeeper MGR 分布式集群 千万级 线程安全 Pump List 类型 拦截器 动态代理 关系数据库 表空间 Next-Key 解锁 调优 慢SQL优化 快照读 当前读 视图 矢量存储 数据库类型 AI代理 国产 用户 RR 互联网 GitHub Git 神经系统 查询规划 算法 count(*) count(主键) 行数 技巧 CAS 并发控制 恢复机制 多线程 闪回