# ======日志配置======
# 错误优先级:NOTSET < DEBUG < INFO < WARNING < ERROR < CRITICAL
# Django使用dictConfig 格式,需要配置:loggers、handlers、filters、formatters
# 创建logs日志目录
if os.path.exists(os.path.join(BASE_DIR, 'logs')) is False:
os.mkdir(os.path.join(BASE_DIR, 'logs'))
# logs目录绝对路径
LOGS_ROOT = os.path.join(BASE_DIR, 'logs')
# 默认情况下,LOGGING设置与Django的默认logging配置进行合并
LOGGING = {
'version': 1,
# 如果LOGGING中的disable_existing_loggers键为True(默认值)那么默认配置中的所有logger 都将禁用(并非删除,仍然存在)
# 如果你禁用配置过程,Django仍然执行logging调用,只是调用的是默认定义的logging 行为。
# 你可以设置disable_existing_loggers为False,并重新定义部分或所有的默认loggers;
# 或者你可以设置LOGGING_CONFIG为None,并自己处理logging 配置。
'disable_existing_loggers': False,
# 日志记录需要转换成文本。Formatter 表示文本的格式。
# asctime时间、threadName线程名称、thread线程号、name 记录器(loggers)的名称、lineno异常行号、
# module执行日志记录调用的模块名称、funcName执行日志记录调用的函数名称、levelname日志记录级别的文本名称、message日志消息
# 具体看:https://docs.python.org/3/library/logging.html#formatter-objects
'formatters': {
'standard': {
'format': '%(asctime)s [%(threadName)s:%(thread)s prototype] [%(name)s:%(lineno)s prototype] [%(module)s:%(funcName)s] [%(levelname)s]- %(message)s'
},
'simple': {
'format': '%(asctime)s [%(threadName)s:%(thread)s prototype] [%(name)s:%(lineno)s prototype] [%(levelname)s]- %(message)s'
}
},
# Filter用于对从logger传递给handler的日志记录进行额外的控制。
'filters': {
'require_debug_false': {
'()': 'django.utils.log.RequireDebugFalse'
}
},
# Handler决定如何处理logger中的每条消息
'handlers': {
'mail_admins': {
'level': 'ERROR',
'filters': ['require_debug_false'],
'class': 'django.utils.log.AdminEmailHandler'
},
'default': {
'level': 'DEBUG', # 日志级别
'class': 'logging.handlers.RotatingFileHandler', # 输出到文件
'filename': os.path.join(LOGS_ROOT, 'all.log'), # 日志文件,请确保修改'filename'路径为运行Django应用的用户有权限写入的一个位置
'maxBytes': 1024 * 1024 * 5, # 5 MB 文件大小
'backupCount': 60, # 备份份数
'formatter': 'standard', # 使用哪种日志格式
},
'console': {
'level': 'DEBUG', # 日志级别
'class': 'logging.StreamHandler', # 输出到控制台
'formatter': 'standard', # 使用哪种日志格式
},
'request_handler': {
'level': 'DEBUG', # 日志级别
'class': 'logging.handlers.RotatingFileHandler', # 输出到文件
'filename': os.path.join(LOGS_ROOT, 'django_request.log'), # 日志文件
'maxBytes': 1024 * 1024 * 5, # 5 MB 文件大小
'backupCount': 60, # 备份份数
'formatter': 'standard', # 使用哪种日志格式
},
'exception_handler': {
'level': 'DEBUG', # 日志级别
'class': 'logging.handlers.RotatingFileHandler', # 输出到文件
'filename': os.path.join(LOGS_ROOT, 'exception.log'), # 日志文件
'maxBytes': 1024 * 1024 * 5, # 5 MB 文件大小
'backupCount': 60, # 备份份数
'formatter': 'standard', # 使用哪种日志格式
},
},
# Logger 为日志系统的入口。每个logger 是一个容器,可以向它写入需要处理的消息,可以配置用哪种handlers来处理日志
# propagate为True时表示向上传播消息,将比level定义的级别更加高级的级别传递到handlers处理
'loggers': {
'django': {
'handlers': ['console'], # 日志处理器
'level': 'DEBUG', # 记录器级别
'propagate': False # 是否向上传播
},
# 某个app专用
'BangSo.app': {
'handlers': ['default', 'console'],
'level': 'DEBUG',
'propagate': True
},
'django.request': {
'handlers': ['request_handler'],
'level': 'INFO',
'propagate': False
},
'exception': {
'handlers': ['exception_handler'],
'level': 'ERROR',
'propagate': False
},
}
}

解析:

1.formatters:配置打印日志格式

2.handlers  :用来定义具体处理日志的方式,可以定义多种,"default"就是默认方式,"console"就是打印到控制台方式。

