FastAPI后台任务依赖管理
一、BackgroundTasks基础回顾
1.1 核心作用机制
FastAPI的BackgroundTasks功能允许在响应返回客户端后执行异步操作。其核心实现原理是通过将任务注册到Starlette的BackgroundTasks实例,在当前请求处理完成后顺序执行。
1.2 典型应用场景
- 邮件/短信通知发送
- 日志记录与分析
- 文件异步处理
- 第三方API回调处理
二、任务依赖关系管理
2.1 依赖关系类型
graph TD
A[主任务] --> B[前置任务]
A --> C[并行任务]
B --> D[后置任务]
2.1.1 顺序依赖
通过任务注册顺序控制执行顺序:
def task_a():
print("执行任务A")
def task_b():
print("执行任务B")
@app.post("/tasks")
async def create_task(background_tasks: BackgroundTasks):
background_tasks.add_task(task_a) # 先执行
background_tasks.add_task(task_b) # 后执行
2.1.2 数据依赖
通过参数传递实现跨任务数据共享:
def process_data(raw_data: dict) -> dict:
# 数据处理逻辑
return cleaned_data
def save_data(cleaned_data: dict):
# 数据存储逻辑
pass
@app.post("/data")
async def handle_data(
data: dict,
background_tasks: BackgroundTasks
):
cleaned = process_data(data)
background_tasks.add_task(save_data, cleaned)
2.2 依赖管理器实现
创建高级任务管理器类:
from pydantic import BaseModel
from typing import List, Callable
class TaskDependency(BaseModel):
task: Callable
depends_on: List[str] = []
class TaskManager:
def __init__(self):
self.tasks = {}
def add_task(self, name: str, task: Callable, dependencies: List[str]):
self.tasks[name] = TaskDependency(
task=task,
depends_on=dependencies
)
def resolve_dependencies(self):
# 实现依赖解析算法
pass
三、异常处理机制
3.1 错误隔离配置
from fastapi import HTTPException
def safe_task():
try:
# 任务逻辑
except Exception as e:
print(f"任务失败: {str(e)}")
@app.post("/safe-task")
async def create_safe_task(background_tasks: BackgroundTasks):
background_tasks.add_task(safe_task)
3.2 重试机制实现
from tenacity import retry, stop_after_attempt
@retry(stop=stop_after_attempt(3))
def retryable_task():
# 可能失败的任务逻辑
pass
课后Quiz
-
当多个后台任务存在数据依赖时,如何保证执行顺序? 答案:通过任务管理器进行拓扑排序,确保依赖任务先执行
-
后台任务抛出未捕获异常会导致什么后果? 答案:不会影响主请求响应,但会中断后续任务执行
常见报错处理
错误现象:RuntimeError: No response object found
- 原因分析:在非请求上下文中访问响应对象
- 解决方案:使用
BackgroundTasks代替直接操作响应对象 - 预防建议:遵循FastAPI的依赖注入机制
运行环境要求:
fastapi>=0.68.0
pydantic==1.10.7
tenacity==8.0.1
代码示例说明: 示例实现了一个包含依赖解析能力的任务管理器,通过拓扑排序算法处理复杂任务依赖关系。使用pydantic进行参数验证,保证任务添加的规范性。