时光不写博客 2019-07-19 665浏览量
Django的日志使用了python的logging模块,需要在settings中进行配置
logging模块由四部分组成
记录器
记录器配置具有日志级别。此日志级别描述了记录器将处理的消息的严重性。Python定义了以下日志级别:
DEBUG: 用于调试目的的低级系统信息
INFO: 一般系统信息
WARNING: 描述已发生的小问题的信息。
ERROR: 描述已发生的主要问题的信息。
CRITICAL: 描述已发生的严重问题的信息
处理器
处理器是确定记录器中每条消息发生情况的引擎。它描述了特定的日志记录行为,例如将消息写入屏幕,文件或网络套接字。
与记录器一样,处理器也具有日志级别。如果日志记录的日志级别未达到或超过处理程序的级别,则处理程序将忽略该消息。
记录器可以有多个处理器,每个处理器可以具有不同的日志级别。以这种方式,可以根据消息的重要性提供不同形式的通知。
过滤器
过滤器用于提供对日志记录从记录器传递到处理程序的附加控制。
默认情况下,将处理满足日志级别要求的任何日志消息。但是,通过安装筛选器,可以在日志记录过程中添加其他条件。例如,您可以安装仅允许ERROR发出来自特定源的消息的过滤器。
过滤器还可用于在发出之前修改日志记录。例如,如果满足一组特定条件,您可以编写一个过滤器,将ERROR日志记录降级 为WARNING记录。
过滤器可以安装在记录器或处理器上; 可以在链中使用多个过滤器来执行多个过滤操作。
配置
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 | 解释 |
---|---|
%(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日志
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
集结各类场景实战经验,助你开发运维畅行无忧