0
点赞
收藏
分享

微信扫一扫

python logging

十里一走马 2022-01-04 阅读 94

python 使用fileconfig配置logging,控制logging的输出。配置文件1如下:

[loggers]
# 配置logger信息。
# 必须包含一个名字叫做root的logger,当使用无参函数logging.getLogger()时,默认返回root这个logger;
# 其他自定义logger可以通过 logging.getLogger("{name}") 方式进行调用
keys=root,file,error
[handlers]
# 定义声明handlers信息。
keys=fileHandler,consoleHandler,errorHandler
[formatters]
# 设置日志格式
keys=simpleFormatter

[logger_root]
# 对loggers中声明的logger进行逐个配置,且要一一对应;
# 在所有的logger中,必须制定level和handlers这两个选项,
# handlers可以指定多个,中间用逗号隔开,比如handlers=fileHandler,consoleHandler,同时制定使用控制台和文件输出日志
# 对于非root logger,还需要添加一些额外的option:
# 其中qualname表示它在logger层级中的名字,在应用代码中通过这个名字制定所使用的handler,即 logging.getLogger("file"),
level=DEBUG
handlers=consoleHandler,fileHandler,errorHandler

[logger_file]
level=DEBUG
handlers=fileHandler
qualname=file
propagate=0

[logger_error]
level=ERROR
handlers=errorHandler
qualname=error
propagate=0 

[handler_consoleHandler]
# 在handler中,必须指定class和args这两个option,
# 常用的class包括 StreamHandler(仅将日志输出到控制台)、FileHandler(将日志信息输出保存到文件)、RotaRotatingFileHandler(将日志输出保存到文件中,并设置单个日志wenj文件的大小和日志文件个数);;
# args表示传递给class所指定的handler类初始化方法参数,它必须是一个元组(tuple)的形式,即便只有一个参数值也需要是一个元组的形式;里面指定输出路径,比如输出的文件名称等。level与logger中的level一样,
# formatter指定的是该处理器所使用的格式器,这里指定的格式器名称必须出现在formatters这个section中,且在配置文件中必须要有这个formatter的section定义;如果不指定formatter则该handler将会以消息本身作为日志消息进行记录,而不添加额外的时间、日志器名称等信息;
level=DEBUG
class=StreamHandler
args=(sys.stdout,)
formatter=simpleFormatter

[handler_fileHandler]
class=FileHandler
args=('/data/log.log', 'a')
level=DEBUG
formatter=simpleFormatter

[handler_errorHandler]
class=FileHandler
args=('/data/log_error.log', 'a')
level=ERROR
formatter=simpleFormatter

[formatter_simpleFormatter]
format=%(asctime)s - %(pathname)s[line:%(lineno)d] - %(levelname)s: %(message)s
#datefmt=%Y-%m-%d %H:%M:%S

测试程序:

mport logging.config

logging.config.fileConfig('logging.ini', disable_existing_loggers=False)
logger = logging.getLogger(__name__)

logger.info("info msg")
logger.debug("debug msg")
logger.warning('warning msg')
logger.error('error msg')
logger.critical('critical msg')

logger = logging.getLogger('error')

logger.info("error info msg")
logger.debug("error debug msg")
logger.warning('error warning msg')
logger.error('error error msg')
logger.critical('error critical msg')

logger = logging.getLogger('file')

logger.info("file info msg")
logger.debug("file debug msg")
logger.warning('file warning msg')
logger.error('file error msg')
logger.critical('file critical msg')

另外,linux服务器中默认时间区时是UTC,修改为上海的时间的修改方法参考 Ubuntu 区时修改


  1. Python通过logging.config.fileConfig()配置日志 ↩︎

举报

相关推荐

0 条评论