1. # ======日志配置======
  2. # 错误优先级:NOTSET < DEBUG < INFO < WARNING < ERROR < CRITICAL
  3. # Django使用dictConfig 格式,需要配置:loggers、handlers、filters、formatters
  4. # 创建logs日志目录
  5. if os.path.exists(os.path.join(BASE_DIR, 'logs')) is False:
  6. os.mkdir(os.path.join(BASE_DIR, 'logs'))
  7. # logs目录绝对路径
  8. LOGS_ROOT = os.path.join(BASE_DIR, 'logs')
  9. # 默认情况下,LOGGING设置与Django的默认logging配置进行合并
  10. LOGGING = {
  11. 'version': 1,
  12. # 如果LOGGING中的disable_existing_loggers键为True(默认值)那么默认配置中的所有logger 都将禁用(并非删除,仍然存在)
  13. # 如果你禁用配置过程,Django仍然执行logging调用,只是调用的是默认定义的logging 行为。
  14. # 你可以设置disable_existing_loggers为False,并重新定义部分或所有的默认loggers;
  15. # 或者你可以设置LOGGING_CONFIG为None,并自己处理logging 配置。
  16. 'disable_existing_loggers': False,
  17. # 日志记录需要转换成文本。Formatter 表示文本的格式。
  18. # asctime时间、threadName线程名称、thread线程号、name 记录器(loggers)的名称、lineno异常行号、
  19. # module执行日志记录调用的模块名称、funcName执行日志记录调用的函数名称、levelname日志记录级别的文本名称、message日志消息
  20. # 具体看:https://docs.python.org/3/library/logging.html#formatter-objects
  21. 'formatters': {
  22. 'standard': {
  23. 'format': '%(asctime)s [%(threadName)s:%(thread)s prototype] [%(name)s:%(lineno)s prototype] [%(module)s:%(funcName)s] [%(levelname)s]- %(message)s'
  24. },
  25. 'simple': {
  26. 'format': '%(asctime)s [%(threadName)s:%(thread)s prototype] [%(name)s:%(lineno)s prototype] [%(levelname)s]- %(message)s'
  27. }
  28. },
  29. # Filter用于对从logger传递给handler的日志记录进行额外的控制。
  30. 'filters': {
  31. 'require_debug_false': {
  32. '()': 'django.utils.log.RequireDebugFalse'
  33. }
  34. },
  35. # Handler决定如何处理logger中的每条消息
  36. 'handlers': {
  37. 'mail_admins': {
  38. 'level': 'ERROR',
  39. 'filters': ['require_debug_false'],
  40. 'class': 'django.utils.log.AdminEmailHandler'
  41. },
  42. 'default': {
  43. 'level': 'DEBUG', # 日志级别
  44. 'class': 'logging.handlers.RotatingFileHandler', # 输出到文件
  45. 'filename': os.path.join(LOGS_ROOT, 'all.log'), # 日志文件,请确保修改'filename'路径为运行Django应用的用户有权限写入的一个位置
  46. 'maxBytes': 1024 * 1024 * 5, # 5 MB 文件大小
  47. 'backupCount': 60, # 备份份数
  48. 'formatter': 'standard', # 使用哪种日志格式
  49. },
  50. 'console': {
  51. 'level': 'DEBUG', # 日志级别
  52. 'class': 'logging.StreamHandler', # 输出到控制台
  53. 'formatter': 'standard', # 使用哪种日志格式
  54. },
  55. 'request_handler': {
  56. 'level': 'DEBUG', # 日志级别
  57. 'class': 'logging.handlers.RotatingFileHandler', # 输出到文件
  58. 'filename': os.path.join(LOGS_ROOT, 'django_request.log'), # 日志文件
  59. 'maxBytes': 1024 * 1024 * 5, # 5 MB 文件大小
  60. 'backupCount': 60, # 备份份数
  61. 'formatter': 'standard', # 使用哪种日志格式
  62. },
  63. 'exception_handler': {
  64. 'level': 'DEBUG', # 日志级别
  65. 'class': 'logging.handlers.RotatingFileHandler', # 输出到文件
  66. 'filename': os.path.join(LOGS_ROOT, 'exception.log'), # 日志文件
  67. 'maxBytes': 1024 * 1024 * 5, # 5 MB 文件大小
  68. 'backupCount': 60, # 备份份数
  69. 'formatter': 'standard', # 使用哪种日志格式
  70. },
  71. },
  72. # Logger 为日志系统的入口。每个logger 是一个容器,可以向它写入需要处理的消息,可以配置用哪种handlers来处理日志
  73. # propagate为True时表示向上传播消息,将比level定义的级别更加高级的级别传递到handlers处理
  74. 'loggers': {
  75. 'django': {
  76. 'handlers': ['console'], # 日志处理器
  77. 'level': 'DEBUG', # 记录器级别
  78. 'propagate': False # 是否向上传播
  79. },
  80. # 某个app专用
  81. 'BangSo.app': {
  82. 'handlers': ['default', 'console'],
  83. 'level': 'DEBUG',
  84. 'propagate': True
  85. },
  86. 'django.request': {
  87. 'handlers': ['request_handler'],
  88. 'level': 'INFO',
  89. 'propagate': False
  90. },
  91. 'exception': {
  92. 'handlers': ['exception_handler'],
  93. 'level': 'ERROR',
  94. 'propagate': False
  95. },
  96. }
  97. }