3.loggers     :用来配置用那种handlers来处理日志,比如你同时需要输出日志到文件、控制台。

log日志应用:

logger = logging.getLogger('BangSo.app') #刚才在setting.py中配置的logger
try:
mysql= connectMysql('127.0.0.1', '3306', 'david')
except Exception,e:
logger.debug(e) #直接将错误写入到日志文件,并将错误输出到控制台上,default、console是“BangSo.app"logger中的handlers

ps:

handlers与loggers都存在level,两者不同:

  loggers中的level表示可以接受的错误级别,就是说loggers接受level或者比level更高级别的错误,由propagate决定:propagate为True,则向上传播;handlers的level表示日志级别

django中日志配置的更多相关文章

  1. Django中日志管理

    在settings中设置日志的相关信息,然后再逻辑代码区就可以保存相应的信息了 #简单设置: LOGGING = { 'version': 1, 'disable_existing_loggers': ...

  2. django 自定义日志配置

    如果不想使用 python 的 dictConfig 格式来配置 logger,可以制定自己的配置架构. LOGGING_CONFIG 配置定义了用来配置 django logger 的可调用函数,默 ...

  3. django 完整日志配置

    django中的log需要在settings.py中配置 import time cur_path = os.path.dirname(os.path.realpath(__file__)) # lo ...

  4. django开发日志配置

    做django开发离不开 日志,这用于保存我门的服务器的日志信息,便于开发人员的维护. 直接上代码: 在setting.py文件里直接配置即可 LOGGING = { 'version': 1, 'd ...

  5. django中日志使用学习记录

    在setting中加入以下代码 LOGGING = { 'version': 1, 'disable_existing_loggers': True, 'formatters': { 'verbose ...

  6. django中缓存配置

    # ======缓存配置====== CACHES = { ## 虚拟缓存,开发调试版本,此为开始调试用,实际内部不做任何操作 # 'default': { # 'BACKEND': 'django. ...

  7. SpringBoot中日志配置

    背景 由于一些框架中还使用log4j-1.x系列陈旧的日志框架,调试过程中有一些错误信息不能在控制台显示,增加了调试成本.以下配置方法 将帮助你获得log4j-1.x日志在控制台显示. 解决方法: 使 ...

  8. Redis缓存在django中的配置

    django  settings中的配置 # 缓存 CACHES = { "default": { "BACKEND": "django_redis. ...

  9. django中路由配置的正则

    在django中配置路由遇到正则的坑: django2.x版本中使用re_path来进行正则表达式的匹配 用法如下: from Django.urls import re.path(导入re_path ...

随机推荐

  1. HDU 5532 Almost Sorted Array (最长非递减子序列)

    题目链接 Problem Description We are all familiar with sorting algorithms: quick sort, merge sort, heap s ...

  2. Python练习-基于socket的FTPServer

    # 编辑者:闫龙 import socket,json,struct class MySocket: with open("FtpServiceConfig","r&qu ...

  3. python概念-常用模块之究竟你是什么鬼

    模块: 一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 说白了,就是一个python文件中定义好了类和方法,实现了一些功能,可以被别的python文件所调用 ...

  4. BNUOJ 12756 Social Holidaying(二分匹配)

    题目链接:http://www.bnuoj.com/bnuoj/problem_show.php?pid=12756 Social Holidaying Time Limit: 3000ms Memo ...

  5. 对接微信支付使用HMAC-SHA256使用签名算法实现方式

    最近做微信押金支付对接,很多坑,心累!这里提醒一下各位: 首先,确保自己商户号进了白名单,没有需要联系客服,否则接口是调不通的,会一直提示参数错误 其次,确保接口文档是最新的,最好去官网去看,否则可能 ...

  6. juery下拉刷新,ajax请求,div加载更多元素(一)

    ;//设置当前页数 var flag=true; //滑动加载 $(function(){ var winH = $(window).height(); //页面可视区域高度 $(window).sc ...

  7. php中heredoc的使用方法

    Heredoc技术,在正规的PHP文档中和技术书籍中一般没有详细讲述,只是提到了这是一种Perl风格的字符串输出技术.但是现在的一些论坛程序,和部分文章系统,都巧妙的使用heredoc技术,来部分的实 ...

  8. 21 JSON and Go go语言和json

    JSON and Go 25 January 2011 Introduction JSON (JavaScript Object Notation) is a simple data intercha ...

  9. Vue 实现loading进度条

    项目中遇到的,用vue实现下: <template> <div class="plLoading"> <div class="plLoadi ...

  10. java基础77 Http协议及Servlet中的GET、POST提交方式

    本文知识点(目录): 1.什么是http协议    2.查看http协议的工具    3.http协议的内容    4.请求方式    5.请求头和响应头(以及获取请求头信息的方法)    6.实体内 ...