python日志配置文件_python之logging的文件配置

logging模块的四个重点:

logger:日志生产者

handler:日志接收处理者(logger生产日志送给handler)

formatter:日志格式化(在handler接收到日志后需要绑定format日志格式处理)

filter:暂时略过

在日志配置文件如何定义logger,handler,formatter?

loggers:keys关联多个logger,其中root为必须(loggers与logger)

level:日志级别

handler:处理后输出位置

qualname:定义logger对象是需要绑定的日志策略名字

progarate:是否将日志传给上游(多级上游,顶级为root,以foo.A.B类似表示,foo就是A,B的顶级,A就是B的父级)

....

handlers:keys关联多个定义的handler

class:日志输出位置,StreamHandler,FileHandler,.......

level:日志级别

formatter:日志格式

args:日志处理对象的参数,比如StreamHandler输出参数可以是sys.stdout,必须是元组格式

formatters:关联多个定义了的formatter

format:日志格式

datefmt:时间格式

日志格式定义:

%(levelno)s: 打印日志级别的数值

%(levelname)s: 打印日志级别名称

%(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0]

%(filename)s: 打印当前执行程序名

%(funcName)s: 打印日志的当前函数

%(lineno)d: 打印日志的当前行号

%(asctime)s: 打印日志的时间

%(thread)d: 打印线程ID

%(threadName)s: 打印线程名称

%(process)d: 打印进程ID

%(message)s: 打印日志信息

配置文件定义:

loggers关联多个logger,formatters关联多个formatter,handlers关联多个handler

logger关联handler,handler定义输出与关联formatter

配置案例:

定义日志策略:

[loggers]

keys=root,l1,l2,l3

[handlers]

keys=h1,h2,h3

[formatters]

keys=f1,f2,f3

[logger_root]

level=NOTSET

handlers=h1

[logger_l1]

level=DEBUG

handlers=h1

qualname=h1

progarate=1

[logger_l2]

level=INFO

handlers=h2

qualname=h2

progarate=0

[logger_l3]

level=ERROR

handlers=h3

qualname=h3

progarate=0

[handler_h1]

class=StreamHandler

level=NOTSET

formatter=f1

args=(sys.stdout,)

[handler_h2]

class=FileHandler

level=INFO

formatter=f2

args=('l2h2f2.txt','a')

[handler_h3]

class=FileHandler

level=ERROR

formatter=f3

args=('l3h3f3.txt','a')

[formatter_f1]

format='%(levelno)s - %(levelname)s - %(pathname)s - %(filename)s - %(funcName)s - %(lineno)d - %(thread)d - %(threadName)s - %(process)d - %(message)s'

[formatter_f2]

format='%(levelno)s - %(pathname)s - %(filename)s - %(funcName)s - %(lineno)d - %(thread)d - %(threadName)s - %(process)d - %(message)s'

[formatter_f3]

format='%(levelno)s - %(filename)s - %(funcName)s - %(lineno)d - %(thread)d - %(threadName)s - %(process)d - %(message)s'

代码定义日志:

import logging

import logging.config

logging.config.fileConfig('logging1.ini')

# logger1 = logging.getLogger('h1')

# logger1.debug('debug message')

# logger1.info('info message')

# logger1.warning('warning message')

# logger1.error('error message')

# logger1.critical('critical message')

logger2 = logging.getLogger('h2')

logger2.debug('debug message')

logger2.info('info message')

logger2.warning('warning message')

logger2.error('error message')

logger2.critical('critical message')

logger3 = logging.getLogger('h3')

logger3.debug('debug message')

logger3.info('info message')

logger3.warning('warning message')

logger3.error('error message')

logger3.critical('critical message')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python 日志logging 是一个非常强大、灵活的工具,可以帮助我们记录应用程序运行时的各种信息,包括错误信息、调试信息、警告信息等。logging 库提供了很多功能和配置选项,可以让我们根据实际需求灵活地控制日志的输出。 日志长度是指在日志文件中每条日志消息的字符数。一般来说,日志长度应该控制在一定范围内,过长的日志会导致日志文件变得异常庞大,不便于查看和分析。因此,我们需要对日志长度进行限制。 下面介绍一些关于 Python 日志logging 的理解和实践经验: 1. 日志级别 logging 库提供了 5 个日志级别:DEBUG、INFO、WARNING、ERROR 和 CRITICAL,分别代表调试信息、普通信息、警告信息、错误信息和致命错误信息。我们可以根据实际需求设置不同的日志级别,以便过滤出需要的信息。 2. 日志格式 logging 库提供了多种日志格式,包括简单格式、详细格式、自定义格式等。我们可以根据实际需求选择合适的日志格式,以便更好地记录和分析日志。 3. 控制日志输出 logging 库提供了多种输出方式,包括输出到控制台、输出到文件、输出到网络等。我们可以根据实际需求选择合适的输出方式,以便更好地记录和分析日志。 4. 设置日志长度 我们可以通过设置日志处理器的 maxBytes 属性和 backupCount 属性来限制日志文件的大小和数量。例如,我们可以设置每个日志文件最大为 10MB,最多保留 5 个日志文件,超过这个限制后就会自动删除旧的日志文件。 下面是一个示例代码,演示如何使用 logging 库记录日志并限制日志长度: ```python import logging from logging.handlers import RotatingFileHandler # 创建日志处理器,限制日志文件最大为 10MB,最多保留 5 个日志文件 handler = RotatingFileHandler(filename='app.log', maxBytes=10*1024*1024, backupCount=5) # 设置日志格式 formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s') handler.setFormatter(formatter) # 创建日志记录器,并设置日志级别和处理器 logger = logging.getLogger('myapp') logger.setLevel(logging.INFO) logger.addHandler(handler) # 记录日志 logger.info('This is a test message.') ``` 在上面的示例代码中,我们使用 RotatingFileHandler 日志处理器来限制日志文件的大小和数量。通过设置 maxBytes 属性和 backupCount 属性,我们可以限制日志文件最大为 10MB,最多保留 5 个日志文件。同时,我们还设置了日志格式和日志级别,以便更好地记录和分析日志。最后,我们使用 logger.info() 方法记录一条日志信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值