>백엔드 개발 >파이썬 튜토리얼 >감사를 위해 FastAPI에서 원시 HTTP 요청/응답 JSON을 효율적으로 기록하려면 어떻게 해야 합니까?

감사를 위해 FastAPI에서 원시 HTTP 요청/응답 JSON을 효율적으로 기록하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-20 20:20:11332검색

How Can I Efficiently Log Raw HTTP Request/Response JSON in FastAPI for Auditing?

특정 경로에 대해 Python FastAPI에서 원시 HTTP 요청/응답 로깅

문제:
개발 중 Kubernetes에 배포될 FastAPI를 사용하는 웹 서비스입니다. 감사 목적으로 특정 경로의 요청 및 응답에 대한 원시 JSON 본문을 기록해야 합니다. 요청 및 응답 JSON 본문의 크기는 약 1MB이며 로깅 프로세스가 응답 시간에 큰 영향을 미치지 않는 것이 중요합니다.

해결책:

옵션 1: 미들웨어 사용

  1. 미들웨어:
    함수를 정의하고 @app.middleware("http") 데코레이터를 사용하여 들어오는 요청과 나가는 응답을 처리합니다.
  2. 요청 본문 캡처:
    request.body() 또는 request.stream()을 사용하여 요청 본문을 캡처하세요.
  3. 프로세스 응답 본문:
    응답 본문을 바이트 객체로 읽고 사용자 정의 응답을 클라이언트에 반환합니다.
  4. 로그 데이터:
    BackgroundTask를 사용하여 요청 및 응답 본문을 파일이나 데이터베이스에 저장합니다.

옵션 2: 사용자 정의 APIRoute 사용 클래스

  1. 사용자 지정 APIRoute 정의:
    APIRoute 기본 클래스를 확장하여 요청 및 응답 본문을 수정할 수 있는 사용자 지정 APIRoute 클래스를 만듭니다.
  2. 요청 본문 처리:
    사용자 정의 경로 핸들러에서 캡처 엔드포인트 핸들러에 도달하기 전에 요청 본문을 처리합니다.
  3. 응답 본문 처리:
    응답 본문을 수정하고 새 응답 객체를 생성합니다. 원래 응답이 StreamingResponse인 경우 스트리밍 반복자에 로깅 기능을 추가합니다.
  4. 백그라운드 로깅:
    로깅 기능을 BackgroundTask로 응답 객체에 연결합니다.

참고:
요청 및 응답의 크기를 고려하세요. 페이로드가 크면 서버와 클라이언트 측 모두에서 메모리 문제나 지연이 발생할 수 있습니다. 로깅을 특정 경로로 제한하거나 로깅에서 스트리밍 응답을 제외해야 할 수도 있습니다.

위 내용은 감사를 위해 FastAPI에서 원시 HTTP 요청/응답 JSON을 효율적으로 기록하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.