电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Python logging模塊異步線程寫日志實現過程解析

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

通過logging模塊,重寫一個logging2模塊,獨立開啟線程,將待寫的日志信息異步放入隊列,做到日志輸出不影響主流程性能,環境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’) #比較新的時間 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:#從隊列獲取日志消息data = logging2.AQueue.get()#解析日志消息,格式:日志級別,內容level = list(data.keys())[0]content = data.get(level)#把內容按分隔符|解析成list傳入參數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 = '' #傳入多個參數用豎線分隔符分開 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): # 創建新線程 thread1 = logging2(1, 'Thread-log', module, level) # 開啟新線程 thread1.start()# thread1.join()

測試樁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’)

測試結果

生成日志文件:

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

文件內容如下:

Python logging模塊異步線程寫日志實現過程解析

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 活动策划,舞台搭建,活动策划公司-首选美湖上海活动策划公司 | 浙江工业冷却塔-菱电冷却塔厂家 - 浙江菱电冷却设备有限公司 | 培训一点通 - 合肥驾校 - 合肥新亚驾校 - 合肥八一驾校 | 识禅_对禅的了解,从这里开始 | 无锡网站建设_小程序制作_网站设计公司_无锡网络公司_网站制作 | 转向助力泵/水泵/发电机皮带轮生产厂家-锦州华一精工有限公司 | 国产离子色谱仪,红外分光测油仪,自动烟尘烟气测试仪-青岛埃仑通用科技有限公司 | PO膜_灌浆膜及地膜供应厂家 - 青州市鲁谊塑料厂 | 高压包-点火器-高压发生器-点火变压器-江苏天网 | 市政路灯_厂家-淄博信达电力科技有限公司 | 专业生产动态配料系统_饲料配料系统_化肥配料系统等配料系统-郑州鑫晟重工机械有限公司 | 筒瓦厂家-仿古瓦-寺庙-古建琉璃瓦-宜兴市古典园林建筑陶瓷厂有限公司 | 盘式曝气器-微孔曝气器-管式曝气器-曝气盘-斜管填料 | 郑州市前程水处理有限公司 | 卡诺亚轻高定官网_卧室系统_整家定制_定制家居_高端定制_全屋定制加盟_定制家具加盟_定制衣柜加盟 | 盘煤仪,盘料仪,盘点仪,堆料测量仪,便携式激光盘煤仪-中科航宇(北京)自动化工程技术有限公司 | 洛阳防爆合格证办理-洛阳防爆认证机构-洛阳申请国家防爆合格证-洛阳本安防爆认证代办-洛阳沪南抚防爆电气技术服务有限公司 | 华禹护栏|锌钢护栏_阳台护栏_护栏厂家-华禹专注阳台护栏、楼梯栏杆、百叶窗、空调架、基坑护栏、道路护栏等锌钢护栏产品的生产销售。 | 太原装修公司_山西整装家装设计_太原室内装潢软装_肖邦家居 | 磁力轮,磁力联轴器,磁齿轮,钕铁硼磁铁-北京磁运达厂家 | BAUER减速机|ROSSI-MERSEN熔断器-APTECH调压阀-上海爱泽工业设备有限公司 | 电子巡更系统-巡检管理系统-智能巡检【金万码】 | 钛板_钛管_钛棒_钛盘管-无锡市盛钛科技有限公司 | 带式过滤机厂家_价格_型号规格参数-江西核威环保科技有限公司 | 根系分析仪,大米外观品质检测仪,考种仪,藻类鉴定计数仪,叶面积仪,菌落计数仪,抑菌圈测量仪,抗生素效价测定仪,植物表型仪,冠层分析仪-杭州万深检测仪器网 | CTP磁天平|小电容测量仪|阴阳极极化_双液系沸点测定仪|dsj电渗实验装置-南京桑力电子设备厂 | 硫酸钡厂家_高光沉淀硫酸钡价格-河南钡丰化工有限公司 | 花纹铝板,合金铝卷板,阴极铝板-济南恒诚铝业有限公司 | 成都亚克力制品,PVC板,双色板雕刻加工,亚克力门牌,亚克力标牌,水晶字雕刻制作-零贰捌广告 | 深圳美安可自动化设备有限公司,喷码机,定制喷码机,二维码喷码机,深圳喷码机,纸箱喷码机,东莞喷码机 UV喷码机,日期喷码机,鸡蛋喷码机,管芯喷码机,管内壁喷码机,喷码机厂家 | 壹作文_中小学生优秀满分作文大全| 集装箱标准养护室-集装箱移动式养护室-广州璟业试验仪器有限公司 | 高尔夫球杆_高尔夫果岭_高尔夫用品-深圳市新高品体育用品有限公司 | 全自动包衣机-无菌分装隔离器-浙江迦南科技股份有限公司 | 马尔表面粗糙度仪-MAHR-T500Hommel-Mitutoyo粗糙度仪-笃挚仪器 | 颚式破碎机,圆锥破碎机,制砂机-新乡市德诚机电制造有限公司 | 模温机-油温机-电加热导热油炉-工业冷水机「欧诺智能」 | 科箭WMS仓库管理软件-TMS物流管理系统-科箭SaaS云服务 | 风电变桨伺服驱动器-风电偏航变桨系统-深圳众城卓越科技有限公司 | 暴风影音| 橡胶粉碎机_橡胶磨粉机_轮胎粉碎机_轮胎磨粉机-河南鼎聚重工机械制造有限公司 | 英国公司注册-新加坡公司注册-香港公司开户-离岸公司账户-杭州商标注册-杭州优创企业 |