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

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

Python如何使用logging為Flask增加logid

瀏覽:105日期:2022-06-23 17:22:49

我們為了問題定位,常見做法是在日志中加入 logid,用于關聯一個請求的上下文。這就涉及兩個問題:1. logid 這個“全局”變量如何保存傳遞。2. 如何讓打印日志的時候自動帶上 logid(畢竟不能每個打日志的地方都手動傳入)

logid保存與傳遞

傳統做法就是講 logid 保存在 threading.local 里面,一個線程里都是一樣的值。在 before_app_request 就生成好,logid并放進去。

import threading from blueprint.hooks import hooks thread_local = threading.local()app = Flask()app.thread_local = thread_local

import uuid from flask import Blueprintfrom flask import current_app as app hooks = Blueprint(’hooks’, __name__) @hooks.before_app_requestdef before_request(): ''' 處理請求之前的鉤子 :return: ''' # 生成logid app.thread_local.logid = uuid.uuid1().time

因為需要一個數字的 logid 所以簡單使用 uuid.uuid1().time 一般并發完全夠了,不會重復且趨勢遞增(看logid就能知道請求的早晚)。

打印日志自動帶上logid

這個就是 Python 日志庫自帶的功能了,可以使用 Filter 來實現這個需求。

import logging # https://docs.python.org/3/library/logging.html#logrecord-attributeslog_format = '%(asctime)s %(levelname)s [%(threadName)s-%(thread)d] %(logid)s %(filename)s:%(lineno)d %(message)s'file_handler = logging.FileHandler(file_name)logger = logging.getLogger()logid_filter = ContextFilter()file_handler.addFilter(logid_filter)file_handler.setFormatter(logging.Formatter(log_format))logger.addHandler(file_handler) class ContextFilter(logging.Filter): ''' logging Filter ''' def filter(self, record):'''threading local 獲取logid:param record::return:'''log_id = thread_local.logid if hasattr(thread_local, ’logid’) else ’-’record.logid = log_id return True

log_format 中我們用了很多系統自帶的占位符,但 %(logid)s 默認沒有的。每條日志打印輸出前都會過 Filter,利用此特征我們就可以把 record.logid 賦值上,最終打印出來的時候就有 logid 了。

雖然最終實現了,但因為是通用化方案,所以有些復雜了。其實官方教程中介紹了一種更加簡單的方式:injecting-request-information,看來沒事還得多看看官方文檔。

以上就是Python如何使用logging為Flask增加logid的詳細內容,更多關于Python為Flask增加logid的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 潜水搅拌机-双曲面搅拌机-潜水推进器|奥伯尔环保 | 电地暖-电采暖-发热膜-石墨烯电热膜品牌加盟-暖季地暖厂家 | 哈希PC1R1A,哈希CA9300,哈希SC4500-上海鑫嵩实业有限公司 | 必胜高考网_全国高考备考和志愿填报信息平台 | 365文案网_全网创意文案句子素材站 | 香蕉筛|直线|等厚|弧形|振动筛|香蕉筛厂家-洛阳隆中重工 | 德国EA可编程直流电源_电子负载,中国台湾固纬直流电源_交流电源-苏州展文电子科技有限公司 | 北京印刷厂_北京印刷_北京印刷公司_北京印刷厂家_北京东爵盛世印刷有限公司 | 电脑刺绣_绣花厂家_绣花章仔_织唛厂家-[源欣刺绣]潮牌刺绣打版定制绣花加工厂家 | 重庆磨床过滤机,重庆纸带过滤机,机床伸缩钣金,重庆机床钣金护罩-重庆达鸿兴精密机械制造有限公司 | 警方提醒:赣州约炮论坛真的安全吗?2025年新手必看的网络交友防坑指南 | 安平县鑫川金属丝网制品有限公司,防风抑尘网,单峰防风抑尘,不锈钢防风抑尘网,铝板防风抑尘网,镀铝锌防风抑尘网 | 高考志愿规划师_高考规划师_高考培训师_高报师_升学规划师_高考志愿规划师培训认证机构「向阳生涯」 | 商标转让-商标注册-商标查询-软著专利服务平台 - 赣江万网 | 沈阳庭院景观设计_私家花园_别墅庭院设计_阳台楼顶花园设计施工公司-【沈阳现代时园艺景观工程有限公司】 | 吨袋包装机|吨包秤|吨包机|集装袋包装机-烟台华恩科技 | 回收二手冲床_金丰旧冲床回收_协易冲床回收 - 大鑫机械设备 | 杭州顺源过滤机械有限公司官网-压滤机_板框压滤机_厢式隔膜压滤机厂家 | 济南展厅设计施工_数字化展厅策划设计施工公司_山东锐尚文化传播有限公司 | 河南膏药贴牌-膏药代加工-膏药oem厂家-洛阳今世康医药科技有限公司 | 冷柜风机-冰柜电机-罩极电机-外转子风机-EC直流电机厂家-杭州金久电器有限公司 | 干洗加盟网-洗衣店品牌排行-干洗设备价格-干洗连锁加盟指南 | 棕刚玉_白刚玉_铝酸钙-锐石新材料 | 全自动包装秤_全自动上袋机_全自动套袋机_高位码垛机_全自动包装码垛系统生产线-三维汉界机器(山东)股份有限公司 | 打包钢带,铁皮打包带,烤蓝打包带-高密市金和金属制品厂 | 直流电能表-充电桩电能表-导轨式电能表-智能电能表-浙江科为电气有限公司 | 杭州公司变更法人-代理记账收费价格-公司注销代办_杭州福道财务管理咨询有限公司 | 不锈钢螺丝,不锈钢螺栓,不锈钢标准件-江苏百德特种合金有限公司 交变/复合盐雾试验箱-高低温冲击试验箱_安奈设备产品供应杭州/江苏南京/安徽马鞍山合肥等全国各地 | 网架支座@球铰支座@钢结构支座@成品支座厂家@万向滑动支座_桥兴工程橡胶有限公司 | 托盘租赁_塑料托盘租赁_托盘出租_栈板出租_青岛托盘租赁-优胜必达 | 耙式干燥机_真空耙式干燥机厂家-无锡鹏茂化工装备有限公司 | 合肥汽车充电桩_安徽充电桩_电动交流充电桩厂家_安徽科帝新能源科技有限公司 | 袋式过滤器,自清洗过滤器,保安过滤器,篮式过滤器,气体过滤器,全自动过滤器,反冲洗过滤器,管道过滤器,无锡驰业环保科技有限公司 | 托利多电子平台秤-高精度接线盒-托利多高精度电子秤|百科 | 清管器,管道清管器,聚氨酯发泡球,清管球 - 承德嘉拓设备 | 武汉不干胶印刷_标签设计印刷_不干胶标签印刷厂 - 武汉不干胶标签印刷厂家 | 智能汉显全自动量热仪_微机全自动胶质层指数测定仪-鹤壁市科达仪器仪表有限公司 | 轴流风机-鼓风机-离心风机-散热风扇-罩极电机,生产厂家-首肯电子 | POS机办理_个人pos机免费领取-银联pos机申请首页 | 福建成考网-福建成人高考网 | 潍坊青州古城旅游景点攻略_青州酒店美食推荐-青州旅游网 |