Spaces:
Running
Running
#!/usr/bin/python3 | |
# -*- coding: utf-8 -*- | |
from datetime import datetime | |
import logging | |
from logging.handlers import RotatingFileHandler, TimedRotatingFileHandler | |
import os | |
from zoneinfo import ZoneInfo # Python 3.9+ 自带,无需安装 | |
def get_converter(tz_info: str = "Asia/Shanghai"): | |
def converter(timestamp): | |
dt = datetime.fromtimestamp(timestamp, ZoneInfo(tz_info)) | |
result = dt.timetuple() | |
return result | |
return converter | |
def setup_size_rotating(log_directory: str, tz_info: str = "Asia/Shanghai"): | |
fmt = "%(asctime)s|%(name)s|%(levelname)s|%(filename)s|%(lineno)d|%(message)s" | |
formatter = logging.Formatter( | |
fmt=fmt, | |
datefmt="%Y-%m-%d %H:%M:%S %z" | |
) | |
formatter.converter = get_converter(tz_info) | |
stream_handler = logging.StreamHandler() | |
stream_handler.setLevel(logging.INFO) | |
stream_handler.setFormatter(formatter) | |
# main | |
main_logger = logging.getLogger("main") | |
main_logger.addHandler(stream_handler) | |
main_info_file_handler = RotatingFileHandler( | |
filename=os.path.join(log_directory, "main.log"), | |
maxBytes=100*1024*1024, # 100MB | |
encoding="utf-8", | |
backupCount=2, | |
) | |
main_info_file_handler.setLevel(logging.INFO) | |
main_info_file_handler.setFormatter(formatter) | |
main_logger.addHandler(main_info_file_handler) | |
# http | |
http_logger = logging.getLogger("http") | |
http_logger.addHandler(stream_handler) | |
http_file_handler = RotatingFileHandler( | |
filename=os.path.join(log_directory, "http.log"), | |
maxBytes=100*1024*1024, # 100MB | |
encoding="utf-8", | |
backupCount=2, | |
) | |
http_file_handler.setLevel(logging.DEBUG) | |
http_file_handler.setFormatter(formatter) | |
http_logger.addHandler(http_file_handler) | |
# api | |
api_logger = logging.getLogger("api") | |
api_logger.addHandler(stream_handler) | |
api_file_handler = RotatingFileHandler( | |
filename=os.path.join(log_directory, "api.log"), | |
maxBytes=10*1024*1024, # 10MB | |
encoding="utf-8", | |
backupCount=2, | |
) | |
api_file_handler.setLevel(logging.DEBUG) | |
api_file_handler.setFormatter(formatter) | |
api_logger.addHandler(api_file_handler) | |
# alarm | |
alarm_logger = logging.getLogger("alarm") | |
alarm_file_handler = RotatingFileHandler( | |
filename=os.path.join(log_directory, "alarm.log"), | |
maxBytes=1*1024*1024, # 1MB | |
encoding="utf-8", | |
backupCount=2, | |
) | |
alarm_file_handler.setLevel(logging.DEBUG) | |
alarm_file_handler.setFormatter(logging.Formatter(fmt)) | |
alarm_logger.addHandler(alarm_file_handler) | |
debug_file_handler = RotatingFileHandler( | |
filename=os.path.join(log_directory, "debug.log"), | |
maxBytes=1*1024*1024, # 1MB | |
encoding="utf-8", | |
backupCount=2, | |
) | |
debug_file_handler.setLevel(logging.DEBUG) | |
debug_file_handler.setFormatter(logging.Formatter(fmt)) | |
info_file_handler = RotatingFileHandler( | |
filename=os.path.join(log_directory, "info.log"), | |
maxBytes=1*1024*1024, # 1MB | |
encoding="utf-8", | |
backupCount=2, | |
) | |
info_file_handler.setLevel(logging.INFO) | |
info_file_handler.setFormatter(logging.Formatter(fmt)) | |
error_file_handler = RotatingFileHandler( | |
filename=os.path.join(log_directory, "error.log"), | |
maxBytes=1*1024*1024, # 1MB | |
encoding="utf-8", | |
backupCount=2, | |
) | |
error_file_handler.setLevel(logging.ERROR) | |
error_file_handler.setFormatter(logging.Formatter(fmt)) | |
logging.basicConfig( | |
level=logging.DEBUG, | |
datefmt="%a, %d %b %Y %H:%M:%S", | |
handlers=[ | |
debug_file_handler, | |
info_file_handler, | |
error_file_handler, | |
] | |
) | |
def setup_time_rotating(log_directory: str): | |
fmt = "%(asctime)s - %(name)s - %(levelname)s %(filename)s:%(lineno)d > %(message)s" | |
stream_handler = logging.StreamHandler() | |
stream_handler.setLevel(logging.INFO) | |
stream_handler.setFormatter(logging.Formatter(fmt)) | |
# main | |
main_logger = logging.getLogger("main") | |
main_logger.addHandler(stream_handler) | |
main_info_file_handler = TimedRotatingFileHandler( | |
filename=os.path.join(log_directory, "main.log"), | |
encoding="utf-8", | |
when="midnight", | |
interval=1, | |
backupCount=7 | |
) | |
main_info_file_handler.setLevel(logging.INFO) | |
main_info_file_handler.setFormatter(logging.Formatter(fmt)) | |
main_logger.addHandler(main_info_file_handler) | |
# http | |
http_logger = logging.getLogger("http") | |
http_file_handler = TimedRotatingFileHandler( | |
filename=os.path.join(log_directory, "http.log"), | |
encoding='utf-8', | |
when="midnight", | |
interval=1, | |
backupCount=7 | |
) | |
http_file_handler.setLevel(logging.DEBUG) | |
http_file_handler.setFormatter(logging.Formatter(fmt)) | |
http_logger.addHandler(http_file_handler) | |
# api | |
api_logger = logging.getLogger("api") | |
api_file_handler = TimedRotatingFileHandler( | |
filename=os.path.join(log_directory, "api.log"), | |
encoding='utf-8', | |
when="midnight", | |
interval=1, | |
backupCount=7 | |
) | |
api_file_handler.setLevel(logging.DEBUG) | |
api_file_handler.setFormatter(logging.Formatter(fmt)) | |
api_logger.addHandler(api_file_handler) | |
# alarm | |
alarm_logger = logging.getLogger("alarm") | |
alarm_file_handler = TimedRotatingFileHandler( | |
filename=os.path.join(log_directory, "alarm.log"), | |
encoding="utf-8", | |
when="midnight", | |
interval=1, | |
backupCount=7 | |
) | |
alarm_file_handler.setLevel(logging.DEBUG) | |
alarm_file_handler.setFormatter(logging.Formatter(fmt)) | |
alarm_logger.addHandler(alarm_file_handler) | |
debug_file_handler = TimedRotatingFileHandler( | |
filename=os.path.join(log_directory, "debug.log"), | |
encoding="utf-8", | |
when="D", | |
interval=1, | |
backupCount=7 | |
) | |
debug_file_handler.setLevel(logging.DEBUG) | |
debug_file_handler.setFormatter(logging.Formatter(fmt)) | |
info_file_handler = TimedRotatingFileHandler( | |
filename=os.path.join(log_directory, "info.log"), | |
encoding="utf-8", | |
when="D", | |
interval=1, | |
backupCount=7 | |
) | |
info_file_handler.setLevel(logging.INFO) | |
info_file_handler.setFormatter(logging.Formatter(fmt)) | |
error_file_handler = TimedRotatingFileHandler( | |
filename=os.path.join(log_directory, "error.log"), | |
encoding="utf-8", | |
when="D", | |
interval=1, | |
backupCount=7 | |
) | |
error_file_handler.setLevel(logging.ERROR) | |
error_file_handler.setFormatter(logging.Formatter(fmt)) | |
logging.basicConfig( | |
level=logging.DEBUG, | |
datefmt="%a, %d %b %Y %H:%M:%S", | |
handlers=[ | |
debug_file_handler, | |
info_file_handler, | |
error_file_handler, | |
] | |
) | |
if __name__ == "__main__": | |
pass | |