logging 模块
Django的日志使用了python的lohhing模块,使用时需要在settings.py中配置。
logging 模块由四部分组成
记录器
记录器的作用是记录日志级别<日志级别描述的是程序运行详细消息>,Python定义了几种级别:
INFO: 一般信息
WARNING: 发生过的小问题
ERROR: 发生过的主要问题
DEBUG: 调试的地基系统讯息
处理器
处理器是确定记录器里的每条讯息的发生情况,做日志描述;记录器有很多处理器且每个处理器具有不同的日志级别
所以,可以根据日志的严重性来提供不同形式的通知
过滤器
过滤器就是对日志记录从记录器到处理器的控制程序,一般来说,所有的额日志讯息都会满足,个人也可以添加删选调节实施过滤
格式化程序
日志记录<说到日志就联想到文本> 最后 日志记录要以文本的形式体现,格式化程序描述此日志记录的准确格式
格式化程序经常由含有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': {
}
}
logging中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 | 记录的日志信息 |
end.........