소개
Requests는 파이썬에서 많이 사용되는 HTTP 라이브러리입니다. 이 라이브러리를 사용하여 HTTP 요청을 보낼 때 로깅(logging)을 설정하면 디버깅이나 이슈 해결 시 유용한 정보를 확인할 수 있습니다. 이번 블로그 포스트에서는 Requests 로깅을 설정하는 방법을 알아보겠습니다.
로깅 레벨 설정하기
Requests에서 로깅을 설정하려면 logging
모듈을 사용해야 합니다. 먼저, Requests의 로깅 레벨을 설정해야 하는데, 이는 요청 및 응답에 대한 로그 메시지를 어느 수준까지 출력할 것인지 결정합니다. 로깅 레벨은 다음과 같이 설정할 수 있습니다:
logging.NOTSET
: 모든 로깅 메시지 출력 (가장 상세한 수준)logging.DEBUG
: 디버깅 관련 로깅 메시지 출력logging.INFO
: 정보 관련 로깅 메시지 출력logging.WARNING
: 경고 관련 로깅 메시지 출력logging.ERROR
: 에러 관련 로깅 메시지 출력logging.CRITICAL
: 치명적인 오류 관련 로깅 메시지 출력 (가장 상위 수준)
로깅 레벨을 설정하려면 다음과 같이 코드를 작성합니다:
import logging
logging.basicConfig(level=logging.INFO)
위의 예제에서는 로깅 레벨을 INFO
로 설정하였습니다. 이제 Requests를 사용할 때 해당 로깅 레벨에 적합한 메시지가 출력됩니다.
로그 포맷 설정하기
로깅 레벨을 설정했다면 다음으로 로그 메시지의 포맷을 설정할 수 있습니다. 이는 출력되는 로그 메시지의 형식을 제어하는 데 사용됩니다. 다음과 같이 코드를 작성하여 로그 포맷을 설정할 수 있습니다:
import logging
logging.basicConfig(format='%(levelname)s:%(message)s')
위의 예제에서는 로그 메시지의 포맷을 ‘[로그레벨]: [메시지]’로 설정하였습니다. 예를 들어, [INFO]: GET request sent
와 같은 형태로 출력됩니다.
예외 처리하기
Requests를 사용하는 동안 예외가 발생할 수 있습니다. 따라서 예외 처리를 통해 예외 상황을 로깅할 수 있습니다. 이를 위해 try-except
문을 사용합니다. 예를 들어:
import logging
import requests
logging.basicConfig(level=logging.ERROR)
try:
response = requests.get('https://www.example.com')
response.raise_for_status()
except requests.exceptions.HTTPError as errh:
logging.error(f"HTTP Error: {errh}")
except requests.exceptions.ConnectionError as errc:
logging.error(f"Connection Error: {errc}")
except requests.exceptions.Timeout as errt:
logging.error(f"Timeout Error: {errt}")
except requests.exceptions.RequestException as err:
logging.error(f"An unexpected error occurred: {err}")
위의 예제에서는 requests.get()
을 사용하여 요청을 보내고, response.raise_for_status()
를 사용하여 응답 상태 코드를 확인합니다. 예외가 발생하면 해당 예외에 대한 로깅 메시지가 출력됩니다.
결론
이제 Requests를 사용할 때 로깅을 설정하는 방법을 알게 되었습니다. 로깅을 사용하면 HTTP 요청과 응답에 대한 디버깅 정보를 확인하고 이슈 해결에 도움이 될 수 있습니다. 로깅을 설정하여 안정적이고 견고한 애플리케이션을 개발하는 데 도움이 되길 바랍니다.
더 자세한 내용과 Requests의 모든 기능에 대해서는 공식 문서를 참조하시기 바랍니다.