Das Hochladen einer 100-MB-Datei mit FastAPI und Python-Anfragen dauert etwa 128 Sekunden und ist damit deutlich langsamer als die 0,5 Sekunden, die bei Verwendung von Flask benötigt werden.
Der Unterschied in der Upload-Zeit ist hauptsächlich auf die Art und Weise zurückzuführen, wie Daten in FastAPI im Vergleich zu Flask verarbeitet werden. Bei der Verarbeitung von Datei-Uploads verwendet FastAPI eine SpooledTemporaryFile mit einer standardmäßigen maximalen Größe von 1 MB für eingehende Anforderungsdaten. Wenn die Dateigröße 1 MB überschreitet, werden die Daten in eine temporäre Datei auf der Festplatte geschrieben, was zu einem langsameren Upload-Vorgang führt.
1. Synchrones Schreiben von Dateien
Definieren Sie den Endpunkt mit dem regulären Schlüsselwort def anstelle des Schlüsselworts async def und schreiben Sie die Datei synchron.
2. Asynchrones Schreiben (mit aiofiles)
Definieren Sie den Endpunkt mit dem Schlüsselwort async def und verwenden Sie aiofiles für das asynchrone Schreiben von Dateien. Bei diesem Ansatz muss auf den Abschluss der Dateivorgänge gewartet werden.
3. Mit request.stream()
Greifen Sie mit request.stream() auf den Anfragetext als Stream zu. Mit dieser Methode können Datenblöcke verarbeitet werden, ohne dass der gesamte Text im Speicher oder auf der Festplatte gespeichert wird, wodurch die Upload-Leistung verbessert wird.
Für eine optimale Leistung beim Hochladen größerer Dateien sollten Sie die Verwendung der Anfrage in Betracht ziehen .stream()-Methode. Dieser Ansatz umgeht die maximale Größenbeschränkung von 1 MB und ermöglicht die direkte Verarbeitung von Datenblöcken ohne zusätzliche Schreib-/Lesevorgänge.
Das obige ist der detaillierte Inhalt vonWarum ist UploadFile von FastAPI im Vergleich zu Flask langsam?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!