-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlogging_handler.py
More file actions
33 lines (28 loc) · 1.13 KB
/
logging_handler.py
File metadata and controls
33 lines (28 loc) · 1.13 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# logging_handler.py
import logging
import os
from logging.handlers import RotatingFileHandler
# 로그 파일을 저장할 디렉터리 생성
if not os.path.exists('logs'):
os.makedirs('logs')
# 1. 로거 인스턴스 생성
logger = logging.getLogger('CardAppLogger')
logger.setLevel(logging.INFO) # 로그 레벨 설정
# 2. 핸들러 생성 (파일, 콘솔)
# 파일 핸들러: 로그를 파일에 저장, 파일 크기가 5MB를 넘으면 새 파일 생성 (최대 5개)
file_handler = RotatingFileHandler(
'logs/app.log', maxBytes=5*1024*1024, backupCount=5, encoding='utf-8'
)
# 콘솔 핸들러: 로그를 터미널(콘솔)에 출력
console_handler = logging.StreamHandler()
# 3. 포매터 생성 (로그 출력 형식 정의)
formatter = logging.Formatter(
'%(asctime)s - %(name)s - %(levelname)s - %(message)s (%(filename)s:%(lineno)d)'
)
file_handler.setFormatter(formatter)
console_handler.setFormatter(formatter)
# 4. 로거에 핸들러 추가
# 중복 로깅을 방지하기 위해 핸들러가 이미 추가되었는지 확인
if not logger.handlers:
logger.addHandler(file_handler)
logger.addHandler(console_handler)