解析:

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

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

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

log日志应用:

  1. logger = logging.getLogger('BangSo.app') #刚才在setting.py中配置的logger
  2. try:
  3. mysql= connectMysql('127.0.0.1', '3306', 'david')
  4. except Exception,e:
  5. 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. js鼠标自定移入输入框文本框光标自动定位到文本框

    1.干货直接上 选中输入框设置如下: document.getElementById("Text1").focus();

  2. python初步学习-python模块之 commands

    commands 通过 os.popen() 执行 shell 命令,返回两个对象,一个是 状态码(Int).另一个为命令输出(str) commands.getoutput(cmd) 返回命令执行输 ...

  3. react 带参数事件方法不立即执行

    handleClick:()=>{this.to_step('to_step3_2')}}

  4. UNIX环境高级编程 第8章 进程控制

    本章是UNIX系统中进程控制原语,包括进程创建.执行新程序.进程终止,另外还会对进程的属性加以说明,包括进程ID.实际/有效用户ID. 进程标识 每个进程某一时刻在系统中都是独一无二的,它们之间是用一 ...

  5. aarch64_g2

    ghc-cryptonite-devel-0.21-1.fc26.aarch64.rpm 2017-02-28 01:28 3.1M fedora Mirroring Project ghc-css- ...

  6. 十五、springboot集成定时任务(Scheduling Tasks)(二)之(线程配置)

    配置类: /** * 定时任务线程配置 * */ @Configuration public class SchedulerConfig implements SchedulingConfigurer ...

  7. Webmin试玩

    安装: # cd /opt # wget http://www.webmin.com/jcameron-key.asc # wget http://www.webmin.com/download/rp ...

  8. Mac上删除不了的文件,Windows上也粉碎不了怎么办?

    推荐一个Mac上的软件:Tuxera Disk Manager 用法很简单:选择删除文件原来所在的文件进行维护就可以了. 维护之后,在废纸篓中清除,成功.

  9. asp.net mvc 本地化 默认的错误提示

    System.ComponentModel.DataAnnotations 给我们提供了一些特性来直接对model的属性进行验证和约束, 同时也提供了 ErrorMessageResourceName ...

  10. CSS--盒子模型详解

    目录 图解 盒模型尺寸基准 使用浏览器的开发者工具,查看元素高(宽)度时,遇到的问题 一.图解 说明:由内而外依次是content.padding(内边距).border(边框).margin(外边距 ...