Heim > Backend-Entwicklung > Python-Tutorial > Wie kann man rohe HTTP-Anforderungs-/Antwortkörper in FastAPI effizient protokollieren?

Wie kann man rohe HTTP-Anforderungs-/Antwortkörper in FastAPI effizient protokollieren?

Mary-Kate Olsen
Freigeben: 2024-12-04 06:43:17
Original
955 Leute haben es durchsucht

How to Efficiently Log Raw HTTP Request/Response Bodies in FastAPI?

Roh-HTTP-Anfrage/-Antwort in Python FastAPI protokollieren

Anforderung:

Erfassen und speichern Sie die rohen JSON-Körper bestimmter Leiten Sie Anfragen und Antworten mit einer Datengröße von etwa 1 MB weiter, ohne die Antwortzeiten wesentlich zu beeinträchtigen.

Option 1: Verwendung von Middleware

Middleware-Konzept

Middleware fängt jede Anfrage ab, bevor sie Endpunkte erreicht, und antwortet, bevor sie an Clients gesendet wird, was eine Datenmanipulation ermöglicht. Das Problem bei der Verwendung des Anforderungstextstroms in der Middleware besteht jedoch darin, dass er für nachgeschaltete Endpunkte nicht mehr verfügbar ist. Daher verwenden wir die Funktion set_body(), um sie verfügbar zu machen.

Für Antworten verwenden Sie BackgroundTask

Die Protokollierung kann mit BackgroundTask durchgeführt werden, wodurch sichergestellt wird, dass die Protokollierung nach der Antwort erfolgt an den Kunden gesendet, wodurch Verzögerungen bei den Antwortzeiten vermieden werden.

Middleware-Beispiel

# Logging middleware
async def some_middleware(request: Request, call_next):
    req_body = await request.body()
    await set_body(request, req_body)
    response = await call_next(request)

    # Body storage in RAM
    res_body = b''
    async for chunk in response.body_iterator:
        res_body += chunk

    # Background logging task
    task = BackgroundTask(log_info, req_body, res_body)
    return Response(...)

# Endpoint using middleware
@app.post('/')
async def main(payload: Dict):
    pass
Nach dem Login kopieren

Option 2: Benutzerdefiniert APIRoute-Klasse

APIRoute-Klassenerweiterung

Durch die Erstellung einer benutzerdefinierten APIRoute-Klasse können wir Anforderungs- und Antworttexte steuern und ihre Verwendung auf bestimmte Routen über einen APIRouter beschränken.

Wichtige Überlegungen

Bei großen Antworten (z. B. Streaming-Medien) kann es bei der benutzerdefinierten Route zu RAM-Problemen oder clientseitigen Verzögerungen aufgrund des Lesens kommen gesamte Antwort in den RAM. Erwägen Sie daher, solche Endpunkte von der benutzerdefinierten Route auszuschließen.

Beispiel für eine benutzerdefinierte APIRoute-Klasse

class LoggingRoute(APIRoute):
    async def custom_route_handler(request: Request) -> Response:
        req_body = await request.body()
        response = await original_route_handler(request)

        # Response handling based on type
        if isinstance(response, StreamingResponse):
            res_body = b''
            async for item in response.body_iterator:
                res_body += item
            response = Response(...)
        else:
            response.body

        # Logging task
        task = BackgroundTask(log_info, req_body, response.body)
        response.background = task
        return response

# Endpoint using custom APIRoute
@router.post('/')
async def main(payload: Dict):
    return payload
Nach dem Login kopieren

Eine Option auswählen

Beide Optionen bieten Lösungen für die Protokollierung von Anforderungs- und Antwortdaten ohne die Reaktionszeiten erheblich beeinträchtigen. Option 1 ermöglicht eine allgemeine Protokollierung, während Option 2 eine detaillierte Kontrolle über Routen bietet, die eine Protokollierung erfordern.

Das obige ist der detaillierte Inhalt vonWie kann man rohe HTTP-Anforderungs-/Antwortkörper in FastAPI effizient protokollieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage