# ======日志配置======
# 错误优先级: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. POJ 1350 Cabric Number Problem (模拟)

    题目链接 Description If we input a number formed by 4 digits and these digits are not all of one same va ...

  2. JS中数组那些事~

    今天闲的没事,看了一些关于数组的操作,好久木有用过,很多都已经忘记的差不多了,所以今天花了一个小时写了一些demo,准备备份一下方便以后使用~~~ 下面是一些工作当中,经常用到的数组的方法,小伙伴可以 ...

  3. Python练习-基于授权方式包装list之与根儿哥必有一战

    # 编辑者:闫龙 # 基于授权定制自己的列表类型,要求定制的自己的__init__方法, # 定制自己的append:只能向列表加入字符串类型的值 # 定制显示列表中间那个值的属性(提示:proper ...

  4. [译] 用HTML5捕获音频和视频

    原文地址:http://www.html5rocks.com/en/tutorials/getusermedia/intro/ 概述 有了HTML5,我们就可以在不借助Flash或者Silverlig ...

  5. Inline函数使用注意事项

    Inline函数使用注意事项 1.在一个文件中定义的inline函数不能再另一个文件中使用 2.inline函数应简洁,只有少数几个语句. 3.在inline函数中不能有循环,if,switch语句. ...

  6. transparent 透明效果

    background-color:transparent;就是把背景色设置为透明. 实际上background默认的颜色就是透明的属性.所以写和不写都是一样的 span{ width: 0; heig ...

  7. 【CTF MISC】文件内容反转方法-2017世安杯CTF writeup详解

    Reverseme 用winhex打开,发现里面的字符反过来可以正常阅读,所以文件被倒置了 Python解题程序如下 with open('reverseMe','rb') as f: with op ...

  8. 内核工具 – Sparse 简介【转】

    转自:http://www.cnblogs.com/wang_yb/p/3575039.html Sparse是内核代码静态分析工具, 能够帮助我们找出代码中的隐患. 主要内容: Sparse 介绍 ...

  9. 转 Java的 BigDecimal类型比较大小

    这个类是java里精确计算的类 1.比较对象是否相等,一般的对象用equals,但是BigDecimal比较特殊,举个例子 BigDecimal a = new BigDecimal.valueOf( ...

  10. 利用CSS函数calc(...)实现Web页面左右布局

    前言 因为自己的网站需要,想要做一个左右布局的页面: 左边是导航菜单之类的东西.右边是文档内容(因为最近看的一些软件的文档页面都是这么布局的): 左边固定宽度——300像素.右边使用剩余的宽度: 左边 ...