django中日志配置
- # ======日志配置======
- # 错误优先级: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中日志配置的更多相关文章
- Django中日志管理
在settings中设置日志的相关信息,然后再逻辑代码区就可以保存相应的信息了 #简单设置: LOGGING = { 'version': 1, 'disable_existing_loggers': ...
- django 自定义日志配置
如果不想使用 python 的 dictConfig 格式来配置 logger,可以制定自己的配置架构. LOGGING_CONFIG 配置定义了用来配置 django logger 的可调用函数,默 ...
- django 完整日志配置
django中的log需要在settings.py中配置 import time cur_path = os.path.dirname(os.path.realpath(__file__)) # lo ...
- django开发日志配置
做django开发离不开 日志,这用于保存我门的服务器的日志信息,便于开发人员的维护. 直接上代码: 在setting.py文件里直接配置即可 LOGGING = { 'version': 1, 'd ...
- django中日志使用学习记录
在setting中加入以下代码 LOGGING = { 'version': 1, 'disable_existing_loggers': True, 'formatters': { 'verbose ...
- django中缓存配置
# ======缓存配置====== CACHES = { ## 虚拟缓存,开发调试版本,此为开始调试用,实际内部不做任何操作 # 'default': { # 'BACKEND': 'django. ...
- SpringBoot中日志配置
背景 由于一些框架中还使用log4j-1.x系列陈旧的日志框架,调试过程中有一些错误信息不能在控制台显示,增加了调试成本.以下配置方法 将帮助你获得log4j-1.x日志在控制台显示. 解决方法: 使 ...
- Redis缓存在django中的配置
django settings中的配置 # 缓存 CACHES = { "default": { "BACKEND": "django_redis. ...
- django中路由配置的正则
在django中配置路由遇到正则的坑: django2.x版本中使用re_path来进行正则表达式的匹配 用法如下: from Django.urls import re.path(导入re_path ...
随机推荐
- js鼠标自定移入输入框文本框光标自动定位到文本框
1.干货直接上 选中输入框设置如下: document.getElementById("Text1").focus();
- python初步学习-python模块之 commands
commands 通过 os.popen() 执行 shell 命令,返回两个对象,一个是 状态码(Int).另一个为命令输出(str) commands.getoutput(cmd) 返回命令执行输 ...
- react 带参数事件方法不立即执行
handleClick:()=>{this.to_step('to_step3_2')}}
- UNIX环境高级编程 第8章 进程控制
本章是UNIX系统中进程控制原语,包括进程创建.执行新程序.进程终止,另外还会对进程的属性加以说明,包括进程ID.实际/有效用户ID. 进程标识 每个进程某一时刻在系统中都是独一无二的,它们之间是用一 ...
- aarch64_g2
ghc-cryptonite-devel-0.21-1.fc26.aarch64.rpm 2017-02-28 01:28 3.1M fedora Mirroring Project ghc-css- ...
- 十五、springboot集成定时任务(Scheduling Tasks)(二)之(线程配置)
配置类: /** * 定时任务线程配置 * */ @Configuration public class SchedulerConfig implements SchedulingConfigurer ...
- Webmin试玩
安装: # cd /opt # wget http://www.webmin.com/jcameron-key.asc # wget http://www.webmin.com/download/rp ...
- Mac上删除不了的文件,Windows上也粉碎不了怎么办?
推荐一个Mac上的软件:Tuxera Disk Manager 用法很简单:选择删除文件原来所在的文件进行维护就可以了. 维护之后,在废纸篓中清除,成功.
- asp.net mvc 本地化 默认的错误提示
System.ComponentModel.DataAnnotations 给我们提供了一些特性来直接对model的属性进行验证和约束, 同时也提供了 ErrorMessageResourceName ...
- CSS--盒子模型详解
目录 图解 盒模型尺寸基准 使用浏览器的开发者工具,查看元素高(宽)度时,遇到的问题 一.图解 说明:由内而外依次是content.padding(内边距).border(边框).margin(外边距 ...