logging 多module 记录日志

本文可以实现实际工作中要求写多个文件,别且依靠文件名作为日志的logger发送到日志服务器去区分

testlog.py

import logging

import threading
class LOGGER:
    def __init__(self):
        pass
    di={}
    __lock = threading.Lock()
    @staticmethod
    def getinstance(logName):
        if not LOGGER.di.has_key(logName):
            LOGGER.__lock.acquire()
            if not LOGGER.di.has_key(logName):
                LOGGER.di[logName]=LOGGER()
                LOGGER.di[logName]=logging.getLogger(logName)
                handler = logging.FileHandler('ts.log')
                formatter = logging.Formatter('%(asctime)s %(name)s %(message)s')
                handler.setFormatter(formatter)
                LOGGER.di[logName].addHandler(handler)
                LOGGER.di[logName].setLevel(logging.INFO)
            LOGGER.__lock.release()
        return LOGGER.di[logName]


if __name__=='__main__':

        while True:

            x=LOGGER.getinstance('test1')

            x.info('1111111')

            y=LOGGER.getinstance('test2')

            y.info('22222222222')

            time.sleep(1)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值