Heim >Backend-Entwicklung >Python-Tutorial >Gleichzeitig vs. parallel: Wie verarbeitet FastAPI Anfragen?

Gleichzeitig vs. parallel: Wie verarbeitet FastAPI Anfragen?

Linda Hamilton
Linda HamiltonOriginal
2024-12-26 20:35:10174Durchsuche

Concurrent vs. Parallel: How Does FastAPI Handle Requests?

Gleichzeitige vs. parallele Anfragen in FastAPI

In FastAPI gibt es ein weit verbreitetes Missverständnis darüber, warum asynchrone Verteidigungsendpunkte nicht immer Anfragen ausführen parallel. Dieses Verhalten wird nicht durch das Design von FastAPI verursacht, sondern hängt vielmehr damit zusammen, wie FastAPI asynchrone Programmierung nutzt.

Bei Verwendung von Def-Endpunkten führt FastAPI diese synchron in separaten Threads aus und ermöglicht so Parallelität. Asynchrone Def-Endpunkte werden jedoch normalerweise direkt in der Ereignisschleife ausgeführt und stellen so sowohl Parallelität als auch Parallelität sicher, wenn der Code mit asynchronen E/A-Vorgängen interagiert.

Synchronischer vs. asynchroner Code in FastAPI

FastAPI unterstützt asynchronen Code durch async def, wodurch die Kontrolle mithilfe von „await“ zurück an die Ereignisschleife übergeben werden kann. Diese Funktion ermöglicht nicht blockierende Vorgänge, z. B. das Warten auf Daten von einem Client oder eine Datenbankantwort. Wenn jedoch eine synchrone Aufgabe wie time.sleep() innerhalb eines asynchronen Def-Endpunkts eingesetzt wird, blockiert sie die Ereignisschleife und letztlich den Server, was zu einer sequentiellen Verarbeitung von Anfragen führt.

Externer Threadpool

Um sicherzustellen, dass blockierende Aufgaben die Ereignisschleife nicht behindern, verwendet FastAPI einen externen Threadpool, der mit def definierte Aufgaben in separaten Threads ausführt und wartet sie, bevor die Ausführung der Ereignisschleife fortgesetzt wird. Dieser Ansatz erreicht Parallelität für Def-Endpunkte, auch wenn es sich nicht um echte Parallelisierung handelt.

Best Practices

  • Verwenden Sie async def für Endpunkte, die auf asynchrone Vorgänge warten müssen.
  • Verwenden Sie def für Endpunkte, die nicht mit Non-Blocking interagieren E/A oder enthalten einfache Antworten.
  • Verwenden Sie die run_in_threadpool()-Funktion von Starlette, um Blockierungsaufgaben in einem separaten Thread für asynchrone Def-Endpunkte auszuführen.
  • Erkunden Sie die Verwendung asynchroner Methoden wie loop.run_in_executor(), Dies bietet mehr Flexibilität bei der asynchronen Ausführung synchroner Aufgaben.
  • Erwägen Sie die Verwendung externer Tools wie Celery oder AsyncIOScheduler für umfangreiche Hintergrundberechnungen.

Das obige ist der detaillierte Inhalt vonGleichzeitig vs. parallel: Wie verarbeitet FastAPI Anfragen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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