특정 경로에 대해 Python FastAPI에서 원시 HTTP 요청/응답 로깅
문제:
개발 중 Kubernetes에 배포될 FastAPI를 사용하는 웹 서비스입니다. 감사 목적으로 특정 경로의 요청 및 응답에 대한 원시 JSON 본문을 기록해야 합니다. 요청 및 응답 JSON 본문의 크기는 약 1MB이며 로깅 프로세스가 응답 시간에 큰 영향을 미치지 않는 것이 중요합니다.
해결책:
옵션 1: 미들웨어 사용
-
미들웨어:
함수를 정의하고 @app.middleware("http") 데코레이터를 사용하여 들어오는 요청과 나가는 응답을 처리합니다.
-
요청 본문 캡처:
request.body() 또는 request.stream()을 사용하여 요청 본문을 캡처하세요.
-
프로세스 응답 본문:
응답 본문을 바이트 객체로 읽고 사용자 정의 응답을 클라이언트에 반환합니다.
-
로그 데이터:
BackgroundTask를 사용하여 요청 및 응답 본문을 파일이나 데이터베이스에 저장합니다.
옵션 2: 사용자 정의 APIRoute 사용 클래스
-
사용자 지정 APIRoute 정의:
APIRoute 기본 클래스를 확장하여 요청 및 응답 본문을 수정할 수 있는 사용자 지정 APIRoute 클래스를 만듭니다. -
요청 본문 처리:
사용자 정의 경로 핸들러에서 캡처 엔드포인트 핸들러에 도달하기 전에 요청 본문을 처리합니다.
-
응답 본문 처리:
응답 본문을 수정하고 새 응답 객체를 생성합니다. 원래 응답이 StreamingResponse인 경우 스트리밍 반복자에 로깅 기능을 추가합니다.
-
백그라운드 로깅:
로깅 기능을 BackgroundTask로 응답 객체에 연결합니다.
참고:
요청 및 응답의 크기를 고려하세요. 페이로드가 크면 서버와 클라이언트 측 모두에서 메모리 문제나 지연이 발생할 수 있습니다. 로깅을 특정 경로로 제한하거나 로깅에서 스트리밍 응답을 제외해야 할 수도 있습니다.
위 내용은 감사를 위해 FastAPI에서 원시 HTTP 요청/응답 JSON을 효율적으로 기록하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!