Heim > Backend-Entwicklung > Python-Tutorial > So verwenden Sie die Nachrichtenwarteschlange für die asynchrone Aufgabenverarbeitung in FastAPI

So verwenden Sie die Nachrichtenwarteschlange für die asynchrone Aufgabenverarbeitung in FastAPI

WBOY
Freigeben: 2023-07-30 21:21:13
Original
2543 Leute haben es durchsucht

So verwenden Sie die Nachrichtenwarteschlange für die asynchrone Aufgabenverarbeitung in FastAPI

Einführung:
In Webanwendungen kommt es häufig vor, dass zeitaufwändige Aufgaben verarbeitet werden müssen, z. B. das Versenden von E-Mails, das Erstellen von Berichten usw. Wenn diese Aufgaben in einen synchronen Anfrage-Antwort-Prozess gestellt werden, müssen Benutzer lange warten, was die Benutzererfahrung und die Antwortgeschwindigkeit des Servers verringert. Um dieses Problem zu lösen, können wir die Nachrichtenwarteschlange für die asynchrone Aufgabenverarbeitung verwenden. In diesem Artikel wird erläutert, wie Nachrichtenwarteschlangen zur Verarbeitung asynchroner Aufgaben im FastAPI-Framework verwendet werden, und es werden entsprechende Codebeispiele bereitgestellt.

1. Was ist eine Nachrichtenwarteschlange?
Nachrichtenwarteschlange ist ein Mechanismus für die asynchrone Kommunikation zwischen Anwendungskomponenten. Es ermöglicht Sendern, Nachrichten an eine Warteschlange zu senden, und Empfängern, diese Nachrichten aus der Warteschlange abzurufen und zu verarbeiten. Der Vorteil der Nachrichtenwarteschlange besteht darin, dass Sender und Empfänger entkoppelt sind. Der Sender muss nicht warten, bis der Empfänger die Verarbeitung abgeschlossen hat, bevor er mit der Ausführung anderer Aufgaben fortfährt, wodurch der Durchsatz und die Parallelitätsleistung des Systems verbessert werden.

2. Wählen Sie einen geeigneten Nachrichtenwarteschlangendienst
Bevor wir die Nachrichtenwarteschlange verwenden, müssen wir einen geeigneten Nachrichtenwarteschlangendienst auswählen. Zu den derzeit am häufigsten verwendeten Nachrichtenwarteschlangendiensten gehören RabbitMQ, Kafka, ActiveMQ usw. Diese Nachrichtenwarteschlangendienste bieten umfangreiche Funktionen und Zuverlässigkeitsgarantien, und wir können den geeigneten Dienst entsprechend den tatsächlichen Anforderungen auswählen.

3. Nachrichtenwarteschlange in FastAPI verwenden
Um die Nachrichtenwarteschlange in FastAPI verwenden zu können, müssen wir zunächst die entsprechende Nachrichtenwarteschlangen-Clientbibliothek installieren. Am Beispiel von RabbitMQ können Sie es über den Befehl pip install aio-pika installieren. Nach Abschluss der Installation können wir die entsprechenden Abhängigkeiten und Module in die Hauptdatei von FastAPI einführen. pip install aio-pika进行安装。安装完成后,我们可以在FastAPI的主文件中引入相应的依赖项和模块。

from fastapi import FastAPI
from fastapi import BackgroundTasks
from aio_pika import connect, IncomingMessage
Nach dem Login kopieren

接下来,我们需要配置消息队列的连接信息,并编写处理消息的函数。

AMQP_URL = "amqp://guest:guest@localhost/"
QUEUE_NAME = "task_queue"

async def process_message(message: IncomingMessage):
    # 在这里编写异步任务的处理逻辑
    # 例如发送邮件、生成报表等
    print(f"Received message: {message.body}")
    # 这里可以根据实际情况进行任务处理
    # ...

    message.ack()
Nach dem Login kopieren

然后,我们需要在FastAPI应用程序中定义一个接口,用来接收需要进行异步处理的任务。

app = FastAPI()

@app.post("/task")
async def handle_task(request: dict, background_tasks: BackgroundTasks):
    connection = await connect(AMQP_URL)
    channel = await connection.channel()
    queue = await channel.declare_queue(QUEUE_NAME)

    # 发送任务给消息队列
    await queue.publish(
        body=str(request).encode(),
        routing_key=QUEUE_NAME
    )

    connection.close()

    return {"message": "Task submitted successfully"}
Nach dem Login kopieren

上述代码定义了一个POST接口/task

async def listen_to_queue():
    connection = await connect(AMQP_URL)
    channel = await connection.channel()
    queue = await channel.declare_queue(QUEUE_NAME)

    # 持续监听消息队列
    async with queue.iterator() as queue_iterator:
        async for message in queue_iterator:
            async with message.process():
                await process_message(message)
Nach dem Login kopieren

Als nächstes müssen wir die Verbindungsinformationen der Nachrichtenwarteschlange konfigurieren und die Funktion zum Verarbeiten der Nachricht schreiben.

app = FastAPI()

@app.on_event("startup")
async def startup_event():
    # 启动消息队列监听
    await listen_to_queue()
Nach dem Login kopieren
Dann müssen wir eine Schnittstelle in der FastAPI-Anwendung definieren, um Aufgaben zu empfangen, die eine asynchrone Verarbeitung erfordern.

rrreee

Der obige Code definiert eine POST-Schnittstelle /task. Wenn eine Anforderung empfangen wird, wird die Aufgabe zur asynchronen Verarbeitung an die Nachrichtenwarteschlange übergeben und nach Abschluss der Verarbeitung wird eine erfolgreiche Nachricht zurückgegeben.

Schließlich müssen wir eine asynchrone Funktion schreiben, um die Nachrichtenwarteschlange abzuhören und asynchrone Aufgaben zu verarbeiten.

rrreee
Am Eingang der FastAPI-Anwendung müssen wir eine asynchrone Funktion starten, um die Nachrichtenwarteschlange abzuhören.

rrreee

Zu diesem Zeitpunkt haben wir die Konfiguration und Codierung der Verwendung von Nachrichtenwarteschlangen für die asynchrone Aufgabenverarbeitung in FastAPI abgeschlossen.

Fazit:

Durch die Verwendung von Nachrichtenwarteschlangen können wir zeitaufwändige Aufgaben vom Synchronisierungsprozess trennen und die Anwendungsleistung und Antwortgeschwindigkeit verbessern. In diesem Artikel wird beschrieben, wie Nachrichtenwarteschlangen in FastAPI konfiguriert und verwendet werden, und es werden entsprechende Codebeispiele bereitgestellt. Ich hoffe, dass es Ihnen bei der Entwicklung der asynchronen Aufgabenverarbeitung hilfreich sein wird.

Referenzen: 🎜[1] https://fastapi.tiangolo.com/🎜[2] https://docs.aio-pika.readthedocs.io/🎜🎜(Hinweis: Die obigen Codebeispiele dienen nur als Referenz. tatsächlich Es muss entsprechend der spezifischen Situation angepasst werden)🎜.

Das obige ist der detaillierte Inhalt vonSo verwenden Sie die Nachrichtenwarteschlange für die asynchrone Aufgabenverarbeitung in FastAPI. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage