python logging的简单使用

logging是python中负责处理日志的模块
  我们对其进行简单的封装,以方便使用
  我们采取配置文件形式来进行日志的配置

class MyLogger():
    """日志类 加载配置文件并获得logger"""

    log_instance = None
    @staticmethod
    def initLogConf():
        """从当前目录加载日志配置文件"""
        current = os.path.dirname(__file__)
        logging.config.fileConfig(current+os.path.sep+'logging.conf')

    @staticmethod
    def getLogger(name=''):
        """获得logger
            :param name  logger名称,默认获得root logger"""
        if MyLogger.log_instance == None:
            MyLogger.initLogConf()
        MyLogger.log_instance = logging.getLogger(name)
        return MyLogger.log_instance

log_instance 是类属性,类属性是属于类的。所有当前类的 实例 都共享 类 的类属性。
  initlogConf() 是用来加载日志配置文件
  getLogger(name) 根据logger名称来获取logger
  在其中,如果log_instance为None,则获取一个logger。如果log_instance不为None,则继续使用当前的logger。以此实现了单列模式。
  这两个方法都是 静态方法,静态方法就是一普通函数,为了更加oop(面向对象)而被塞进了类里
python 静态方法,类方法,实例方法的区别
下面是配置文件
  其中MultiprocessHandler是自定义的支持多进程版的MultiprocessHandler
python 多进程日志 logging

#logging配置文件

#定义logger模块,root是父类,必须存在,其他的自定义
#logging。getLogger(name) 相当于向loggging模块注册了一种日志打印
#如果name为loggers里面keys的值,则调用对应的配置,如果name没有则调用默认(root)的配置
#name 中用点 . 表示继承关系
#可以有多个,以逗号隔开

[loggers]
keys=root,consolelogger,errorlogger


#实现logger对应的配置信息
#            必须是 logger_name  name为loggers中key的值
#level       日志级别,级别有 DEBUG,INFO,WARNING,ERROR,CRITICAL
#handlers    日志处理器,可以有多个 以逗号隔开
#qualname    logger的名称,通过logging.getLogger(name)获取,这里的name便是qualname
#            如果获取的logger 名称不存在,则调用默认(root)logger
#propagate   是否继承符类的配置信息,0:否 1:是

[logger_root]
level=DEBUG
handlers=consoleHandler
qualname=root

#在这里 如果propagate=1,则表示继承父类(root)的配置信息。
#也就是说 既输出到控制台(继承父类的配置)又输出到日志文件
#propagate = 0 表示仅使用自身的配置,仅输出到日志文件
[logger_consolelogger]
level=INFO
handlers=consoleHandler
qualname=consolelogger
propagate=0

[logger_errorlogger]
level=ERROR
handlers=errorHandler,errconsoleHandler
qualname=errorlogger
propagate=0

#定义handlers
[handlers]
keys=consoleHandler,errorHandler,errconsoleHandler


#handlers的具体配置实现
#必须是 handler_name  name为handlers中key的值
#class为logging包里面的handler处理器
#formatter 日志输入格式
#args handler相关参数
[handler_consoleHandler]
class=StreamHandler
level=INFO
formatter=simpleFormatter
args=(sys.stdout,)

[handler_errconsoleHandler]
class=StreamHandler
level=ERROR
formatter=simpleFormatter
args=(sys.stderr,)

[handler_errorHandler]
#class=handlers.TimedRotatingFileHandler
#这个地方要写完整的包名
class=books.util.multiprocessloghandler.MultiprocessHandler
level=ERROR
formatter=simpleFormatter
args=('error_log','D',7)
#args=('error_log','M')

#定义日志输出格式
[formatters]
keys=simpleFormatter

#日志输出格式化实现
#datefmt 日期格式 对应asctime
#----------------------------
#日志格式
#----------------------------
# %(asctime)s      年-月-日 时-分-秒,毫秒
# %(filename)s     文件名,不含目录
# %(pathname)s     目录名,完整路径
# %(funcName)s     函数名
# %(levelname)s    级别名
# %(lineno)d       行号
# %(module)s       模块名
# %(message)s      日志信息
# %(name)s         日志模块名
# %(process)d      进程id
# %(processName)s  进程名
# %(thread)d       线程id
# %(threadName)s   线程名
#----------------------------
[formatter_simpleFormatter]
format=%(levelname)s - %(name)s - %(asctime)s - %(module)s.%(funcName)s - %(message)s
datefmt=%Y-%m-%d %H:%M:%S
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,837评论 18 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,925评论 6 342
  • 本文章是我大概三年前,在上家单位使用 Python 工作时结合官方文档做的整理。现在 Python 官方文档听说已...
    好吃的野菜阅读 217,436评论 14 232
  • “我的心里装满了人。” “那么多的人怎么住的下呢?那我在哪里?” “你在左心房里面。” “为什么不是左心室?” “...
    engine木几阅读 179评论 0 0
  • 2016年02月24日 (2016-02-24 23:57:51) 你带着炽热的阳光向我走来,以照亮我卑微生命的名...
    别人家的小孩阅读 200评论 0 0