Flask-日志输出中包含代码出错位置信息

在flask中,通常当函数抛出异常时,日志中需要记录报错的原因信息,可以使用repr(e)实现。但是,仅有这些信息不易于分析和排障,最好是能体现出报错的代码所在的位置,以便及时调整代码。
在本例中,通过使用traceback,可在日志输出中打印报错的代码信息,类似在控制台中显示的那样。
相应的,在所有的Python项目中都可使用该方法。

import traceback
from flask import current_app

def task_exec(task_id):
    try:
        current_app.logger.debug("进入任务%s的函数执行"%(task_id))
        # todo 代码逻辑
    except Exception as e:
        current_app.logger.error("任务%s执行出现异常,原因为:%s\n%s"%(task_id, repr(e), traceback.format_exc()))

打印结果

2023-08-08 09:47:57,615 - ERROR - 任务R230808094735B2-T1执行出现异常,原因为:KeyError('TASK_DIR1')
Traceback (most recent call last):
  File "/project/app/api/views.py", line 345, in task_exec
    exec.load_task(task_id)
  File "/project/app/executor/service.py", line 34, in load_task
    task_dir = current_app.config['TASK_DIR1']
KeyError: 'TASK_DIR1'
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值