国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Python logging模塊異步線程寫日志實(shí)現(xiàn)過(guò)程解析

瀏覽:114日期:2022-07-19 11:05:04

通過(guò)logging模塊,重寫一個(gè)logging2模塊,獨(dú)立開(kāi)啟線程,將待寫的日志信息異步放入隊(duì)列,做到日志輸出不影響主流程性能,環(huán)境python3.8

logging2.py

import osimport threadingimport queueimport timeimport datetimeimport loggingfrom logging.handlers import RotatingFileHandlerclass logging2(threading.Thread): AQueue = queue.Queue(100000) nPID = os.getpid() Adt = datetime.datetime.now().strftime(’%Y%m%d’) nCount = 1 def __init__(self, threadID, name, module, logLevel): threading.Thread.__init__(self) self.threadID = threadID self.name = name self.module = moduleprint('set loglevel: [%s]' % (logLevel) ) formatter = logging.Formatter(’%(asctime)s|%(name)s|%(process)d|%(levelname)s|%(message)s’) logfile = 'log_' + self.module + '_' + str(logging2.nPID) + '_' + str(logging2.Adt) + '.log' self.logger = logging.getLogger(__name__)self.rHandler = RotatingFileHandler(logfile, maxBytes = 10*1024*1024, backupCount = 10) self.rHandler.setFormatter(formatter)self.console = logging.StreamHandler() self.console.setFormatter(formatter)if logLevel == ’DEBUG’ : self.logger.setLevel(level = logging.DEBUG) self.rHandler.setLevel(logging.DEBUG) self.console.setLevel(logging.DEBUG) elif logLevel == ’INFO’ : self.logger.setLevel(level = logging.INFO) self.rHandler.setLevel(logging.INFO) self.console.setLevel(logging.INFO) elif logLevel == ’WARNING’ : self.logger.setLevel(level = logging.WARN) self.rHandler.setLevel(logging.WARN) self.console.setLevel(logging.WARN) elif logLevel == ’ERROR’ : self.logger.setLevel(level = logging.ERROR) self.rHandler.setLevel(logging.ERROR) self.console.setLevel(logging.ERROR)self.logger.addHandler(self.rHandler) self.logger.addHandler(self.console) #如果跨天了,則重新生成新的文件名 def reSetLog(self): AdtTemp = datetime.datetime.now().strftime(’%Y%m%d’) #比較新的時(shí)間 if AdtTemp == logging2.Adt: return(True) logging2.Adt = AdtTemp logfile = 'log_' + self.module + '_' + str(logging2.nPID) + '_' + str(AdtTemp) + '.log' self.rHandler = RotatingFileHandler(logfile, maxBytes = 1*1024, backupCount = 10)self.logger.addHandler(self.rHandler) self.logger.addHandler(self.console) logging2.nCount += 1 def run(self): print ('開(kāi)啟日志線程:' + self.name) i = 0 while True: #data = 'queue test data' #debug(data) #print('Queuesize: %s' % (logging2.AQueue.qsize())) self.reSetLog() if logging2.AQueue.empty() == False:#從隊(duì)列獲取日志消息data = logging2.AQueue.get()#解析日志消息,格式:日志級(jí)別,內(nèi)容level = list(data.keys())[0]content = data.get(level)#把內(nèi)容按分隔符|解析成list傳入?yún)?shù)lstContent = list(content.split(’|’))if level == ’DEBUG’ : self.logger.debug(*lstContent)elif level == ’INFO’ : self.logger.info(*lstContent)elif level == ’WARNING’ : self.logger.warn(*lstContent)elif level == ’ERROR’ : self.logger.error(*lstContent) else:time.sleep(0.5) print ('退出線程:' + self.name) def debug(*content): logMsg = '' #傳入多個(gè)參數(shù)用豎線分隔符分開(kāi) for i in range(len(content)): if i == len(content)-1: logMsg += content[i] else: logMsg += content[i]+'|' logging2.AQueue.put({’DEBUG’:logMsg}) def info(*content): logMsg = '' for i in range(len(content)): if i == len(content)-1: logMsg += content[i] else: logMsg += content[i]+'|' logging2.AQueue.put({’INFO’:logMsg})def warn(*content): logMsg = '' for i in range(len(content)): if i == len(content)-1: logMsg += content[i] else: logMsg += content[i]+'|' logging2.AQueue.put({’WARNING’:logMsg}) def error(*content): logMsg = '' for i in range(len(content)): if i == len(content)-1: logMsg += content[i] else: logMsg += content[i]+'|' logging2.AQueue.put({’ERROR’:logMsg}) def init(module, level): # 創(chuàng)建新線程 thread1 = logging2(1, 'Thread-log', module, level) # 開(kāi)啟新線程 thread1.start()# thread1.join()

測(cè)試樁logMain.py

import sysimport osimport timeimport threadingif __name__ == ’__main__’: import logging2 logging2.init('logMain', 'DEBUG') teststr = '22222' while True: logging2.debug(’this is a debug log test [%s] ’, teststr) logging2.info(’this is a info log test [%s] [%s]’, teststr, teststr) logging2.warn(’this is a warn log test’) logging2.error(’this is a error log test’) #time.sleep(0.1) print(threading.enumerate()) print(’press ctrl_c to exit’)

測(cè)試結(jié)果

生成日志文件:

-rw-rw-r--. 1 zxl zxl 10152463 6月 24 17:52 log_logMain_57554_20200624.log

文件內(nèi)容如下:

Python logging模塊異步線程寫日志實(shí)現(xiàn)過(guò)程解析

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 欧美日韩在线国产 | 九九免费在线视频 | 精品视频在线免费看 | 久久综久久美利坚合众国 | 在线看片日本 | 日本成本人视频 | 国产成人精品s8p视频 | 日本三级欧美三级人妇英文 | 成年人国产 | 久久精品国产99久久72 | 久久精品国产400部免费看 | 99久久国语露脸精品对白 | 久在线| 色视频www在线播放国产人成 | 亚洲高清无在码在线无弹窗 | 久久精品亚洲乱码伦伦中文 | 欧美另类交视频 | 日本欧美不卡一区二区三区在线 | 国产精品爱久久久久久久小 | 亚洲图片偷拍区 | 久久久久久久久久久观看 | 亚洲一区视频在线 | 一及黄色毛片 | 欧美一线免费http | 国产一级高清视频 | 欧美孕妇性xxxⅹ精品hd | 亚洲国产成人精品激情 | 国产精品一区在线播放 | 亚洲天堂网视频 | 欧美日韩在线视频观看 | 九草在线观看 | 国产精品久久久久久麻豆一区 | 国产精品亚洲精品一区二区三区 | 中文字幕一区二区三区在线观看 | 在线一区二区三区 | 久久综合免费视频 | 国产成人免费片在线观看 | 在线播放日韩 | 亚洲免费久久 | 在线观看国产情趣免费视频 | 国产一区二区播放 |