日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

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

通過logging模塊,重寫一個(gè)logging2模塊,獨(dú)立開啟線程,將待寫的日志信息異步放入隊(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 ('開啟日志線程:' + 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ù)用豎線分隔符分開 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) # 開啟新線程 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)過程解析

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

標(biāo)簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
尤物网精品视频| 国产精品伦一区二区| 综合在线一区| 亚洲精品伊人| 欧美激情麻豆| 国产精品成人a在线观看| 97精品国产| 999久久久国产精品| 国产日韩专区| 国产亚洲欧美日韩精品一区二区三区| 美女亚洲一区| 在线精品视频在线观看高清| 午夜在线播放视频欧美| 天海翼亚洲一区二区三区| 天堂va在线高清一区| 日本欧美一区二区| 国产精品久久久久久久久久白浆 | 免费日韩av| 视频一区视频二区中文| 日本亚洲不卡| 色偷偷色偷偷色偷偷在线视频| 麻豆精品新av中文字幕| www在线观看黄色| 欧美日韩国产高清| 欧美日韩一区二区高清| 成人在线视频中文字幕| 亚洲最新av| 黑人精品一区| 国产欧美一级| 中文一区在线| 国产v综合v| 在线观看亚洲精品福利片| 日韩综合一区| 国产亚洲精品美女久久| 亚洲激情久久| 欧美黄色网页| 国产二区精品| 精品国产18久久久久久二百| 日本va欧美va精品发布| 国产精品日本欧美一区二区三区| 国产福利一区二区精品秒拍| 香蕉久久国产| 国产v综合v| 日本精品另类| 在线国产精品一区| 蜜桃传媒麻豆第一区在线观看| 少妇久久久久| 高清久久精品| 久久精品三级| 国产精品一国产精品k频道56| 免费在线观看一区二区三区| 国产日韩一区二区三区在线播放| 午夜精品影院| 国产精品人人爽人人做我的可爱| 日韩大片在线观看| 色偷偷偷在线视频播放| 丁香婷婷久久| 欧美羞羞视频| 黄毛片在线观看| 精品国产日韩欧美精品国产欧美日韩一区二区三区| 亚洲最新av| 免费在线观看视频一区| 老牛国产精品一区的观看方式| 欧美在线亚洲综合一区| 九色精品91| 五月天久久久| 欧美不卡高清一区二区三区| 欧美日韩亚洲在线观看| 人人精品亚洲| 亚洲天堂免费| 欧美精品影院| 精品三级久久| 亚洲一区二区动漫| 欧美在线综合| 国产日韩中文在线中文字幕| 免费在线欧美黄色| 美腿丝袜在线亚洲一区| 午夜久久中文| 国产韩日影视精品| 免费日韩av| 国产精成人品2018| 日韩不卡一二三区| www成人在线视频| 在线一区免费| 麻豆成人在线观看| 一本一道久久a久久精品蜜桃| 青草国产精品| 香蕉国产精品| 国产精品qvod| 久久国产电影| 国产精品日韩精品在线播放| www.com.cn成人| 蜜臀av一区二区在线免费观看| 国产精品亚洲一区二区在线观看| 麻豆高清免费国产一区| 一本色道精品久久一区二区三区| 欧美私人啪啪vps| 四虎8848精品成人免费网站| 亚洲精品美女| 国产一区2区| 中文字幕日韩欧美精品高清在线| 国产精品伦一区二区| 亚洲美女91| 成人午夜亚洲| 日韩欧乱色一区二区三区在线| 久草精品视频| 好看的av在线不卡观看| 国产一区二区三区四区五区传媒| 亚洲视频电影在线| 激情欧美丁香| 国产精品一二| 九九久久婷婷| 91视频久久| 欧美日本不卡| 日韩一区二区久久| 国产精品久久久久久久久久白浆 | 国产一二在线播放| 亚洲午夜免费| 99视频+国产日韩欧美| 开心激情综合| 亚洲人成网77777色在线播放| 丝袜美腿高跟呻吟高潮一区| 欧美特黄一区| 亚洲成人精选| 日韩欧美综合| 99久久亚洲精品蜜臀| 成人小电影网站| 精品一区二区三区在线观看视频| 91亚洲无吗| 久久黄色影视| 亚洲免费成人| 久久国产精品免费精品3p | 亚洲神马久久| 综合日韩在线| 亚洲三级毛片| 男女性色大片免费观看一区二区| 欧美精品一区二区久久| 蜜臀久久99精品久久一区二区| 成人一区而且| 国内精品福利| 亚洲免费毛片| 免费在线观看一区二区三区| 欧美日韩少妇| 五月激情久久| 国产精品色网| 亚洲综合日本| 亚洲精品乱码久久久久久蜜桃麻豆| 视频在线观看国产精品| 欧美午夜三级| 精品国产乱码| 国产亚洲毛片在线| 国产探花一区在线观看| 日本欧美国产| 亚洲资源av| 精品精品99| 亚洲在线免费| 国产精品欧美三级在线观看| 国产资源在线观看入口av| 国产精品欧美三级在线观看 | 麻豆精品蜜桃视频网站| 日韩影院二区| 日av在线不卡| 国产精品黑丝在线播放| 亚洲午夜在线| 久久精品理论片| 快she精品国产999| 久久精品一区二区国产| 午夜欧美精品| 国产精品久久久久久久久久齐齐 | 午夜亚洲福利在线老司机| 国产精品玖玖玖在线资源| 欧美日韩在线二区| 88久久精品| 久热综合在线亚洲精品| 91免费精品| 日本在线不卡视频一二三区| 国产欧美久久一区二区三区| 丝袜美腿成人在线| 黄色aa久久| 日韩高清成人在线| 亚洲一区二区成人| 99国产精品| 日韩一区欧美| 四虎884aa成人精品最新| 久久国产三级精品| 免费成人性网站| 午夜在线一区| 97精品国产| 神马久久午夜| 日本午夜大片a在线观看| 国产精品玖玖玖在线资源| 91成人精品视频| 欧美sss在线视频| 夜鲁夜鲁夜鲁视频在线播放| 欧洲av不卡| 蜜桃av.网站在线观看| 成人国产精品| 久久久夜精品| 国产综合激情| 模特精品在线|