• FastAPI, 一个神奇的 Python 库

FastAPI, 一个神奇的 Python 库

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

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