10

我在火车上可能有点晚了,但我想使用 Sentry 和 Raven 登录 Django。

我设置了哨兵和乌鸦,在那里我对乌鸦进行了测试,它可以工作。

所以现在我想将调试消息发送到哨兵,但我该怎么做呢?

设置.py

RAVEN_CONFIG = {
    'dsn': 'http://code4@mydomain:9000/2',
    # If you are using git, you can also automatically configure the
    # release based on the git info.
    'release': raven.fetch_git_sha(BASE_DIR),
}

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'verbose': {
            'format': '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d %(message)s'
        },
    },
    'handlers': {
        'sentry': {
            'level': 'WARNING',
            'class': 'raven.contrib.django.raven_compat.handlers.SentryHandler',
        },
        'console': {
            'level': 'WARNING',
            'class': 'logging.StreamHandler',
            'formatter': 'verbose'
        }
    },
    'loggers': {
        'django': {
            'handlers': ['sentry'],
            'level': 'DEBUG',
            'propagate': True,
        },
        'raven': {
            'level': 'DEBUG',
            'handlers': ['sentry'],
            'propagate': False,
        },
        'sentry.errors': {
            'level': 'DEBUG',
            'handlers': ['sentry'],
            'propagate': False,
        },
    }
}

视图.py

import logger
from raven.contrib.django.models import get_client


client = get_client()
client.captureException()

logger = logging.getLogger(__name__)



def my_view(request):

   [...]
    logger.error('There was some crazy error', exc_info=True, extra={
    # Optionally pass a request and we'll grab any information we can
    'request': request,
    })
    [...]

此时它只记录错误和异常,但不会向我发送此错误消息...

如何正确使用渡鸦和哨兵?文档完全没有帮助,我的 google foo 也离开了我。任何提示或有用的教程?

4

1 回答 1

15

您定义了 3 个记录器djangoravensentry.errors. 当您打电话时,logging.getLogger(__name__)您实际上创建了一个“丢弃”,因为您___name__与上述任何一个都不匹配。

您应该使用raven记录器...

logger = logging.getLogger('raven')
logger.debug('Hola!')

...或设置您自己的:

LOGGING = {
    # ...
    'loggers': {
        # ...
        'yourapp': {
            'level': 'debug',
            'handlers': ['sentry'],
            'propagate': False,
        },
    }
}

然后在yourapp/views.py

logger = logging.getLogger(__name__)
logger.debug('Hola!')
于 2016-01-11T19:04:27.483 回答