FastAPI StreamingResponse がジェネレーター関数でのストリーミングに失敗する
FastAPI の StreamingResponse は、クライアントにデータを段階的に送り返す便利な方法ですが、場合によっては特にジェネレーター関数を使用する場合、期待どおりに動作しない可能性があります。ここでは、考えられる原因とそれぞれの解決策について詳しく説明します。
一般的な原因と解決策:
1.間違った HTTP メソッドと資格情報の処理:
データの取得に POST リクエストを使用しないでください。代わりに、GET リクエストを選択してください。また、セキュリティを強化し、URL パラメーターの汚染を回避するために、クエリ パラメーターではなく認証情報にヘッダーまたは Cookie を使用することを強くお勧めします。
2.ジェネレーター関数内のブロック操作:
ジェネレーター関数に I/O または CPU を集中的に使用する操作のブロックが含まれている場合は、潜在的なデッドロックやイベント ループの中断を防ぐために、async def の代わりに def を使用します。あるいは、async def を使用している場合は、別の ThreadPool または ProcessPool でブロック操作を実行します。
3.不完全な改行:
リクエストの iter_lines() を使用して応答データを反復処理している場合は、応答を 1 行ずつ読み取ることを考慮してください。データが到着時に表示されるようにするには、応答を変更して改行を含めるか、チャンク サイズを指定して iter_content() を使用します。
4.メディア タイプと MIME スニッフィング:
ブラウザは、コンテンツ タイプを検出するためにテキスト/プレーン応答をバッファリングする場合があります。これを回避するには、別のメディア タイプ (application/json や text/event-stream など) を使用するか、X-Content-Type-Options ヘッダーを nosniff に設定して MIME スニッフィングを無効にします。
例解決策:
以下は、偽のデータをストリーミングし、問題に対処する FastAPI アプリの実用的な実装です。前述の問題:
from fastapi import FastAPI from fastapi.responses import StreamingResponse import asyncio app = FastAPI() async def fake_data_streamer(): for i in range(10): yield b'some fake data\n\n' await asyncio.sleep(0.5) @app.get('/') async def main(): headers = {'X-Content-Type-Options': 'nosniff'} return StreamingResponse(fake_data_streamer(), headers=headers, media_type='text/plain')
ストリーミング応答の処理は、クライアント (Web ブラウザ、HTTP クライアントなど) とそれぞれの機能によって異なる場合があることに注意してください。
以上がFastAPI StreamingResponse がジェネレーター関数でストリーミングできないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。