首页 > 编程 > Python > 正文

python+logging+yaml实现日志分割

2019-11-25 12:16:52
字体:
来源:转载
供稿:网友

本文实例为大家分享了python+logging+yaml实现日志分割的具体代码,供大家参考,具体内容如下

1、建立log.yaml文件

version: 1disable_existing_loggers: Falseformatters: simple:  format: "%(asctime)s - %(filename)s - %(levelname)s - %(message)s"  datefmt: '%F %T' handlers: console:  class: logging.StreamHandler  level: DEBUG  formatter: simple  stream: ext://sys.stdout info_file_handler:  class: logging.handlers.TimedRotatingFileHandler  level: DEBUG  formatter: simple  filename: ./mylog/log.log #这个路径根据自己的日志存放路径填写  interval: 1  backupCount: 2 #most 2 extensions  encoding: utf8  when: H #这里是按小时生成root: level: INFO handlers: [console, info_file_handler]

2、在自己的app.py中引用log.yaml

import yamlimport logging.configimport os def setup_logging(default_path='log.yaml', default_level=logging.INFO): """ Setup logging configuration """ if os.path.exists("mylog"):  pass else:  os.mkdir('mylog') path = default_path if os.path.exists(path):  with open(path, 'rt') as f:   config = yaml.load(f.read())  logging.config.dictConfig(config) else:  logging.basicConfig(level=default_level)  print('the input path doesn/'t exist')setup_logging(default_path='./log.yaml')logger = logging.getLogger()

之后就可以在需要日志的业务节点上使用logger.info或者其他级别输出日志信息

3、生成的日志文件效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表