"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Uvicorn을 사용하여 FastAPI에서 동시 HTTP 요청을 할 때 "ConnectionClosed" 오류를 방지하려면 어떻게 해야 합니까?

Uvicorn을 사용하여 FastAPI에서 동시 HTTP 요청을 할 때 "ConnectionClosed" 오류를 방지하려면 어떻게 해야 합니까?

2024년 12월 21일에 게시됨
검색:310

How Can I Avoid

Uvicorn/FastAPI에서 HTTP 요청 만들기

FastAPI 및 Uvicorn을 사용하여 구축된 HTTP 엔드포인트를 처리할 때 외부 API에서 데이터를 요청하는 것이 일반적입니다. 그러나 여러 동시 요청을 처리하는 경우 "role=SERVER 및 state=SEND_RESPONSE인 경우 이벤트 유형 ConnectionClosed를 처리할 수 없습니다."와 같은 오류가 발생할 수 있습니다. 이는 기본 HTTP 클라이언트 라이브러리 '요청'이 이러한 동시 환경에서 활용될 때 스레드로부터 완전히 안전하지 않기 때문에 발생합니다.

이 문제를 해결하려면 httpx라는 대체 HTTP 클라이언트 라이브러리 구현을 고려하십시오. FastAPI 내에서 스레드 안전 문제를 방지하는 데 도움이 되는 비동기 API를 제공합니다. 아래 예는 FastAPI에서 httpx를 사용하는 방법을 보여줍니다.

from fastapi import FastAPI, Request, BackgroundTask
from fastapi.responses import StreamingResponse, Response
from contextlib import asynccontextmanager
import httpx

@asynccontextmanager
async def lifespan(app: FastAPI):
    async with httpx.AsyncClient() as client:
        yield {'client': client}

app = FastAPI(lifespan=lifespan)

@app.get('/')
async def home(request: Request):
    client = request.state.client
    req = client.build_request('GET', 'https://www.example.com')
    r = await client.send(req, stream=True)
    return StreamingResponse(r.aiter_raw(), background=BackgroundTask(r.aclose())) 

httpx의 비동기 API를 활용하면 스레드 안전성을 유지하면서 FastAPI 내에서 HTTP 요청을 보다 효율적으로 처리할 수 있습니다. 클라이언트 개체의 'limits' 키워드 인수를 사용하여 연결 풀 크기를 추가로 사용자 정의할 수 있습니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3