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

你可能感兴趣的:(python logging的简单使用)