> 백엔드 개발 > 파이썬 튜토리얼 > 파이썬 로깅 :로 루루 대 벌목

파이썬 로깅 :로 루루 대 벌목

DDD
풀어 주다: 2025-01-26 16:11:13
원래의
679명이 탐색했습니다.

Python 로그 라이브러리 비교: 로깅과 loguru

1. 로그루는 로깅을 단순화합니다

Python Logging: loguru vs logging

로깅은 Python 개발에서 중요한 도구입니다. 이는 개발자가 프로그램 실행 상태를 기록하고, 문제를 디버깅하고, 시스템 상태를 모니터링하는 데 도움이 됩니다. Python에는 로깅 라이브러리가 함께 제공됩니다. 그러나 요구 사항이 바뀌면서 많은 사람들이 로그루를 대안으로 사용하기 시작했습니다. 이 문서에서는 이 두 라이브러리를 비교하고 더 적합한 로깅 솔루션을 선택하는 데 도움을 줍니다.

Loguru는 인기 있는 타사 로깅 라이브러리입니다. 구성 프로세스를 단순화하고, 연결된 호출을 지원하며, 더 풍부한 기능을 제공함으로써 로깅에 대한 강력한 대안이 됩니다.

로구루의 장점

  • 간단한 구성: Loguru는 복잡한 구성을 만들 필요가 없습니다. 복잡한 로그 구성은 코드 몇 줄만으로 완료할 수 있습니다.
  • 연결 통화: 연결 통화를 지원하여 로깅을 더욱 직관적으로 만듭니다.
  • 멀티 타겟 출력: 로그와 파일을 동시에 쉽게 콘솔에 출력할 수 있으며 풍부한 형식 구성을 지원합니다.
  • 추가 기능: 자동 로그 압축, 로그 파일 순환, 로그 보존 기간 등의 기능을 지원합니다.

로구루 기본 예시

<code class="language-python">from loguru import logger

# 配置日志
logger.add("app.log", rotation="500 MB")  # 文件大小超过 500 MB 时自动轮转

# 记录日志消息
logger.info("这是一个信息消息。")
logger.warning("这是一个警告消息。")
logger.error("这是一个错误消息。")</code>
로그인 후 복사

이 예에서는 여러 개의 추가 프로세서를 구성할 필요가 없습니다. 파일 로그 구성은 간단히 logger.add()를 호출하여 쉽게 수행할 수 있습니다.

파일과 콘솔로 동시에 출력

Loguru는 동시에 파일과 콘솔로 쉽게 출력할 수 있습니다.

<code class="language-python">from loguru import logger
import sys

# 添加日志输出到文件和控制台
logger.add("app.log", rotation="500 MB", retention="10 days")  # 文件轮转和保留 10 天
logger.add(sys.stdout, level="INFO")  # 输出到控制台

# 记录日志消息
logger.info("这是一个信息消息。")
logger.warning("这是一个警告消息。")
logger.error("这是一个错误消息。")</code>
로그인 후 복사

여기서 logger.add(sys.stdout, level="INFO")는 추가 구성 없이 콘솔에 로그를 표시할 수 있습니다.

2. Python 내장 로깅 라이브러리의 장점과 단점

장점

  • 표준 라이브러리의 일부: 로깅은 Python 표준 라이브러리의 일부이므로 추가 설치가 필요하지 않으며 크로스 플랫폼입니다.
  • 높은 사용자 정의 가능: 로깅은 강력한 사용자 정의 기능을 제공하여 로그 형식, 수준 및 대상(파일, 콘솔, 원격 서버 등)을 유연하게 제어할 수 있습니다.
  • 강력한 호환성: 많은 타사 라이브러리도 로깅을 사용하므로 다양한 로그를 원활하게 통합할 수 있습니다.

단점

  • 복잡한 구성: 로깅의 기본 사용은 상대적으로 간단하지만 약간 더 복잡한 구성은 특히 출력을 동시에 여러 대상(예: 파일)으로 출력해야 하는 경우 장황하고 직관적이지 않을 수 있습니다. 및 콘솔) )시간.
  • 체인 콜을 지원하지 않습니다: 로깅은 loguru와 같은 체인 콜을 지원하지 않으며 레이어별로 구성해야 합니다.

기본 예시

로깅의 간단한 로그 예시는 다음과 같습니다.

<code class="language-python">import logging

# 配置日志
logging.basicConfig(
    level=logging.INFO,
    format='%(asctime)s - %(levelname)s - %(message)s',
    filename='app.log',
    filemode='a'
)

# 记录日志消息
logging.info("这是一个信息消息。")
logging.warning("这是一个警告消息。")
logging.error("这是一个错误消息。")</code>
로그인 후 복사

이 예에서는 로그가 app.log 파일에 기록되지만 콘솔에는 표시되지 않습니다. 콘솔과 파일에 동시에 로그를 표시하려면 StreamHandler를 추가로 구성해야 합니다.

위 내용은 파이썬 로깅 :로 루루 대 벌목의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