django - 创建自定义 django 日志记录处理程序。 'module' 对象没有属性 'handlers'

标签 django exception exception-handling django-1.11 django-logging

我正在尝试创建一个基于类的日志记录处理程序,当应用程序使用 django 提供的一些内置日志记录配置看到 DisallowedHost 异常时,它会通知某些第三方服务。

但是,我得到了一个特殊的 import我无法理解如何解决的错误。

我的设置.py

LOGGING = {
    ...
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'notify_my_service': {
            'level': 'ERROR',
            'class': 'tools.exception_logging.NotifyMyServiceHandler'
        }
    },
    'loggers': {
        ...
        'django.security.DisallowedHost': {
            'handlers': ['notify_my_service'],
            'propagate': False,
        },
    },
}

我的异常处理程序:
import logging

class NotifyMyServiceHandler(logging.handlers.HTTPHandler):
    def emit(self, error):
        doSomething()

大追溯
Traceback (most recent call last):
  File "/usr/local/lib/python2.7/dist-packages/django/utils/autoreload.py", line 227, in wrapper
    fn(*args, **kwargs)
  File "/usr/local/lib/python2.7/dist-packages/django/core/management/commands/runserver.py", line 117, in inner_run
    autoreload.raise_last_exception()
  File "/usr/local/lib/python2.7/dist-packages/django/utils/autoreload.py", line 250, in raise_last_exception
    six.reraise(*_exception)
  File "/usr/local/lib/python2.7/dist-packages/django/utils/autoreload.py", line 227, in wrapper
    fn(*args, **kwargs)
  File "/usr/local/lib/python2.7/dist-packages/django/__init__.py", line 22, in setup
    configure_logging(settings.LOGGING_CONFIG, settings.LOGGING)
  File "/usr/local/lib/python2.7/dist-packages/django/utils/log.py", line 75, in configure_logging
    logging_config_func(logging_settings)
  File "/usr/lib/python2.7/logging/config.py", line 794, in dictConfig
    dictConfigClass(config).configure()
  File "/usr/lib/python2.7/logging/config.py", line 576, in configure
    '%r: %s' % (name, e))
ValueError: Unable to configure handler 'notify_my_service': 'module' object has no attribute 'handlers'

因此,由于某种原因,日志模块似乎没有正确导入。我已经尝试过来自其他线程的示例,例如在异常处理程序模块中导入设置。

是否可以以这种方式为 django 日志编写自定义处理程序?

最佳答案

当我在这里用代码模拟你的情况时,我遇到的问题是这段代码,因为 logging模块没有 handlers属性。

import logging

class NotifyMyServiceHandler(logging.handlers.HTTPHandler):
    def emit(self, error):
        doSomething()

您正在寻找的是导入 logging.handlers模块。 所以你需要:
import logging.handlers

class NotifyMyServiceHandler(logging.handlers.HTTPHandler):
    def emit(self, error):
        doSomething()

不幸的是,logging.config模块通过引发隐藏原始堆栈跟踪的新异常来报告错误,这使得查找原始错误变得困难。

关于django - 创建自定义 django 日志记录处理程序。 'module' 对象没有属性 'handlers',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53640531/

相关文章:

python - 可以使用 cmd ">>"登录 Django 开发服务器吗?

java - 使用简单 XML 反序列化时出现未知异常

java - 在 Java 中完成事务的正确代码模式是什么(异常回滚并成功提交)?

ruby - 我如何在 Ruby 中捕获此异常?

c++ - try-catch block 是否会降低性能

django - 管理界面主题化?

ajax - django,表单POST提交后返回上一页

java - 在 catch block 中抛出相同的异常

c# - 有没有办法在抛出 CLR 异常时触发事件

Angularjs 代码不适用于 Django