Maison > développement back-end > Tutoriel Python > Comment gérer efficacement les requêtes HTTP en aval dans FastAPI/Uvicorn à l'aide de httpx ?

Comment gérer efficacement les requêtes HTTP en aval dans FastAPI/Uvicorn à l'aide de httpx ?

Linda Hamilton
Libérer: 2024-12-12 18:57:11
original
655 Les gens l'ont consulté

How to Efficiently Handle Downstream HTTP Requests in FastAPI/Uvicorn Using httpx?

Faire des requêtes HTTP en aval dans FastAPI/Uvicorn à l'aide de httpx

Introduction

Lors de l'utilisation d'un Point de terminaison d'API dans FastAPI/Uvicorn qui s'appuie sur des requêtes HTTP externes, il est crucial de garantir une gestion sécurisée des threads concurrence. Cet article explore l'approche recommandée pour résoudre ce problème à l'aide de la bibliothèque httpx.

À l'aide de httpx

Dans les requêtes httpx, httpx propose une API asynchrone qui prend en charge plusieurs requêtes HTTP simultanées à l'aide d'un client partagé. Cela améliore les performances en réutilisant les connexions et les en-têtes.

Implémentation de httpx dans FastAPI

Pour utiliser httpx dans FastAPI, vous pouvez utiliser son AsyncClient :

from fastapi import FastAPI
from httpx import AsyncClient

app = FastAPI()
app.state.client = AsyncClient()

@app.on_event("shutdown")
async def shutdown_event():
    await app.state.client.aclose()
Copier après la connexion

Dans cet exemple, un client partagé est créé dans le cadre de l'état de FastAPI, permettant d'y accéder par points de terminaison.

Exemple asynchrone

Le point de terminaison suivant effectue une requête HTTP asynchrone et renvoie la réponse au client :

from fastapi import FastAPI, StreamingResponse, BackgroundTask

@app.get("/")
async def home():
    client = app.state.client
    req = client.build_request("GET", "https://www.example.com/")
    r = await client.send(req, stream=True)
    return StreamingResponse(r.aiter_raw(), background=BackgroundTask(r.aclose))
Copier après la connexion

Exemple mis à jour

Avec la dépréciation des événements de démarrage et d'arrêt, vous pouvez désormais employer un gestionnaire de durée de vie :

from fastapi import FastAPI, Request, lifespan
from starlette.background import BackgroundTask
from httpx import AsyncClient, Request

@lifespan.on_event("startup")
async def startup_handler(app: FastAPI):
    app.state.client = AsyncClient()

@lifespan.on_event("shutdown")
async def shutdown_handler():
    await app.state.client.aclose()

@app.get("/")
async def home(request: Request):
    client = request.state.client
    req = client.build_request("GET", "https://www.example.com")
    r = await client.send(req, stream=True)
    return StreamingResponse(r.aiter_raw(), background=BackgroundTask(r.aclose))
Copier après la connexion

Lecture du contenu de la réponse

Si vous devez lire le contenu de la réponse côté serveur avant de l'envoyer au client, vous pouvez utiliser un générateur :

def gen():
    async for chunk in r.aiter_raw():
        yield chunk
    await r.aclose()

return StreamingResponse(gen())
Copier après la connexion

Conclusion

En tirant parti de httpx et Grâce à son client asynchrone partagé, vous pouvez gérer efficacement les requêtes HTTP en aval dans FastAPI/Uvicorn, garantissant ainsi la sécurité des threads et l'optimisation des performances dans un environnement multithread.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal