Django 日志
Django 使用Python 内建的logging 模块打印日志,Python 的logging 配置由四个部分组成:
记录器 —— Logger
处理程序 —— Handler
过滤器 —— Filter
格式化 —— Formatter
1.记录器 —— Logger
Logger 为日志系统的入口。每个logger命名都是bucket,你可以向这个bucket写入需要处理的消息。
每个logger 都有一个日志级别。日志级别表示该logger 将要处理的消息的严重性。Python
定义以下几种日志级别:
DEBUG:用于调试目的的底层系统信息
INFO:普通的系统信息
WARNING:表示出现一个较小的问题。
ERROR:表示出现一个较大的问题。
CRITICAL:表示出现一个致命的问题。
写入logger 的每条消息都是一条日志。每条日志也具有一个日志级别,它表示对应的消息的严重性。每个日志记录还可以包含描述正在打印的事件的元信息。
当一条消息传递给logger 时,消息的日志级别将与logger 的日志级别进行比较。如果消息的日志级别大于等于logger 的日志级别,该消息将会往下继续处理。如果小于,该消息将被忽略。
Logger 一旦决定消息需要处理,它将传递该消息给一个Handler。

2.Logger配置

logger 对应的值是个字典,其每一个键都是logger的名字,每一个值又是个字典,描述了如何配置对应的Logger实例。
- level (可选的)。logger的级别。
- propagate (可选的)。logger的传播设置。
- flters (可选的)。logger的Òlter的标识符的列表。
- handlers (可选的)。logger的handler的标识符的列表。
 
LOGGING = {
  'loggers': {
    'reboot': {
      'handlers': ['file_handler', 'console_handler'],
      'level': 'DEBUG',
     },
   },
}3.处理程序 —— Handler
Handler 决定如何处理logger 中的每条消息。它表示一个特定的日志行为,例如将消息写
到屏幕上、写到文件中或者写到网络socket
与logger 一样,handler 也有一个日志级别。如果消息的日志级别小于handler 的级别,
handler 将忽略该消息
Logger 可以有多个handler,而每个handler 可以有不同的日志级别。利用这种方式,可以
根据消息的重要性提供不同形式的处理
5.格式化——Formatters 
最后,日志记录需要转换成文本。Formatter 表示文本的格式。Fomatter 通常由包含日志记录
属性的Python 格式字符串组成;你也可以编写自定义的fomatter 来实现自己的格式
LOGGING = {
  'formatters': {
    'reboot':{
      'format': '%(asctime)s - %(pathname)s:%(lineno)d[%(levelname)s] - %(message)s'
    }
    'simple': {
      'format': '%(asctime)s %(levelname)s %(message)s'
    },
  },
}

6.Django 内置logger

django 获取所有日志
django.request 处理与请求相关的日志,5xx响应报出error日志,4xx报出WARNING日志
django.db.backends 处理与数据库之间交互的日志,
django.security.* 处理与安全相关的日志
django.db.backends.schemea 处理数据库迁移时的日志 

示例:django中的log需要在settings.py中配置

import time

cur_path = os.path.dirname(os.path.realpath(__file__))  # log_path是存放日志的路径
log_path = os.path.join(os.path.dirname(cur_path), 'logs')
if not os.path.exists(log_path): os.mkdir(log_path) # 如果不存在这个logs文件夹,就自动创建一个 LOGGING = {
'version': 1,
'disable_existing_loggers': True,
'formatters': {
# 日志格式
'standard': {
'format': '[%(asctime)s] [%(filename)s:%(lineno)d] [%(module)s:%(funcName)s] '
'[%(levelname)s]- %(message)s'},
'simple': { # 简单格式
'format': '%(levelname)s %(message)s'
},
},
# 过滤
'filters': {
},
# 定义具体处理日志的方式
'handlers': {
# 默认记录所有日志
'default': {
'level': 'INFO',
'class': 'logging.handlers.RotatingFileHandler',
'filename': os.path.join(log_path, 'all-{}.log'.format(time.strftime('%Y-%m-%d'))),
'maxBytes': 1024 * 1024 * 5, # 文件大小
'backupCount': 5, # 备份数
'formatter': 'standard', # 输出格式
'encoding': 'utf-8', # 设置默认编码,否则打印出来汉字乱码
},
# 输出错误日志
'error': {
'level': 'ERROR',
'class': 'logging.handlers.RotatingFileHandler',
'filename': os.path.join(log_path, 'error-{}.log'.format(time.strftime('%Y-%m-%d'))),
'maxBytes': 1024 * 1024 * 5, # 文件大小
'backupCount': 5, # 备份数
'formatter': 'standard', # 输出格式
'encoding': 'utf-8', # 设置默认编码
},
# 控制台输出
'console': {
'level': 'DEBUG',
'class': 'logging.StreamHandler',
'formatter': 'standard'
},
# 输出info日志
'info': {
'level': 'INFO',
'class': 'logging.handlers.RotatingFileHandler',
'filename': os.path.join(log_path, 'info-{}.log'.format(time.strftime('%Y-%m-%d'))),
'maxBytes': 1024 * 1024 * 5,
'backupCount': 5,
'formatter': 'standard',
'encoding': 'utf-8', # 设置默认编码
},
},
# 配置用哪几种 handlers 来处理日志
'loggers': {
# 类型 为 django 处理所有类型的日志, 默认调用
'django': {
'handlers': ['default', 'console'],
'level': 'INFO',
'propagate': False
},
# log 调用时需要当作参数传入
'log': {
'handlers': ['error', 'info', 'console', 'default'],
'level': 'INFO',
'propagate': True
},
}
}

脚本中调用views.py:

import logging

logger = logging.getLogger('log')
 

最新文章

  1. jasperreports+iReport制作报表笔记
  2. 制作C/C++动态链接库(dll)若干注意事项
  3. Golang学习 - errors 包
  4. ArcGIS AO开发高亮显示某些要素
  5. [PHP] chr和ord函数实现字符串和ASCII码互转
  6. HDU-1225 Football Score
  7. 01我为什么学Unity3d
  8. SQL Server管理员专用连接的使用
  9. iOS两个关于对象的关键字
  10. Dojo初探之3:dojo的DOM操作、query操作和domConstruct元素位置操作(基于dojo1.11.2版本)
  11. Jenkins系列——定时构建
  12. js的组成部分
  13. angular $index获取ng-repeat的上一条数据
  14. 第三十六篇-FloatingActionButton的使用
  15. spline和Pchips的不同(matlab)
  16. babel-loader和webpack UglifyJS一起使用时console的问题
  17. 使用XHProf分析PHP性能瓶颈(一)
  18. Java基础——数组
  19. C语言不使用加号实现加法运算的几种方法
  20. matlab绿色版本合集

热门文章

  1. Java实现蓝桥杯模拟递增的数
  2. Java实现 蓝桥杯 数独游戏
  3. 第七届蓝桥杯JavaA组国(决)赛部分真题
  4. java实现第八届蓝桥杯生命游戏
  5. SqlServer下一些实用的sql语句收集
  6. Python--循环--for && while
  7. Ement 学习
  8. VMWare 安装CentOS7 时启动黑屏
  9. (七)MySQL常见的数据类型、约束和标识列
  10. WPF入门(1)