|
|
""" |
|
|
로깅 설정 모듈 |
|
|
""" |
|
|
|
|
|
import logging |
|
|
import sys |
|
|
from pathlib import Path |
|
|
from typing import Optional |
|
|
|
|
|
|
|
|
LOG_DIR = Path(__file__).parent.parent.parent / 'logs' |
|
|
LOG_DIR.mkdir(exist_ok=True) |
|
|
|
|
|
|
|
|
LOG_FORMAT = '%(asctime)s - %(name)s - %(levelname)s - %(message)s' |
|
|
DATE_FORMAT = '%Y-%m-%d %H:%M:%S' |
|
|
|
|
|
|
|
|
def get_logger(name: str, level: int = logging.INFO) -> logging.Logger: |
|
|
""" |
|
|
로거 인스턴스 생성 및 반환 |
|
|
|
|
|
Args: |
|
|
name: 로거 이름 (일반적으로 __name__ 사용) |
|
|
level: 로그 레벨 (기본값: INFO) |
|
|
|
|
|
Returns: |
|
|
설정된 로거 인스턴스 |
|
|
""" |
|
|
logger = logging.getLogger(name) |
|
|
|
|
|
|
|
|
if logger.handlers: |
|
|
return logger |
|
|
|
|
|
logger.setLevel(level) |
|
|
|
|
|
|
|
|
console_handler = logging.StreamHandler(sys.stdout) |
|
|
console_handler.setLevel(level) |
|
|
console_formatter = logging.Formatter(LOG_FORMAT, datefmt=DATE_FORMAT) |
|
|
console_handler.setFormatter(console_formatter) |
|
|
logger.addHandler(console_handler) |
|
|
|
|
|
|
|
|
file_handler = logging.FileHandler( |
|
|
LOG_DIR / 'app.log', |
|
|
encoding='utf-8' |
|
|
) |
|
|
file_handler.setLevel(logging.DEBUG) |
|
|
file_formatter = logging.Formatter(LOG_FORMAT, datefmt=DATE_FORMAT) |
|
|
file_handler.setFormatter(file_formatter) |
|
|
logger.addHandler(file_handler) |
|
|
|
|
|
|
|
|
error_handler = logging.FileHandler( |
|
|
LOG_DIR / 'error.log', |
|
|
encoding='utf-8' |
|
|
) |
|
|
error_handler.setLevel(logging.ERROR) |
|
|
error_handler.setFormatter(file_formatter) |
|
|
logger.addHandler(error_handler) |
|
|
|
|
|
return logger |
|
|
|
|
|
|
|
|
|
|
|
|