Flask实现定制日志并输出到文件

 更新时间:2023年07月25日 11:28:28   作者:Jacky-008  
这篇文章主要为大家学习介绍了Flask如何实现定制日志并输出到文件,文中的示例代码简介易懂,感兴趣的小伙伴快跟随小编一起学习一下吧

定制日志器

flask缺省日志器配置

flask自带的日志系统,缺省配置dictConfig(),但必须在Flask()应用之前使用

# flask缺省配置
from logging.config import dictConfig
dictConfig({
    'version': 1,
    'formatters': {'default': {
        'format': '[%(asctime)s] %(levelname)s in %(module)s: %(message)s',
    }},
    'handlers': {'wsgi': {
        'class': 'logging.StreamHandler',
        'stream': 'ext://flask.logging.wsgi_errors_stream',
        'formatter': 'default'
    }},
    'root': {
        'level': 'INFO',
        'handlers': ['wsgi']
    }
})
app = Flask(__name__)

自定义日志器

# 配置
def logger_setting(base_dir=None):
	# base_dir是日志文件存放的根目录,这里为项目目录
    if not base_dir:
        base_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__))
    format_dic, handler_dic, logger_dic = dict(), dict(), dict()
    # 定义日志格式
    format_dic['default'] = {'format': '[%(asctime)s] %(levelname)s in %(module)s: %(message)s'}
    format_dic['simple'] = {'format': '{asctime}- {levelname} {message}'}
    format_dic['standard'] = {'format': '%(asctime)s [%(module)s:%(funcName)s] [%(levelname)s]- %(message)s'}
    # 定义日志处理器
    handler_dic['wsgi'] = {'class': 'logging.StreamHandler', # 流输出
                           'stream': 'ext://flask.logging.wsgi_errors_stream',
                           'formatter': 'default'}
    handler_dic['console'] = {'level': 'INFO',
                              #'class': 'logging.StreamHandler',
                              'class': 'logging.FileHandler', # 输出到文件
                              'filename': os.path.join(base_dir, 'logs','console.log',
                              'formatter': 'simple'}
    handler_dic['error'] = {'level': 'ERROR',
                            'class': 'logging.handlers.RotatingFileHandler',
                            'filename': os.path.join(base_dir, 'logs', 'error.log'),  # 日志文件全路径 = base_dir/logs/error.log
                            'maxBytes': 1024 * 1024 * 5,
                            'formatter': 'standard'}
    handler_dic['master'] = {'level': 'ERROR',
                             'class': 'logging.handlers.RotatingFileHandler',
                             'filename': os.path.join(base_dir, 'logs', 'master.log'),
                             'maxBytes': 1024 * 1024 * 5,
                             'formatter': 'standard'}
    # 定义日志器
    logger_dic['master'] = {'handlers': ['master'],
                            'level': 'INFO',
                            'propagate': True}
    config = {
        'version': 1,
        'formatters': format_dic,
        'handlers': handler_dic,
        # 'root': {'level': 'INFO', 'handlers': ['wsgi']},  #这个可以不用
        'loggers': logger_dic
    }
    return config

# flask使用自定义日志器配置, 这里使用是重新定义缺省日志器配置
dictConfig(logger_setting())
app = Flask(__name__, template_folder='templates', static_folder='static')
logger = logging.getLogger('master')
@app.get('/')
def login():
	try:
        print('测试日志器')
        raise ValueError('djjsdwewoeoopw')
    except Exception as e:
        logger.error(e)
        traceback.print_exc()
        abort(401)

if __name__ == '__main__':
   app.run()

同时在项目目录下创建logs目录如下图

到此这篇关于Flask实现定制日志并输出到文件的文章就介绍到这了,更多相关Flask定制日志内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python中的异常处理学习笔记

    Python中的异常处理学习笔记

    这篇文章主要介绍了Python中的异常处理学习笔记,本文讲解了常见的异常类、自定义异常类、捕获异常、抛出异常、上下文管理器等内容,需要的朋友可以参考下
    2015-01-01
  • python安装numpy和pandas的方法步骤

    python安装numpy和pandas的方法步骤

    这篇文章主要介绍了python安装numpy和pandas的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • pycharm设置python文件模板信息过程图解

    pycharm设置python文件模板信息过程图解

    这篇文章主要介绍了pycharm设置python文件模板信息过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • python常规方法实现数组的全排列

    python常规方法实现数组的全排列

    这篇文章主要介绍了python常规方法实现数组的全排列,实例分析了全排列的概念及Python常规实现技巧,需要的朋友可以参考下
    2015-03-03
  • python实现超市商品销售管理系统

    python实现超市商品销售管理系统

    这篇文章主要为大家详细介绍了python实现超市商品销售管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • python和pygame实现简单俄罗斯方块游戏

    python和pygame实现简单俄罗斯方块游戏

    这篇文章主要为大家详细介绍了python和pygame实现简单俄罗斯方块游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • 利用python绘制带有时间线的柱状图

    利用python绘制带有时间线的柱状图

    这篇文章主要为大家详细介绍了如何使用python绘制出带有时间线的柱状图,文中的示例代码讲解的非常详细,具有一定的学习与借鉴价值,需要的可以参考一下
    2023-07-07
  • Android 兼容性问题:java.lang.UnsupportedOperationException解决办法

    Android 兼容性问题:java.lang.UnsupportedOperationException解决办法

    这篇文章主要介绍了Android 兼容性问题:java.lang.UnsupportedOperationException解决办法的相关资料,需要的朋友可以参考下
    2017-03-03
  • python计算牛顿迭代多项式实例分析

    python计算牛顿迭代多项式实例分析

    这篇文章主要介绍了python计算牛顿迭代多项式的方法,涉及Python数学运算的相关技巧,需要的朋友可以参考下
    2015-05-05
  • python opencv实现图像边缘检测

    python opencv实现图像边缘检测

    这篇文章主要为大家详细介绍了python opencv实现图像边缘检测,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-04-04

最新评论