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'

你可能感兴趣的:(Python开发,flask,python,后端)