2015-09-11 17 views
7

Come posso configurare Django logging per supportare diversi DSN per diversi loggers?Django/Raven/Sentry: diversi logger per diversi DSN

Qualcosa di simile a questo:

settings.py

LOGGING = { 
    .. 
    'handlers': { 
     'sentry1': { 
      'level': 'ERROR', 
      'class': 'raven.contrib.django.handlers.SentryHandler', 
      'dsn': '<DSN1>', 
     },   
     'sentry2': { 
      'level': 'ERROR', 
      'class': 'raven.contrib.django.handlers.SentryHandler', 
      'dsn': '<DSN2>', 
     }, 
    }, 
    'loggers': { 
     'sentry1':{ 
      'handlers': ['console', 'sentry1'], 
      'level': 'ERROR', 
      'propagate': False, 
     }, 
     'sentry2':{ 
      'handlers': ['console', 'sentry2'], 
      'level': 'ERROR', 
      'propagate': False, 
     }, 
} 

views.py

import logging 
logger = logging.getLogger('sentry2') 
logger.error('yeey!') 

risposta

1

Prova in questo modo ha funzionato per me

1) c handler ustom

from __future__ import absolute_import 

import logging 

from raven.handlers.logging import SentryHandler 


class CustomHandler(SentryHandler): 
    def __init__(self, *args, **kwargs): 
     dsn = kwargs.pop('dsn', None) 

     self.tags = kwargs.pop('tags', None) 

     logging.Handler.__init__(self, level=kwargs.get('level', logging.NOTSET)) 

     super(CustomHandler, self).__init__(dsn, **kwargs) 

2) Cambia la tua registrazione nelle impostazioni

LOGGING = { 
'version': 1, 
'disable_existing_loggers': True, 
'formatters': { 
    'verbose': { 
     'format': '%(levelname)s %(asctime)s %(module)s ' 
        '%(process)d %(thread)d %(message)s' 
    }, 
}, 
'handlers': { 
    'sentry1': { 
     'level': 'ERROR', 
     'class': 'project.sentry.CustomHandler', 
     'dsn': '<DSN1>', 
    }, 
    'sentry2': { 
     'level': 'ERROR', 
     'class': 'project.sentry.CustomHandler', 
     'dsn': '<DSN2>', 
    }, 
    'console': { 
     'level': 'DEBUG', 
     'class': 'logging.StreamHandler', 
     'formatter': 'verbose' 
    } 
}, 
'loggers': { 
    'sentry1': { 
     'handlers': ['sentry1'], 
     'level': 'ERROR', 
     'propagate': False, 
    }, 
    'sentry2': { 
     'handlers': ['sentry2'], 
     'level': 'ERROR', 
     'propagate': False, 
    }, 
} 
} 

3) Log vostri errori ovunque

import logging 
logger = logging.getLogger('sentry2') 
logger.error('yeey!') 

ha funzionato per me, testati con python3.6 django2.