Django日志
logging模块
Django的日志使用了python的logging模块,需要在settings中进行配置
logging模块由四部分组成
-
记录器
记录器配置具有日志级别。此日志级别描述了记录器将处理的消息的严重性。Python定义了以下日志级别:DEBUG: 用于调试目的的低级系统信息
INFO: 一般系统信息
WARNING: 描述已发生的小问题的信息。
ERROR: 描述已发生的主要问题的信息。
CRITICAL: 描述已发生的严重问题的信息
-
处理器
处理器是确定记录器中每条消息发生情况的引擎。它描述了特定的日志记录行为,例如将消息写入屏幕,文件或网络套接字。与记录器一样,处理器也具有日志级别。如果日志记录的日志级别未达到或超过处理程序的级别,则处理程序将忽略该消息。
记录器可以有多个处理器,每个处理器可以具有不同的日志级别。以这种方式,可以根据消息的重要性提供不同形式的通知。
-
过滤器
过滤器用于提供对日志记录从记录器传递到处理程序的附加控制。默认情况下,将处理满足日志级别要求的任何日志消息。但是,通过安装筛选器,可以在日志记录过程中添加其他条件。例如,您可以安装仅允许ERROR发出来自特定源的消息的过滤器。
过滤器还可用于在发出之前修改日志记录。例如,如果满足一组特定条件,您可以编写一个过滤器,将ERROR日志记录降级 为WARNING记录。
过滤器可以安装在记录器或处理器上; 可以在链中使用多个过滤器来执行多个过滤操作。
- 格式化程序
最终,日志记录需要呈现为文本。格式化程序描述该文本的确切格式。格式化程序通常由包含LogRecord属性的Python格式化字符串组成 ; 但是,也可以编写自定义格式化程序来实现特定的格式化行为。
示例
-
配置
LOG_PATH = 'xx/xx/' LOGGING = { 'version': 1, #定义了配置文件的版本 'disable_existing_loggers': False, ## True表示禁用logger # 格式化 'formatters': { 'default': { 'format': '%(levelname)s %(asctime)s %(module)s %(funcName)s %(msecs)s %(message)s' }, 'simple': { 'format': '%(levelname)s %(message)s' }, }, # 处理日志的方式 'handlers': { 'v_handlers': { # 级别 'level': 'DEBUG', # 存储方式 "class": 'logging.handlers.RotatingFileHandler', # 日志文件大小 'maxBytes': 5 * 1024, 'encoding': 'utf8', # 日志文件路径 'filename': '{}salary_all.log'.format(LOG_PATH), # 格式化方式 'formatter': 'default', }, 'error': { 'level': "ERROR", 'class': 'logging.handlers.RotatingFileHandler', 'maxBytes': 5 * 1024, 'encoding': 'utf8', 'filename': '{}salary_error.log'.format(LOG_PATH), 'formatter': 'simple' } }, # 配置日志的处理方式 'loggers': { 'django': { 'handlers': ['v_handlers'], 'propagate': True, }, 'django.request': { 'handlers': ['error'], 'level': 'ERROR', 'propagate': True } }, # 过滤器 'filters': { } }
- format
format | 解释 |
---|---|
%(levelno)s | 日志的级别数字形式 |
%(levelname)s | 日志级别的名称 |
%(pathname)s | 当前执行程序的路径 |
%(filename)s | 当前执行程序名 |
%(funcName)s* | 当前的函数 |
%(lineno)d | 记录日志的当前行号 |
%(asctime)s | 日期时间 |
%(msecs)s | 毫秒级的时间 |
%(thread)d | 线程ID |
%(threadName)s | 线程名称 |
%(process)d | 进程ID |
%(message)s | 记录的日志信息 |
参考链接:时光不写博客-Django日志
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Python四舍五入保留两位小数
出现问题 失败一:使用"%.2f" a = 1.335 print("%.2f" % a) # 输出1.33 失败二:使用round() a = 1.335 print(round(a, 2)) # 输出1.33 失败三:使用Decimal() from decimal import Decimal a = 1.335 print(Decimal(a).quantize(Decimal('0.00'))) #输出1.33 解决问题: a+0.001 a = 1.335 print(round(a + 0.001, 2)) # 输出 1.34 这种方法也有点问题,保留两位小数要加0.001,三位的时候就要加0.0001,不够灵活,暂时没有发现更好的方法,先记一下 参考链接:时光不写博客-Python四舍五入保留两位小数
- 下一篇
Python list元素移动
思路 得到要移动元素的当前下标 --> pop出要移动的元素 --> 计算移动位置,insert进列表 实现 # 把a2向右移动两位 list_a = ['a1', 'a2', 'a3', 'a4'] index_a2 = list_a.index('a2') a2 = list_a.pop(index_a2) # 向右移动时注意index小于零的情况 insert_a2 = index_a2 + 2 list_a.insert(insert_a2, a2) print(list_a) # ['a1', 'a3', 'a4', 'a2']
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Red5直播服务器,属于Java语言的直播服务器
- CentOS7,CentOS8安装Elasticsearch6.8.6
- Docker安装Oracle12C,快速搭建Oracle学习环境
- CentOS8编译安装MySQL8.0.19
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS6,CentOS7官方镜像安装Oracle11G
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- CentOS8安装Docker,最新的服务器搭配容器使用