在Linux系统中配置Python的日志系统,可以通过多种方式实现,包括使用Python的内置logging模块、配置文件(如INI、JSON、YAML格式)以及第三方库。以下是一些常见的配置方法:
logging模块Python的logging模块提供了灵活的日志记录功能。可以通过编程方式配置日志系统,也可以使用配置文件。
import logging
# 创建一个logger
logger = logging.getLogger('my_logger')
logger.setLevel(logging.DEBUG)
# 创建handlers
c_handler = logging.StreamHandler()
c_handler.setLevel(logging.INFO)
f_handler = logging.FileHandler('my_app.log')
f_handler.setLevel(logging.ERROR)
# 创建formatters并添加到handlers
c_format = logging.Formatter('%(name)s - %(levelname)s - %(message)s')
c_handler.setFormatter(c_format)
f_format = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
f_handler.setFormatter(f_format)
# 将handlers添加到logger
logger.addHandler(c_handler)
logger.addHandler(f_handler)
# 使用logger
logger.debug('This is a debug message')
logger.info('This is an info message')
logger.warning('This is a warning message')
logger.error('This is an error message')
logger.critical('This is a critical message')
可以使用logging.config.fileConfig()函数从INI文件加载配置。
logging.ini
[loggers]
keys=root,my_logger
[handlers]
keys=consoleHandler,fileHandler
[formatters]
keys=simpleFormatter, detailedFormatter
[logger_root]
level=DEBUG
handlers=consoleHandler
[logger_my_logger]
level=DEBUG
handlers=consoleHandler,fileHandler
qualname=my_logger
propagate=0
[handler_consoleHandler]
class=StreamHandler
level=INFO
formatter=simpleFormatter
args=(sys.stdout,)
[handler_fileHandler]
class=FileHandler
level=ERROR
formatter=detailedFormatter
args=('my_app.log', 'a')
[formatter_simpleFormatter]
format=%(name)s - %(levelname)s - %(message)s
datefmt=
[formatter_detailedFormatter]
format=%(asctime)s - %(name)s - %(levelname)s - %(message)s
datefmt=%Y-%m-%d %H:%M:%S
Python代码
import logging
import logging.config
# 加载配置文件
logging.config.fileConfig('logging.ini')
# 获取logger实例
logger = logging.getLogger('my_logger')
# 使用logger
logger.debug('This is a debug message')
logger.info('This is an info message')
logger.warning('This is a warning message')
logger.error('This is an error message')
logger.critical('This is a critical message')
还有一些第三方库可以帮助配置Python的日志系统,例如loguru。
loguru库from loguru import logger
# 配置日志
logger.add("my_app.log", level="ERROR", format="{time} {level} {message}")
# 使用logger
logger.debug('This is a debug message') # 不会记录,因为级别低于ERROR
logger.info('This is an info message') # 不会记录,因为级别低于ERROR
logger.warning('This is a warning message') # 不会记录,因为级别低于ERROR
logger.error('This is an error message') # 会记录
logger.critical('This is a critical message') # 会记录
选择哪种方法取决于具体的需求和项目的复杂性。