2013-12-10 16 views
7

sto usando il seguente comando:Python Sedano - Lavoratore ignorando INFO livello di log

sedano lavoratore informazioni -l -A django_app --concurrency = 10 --autoreload

Ma DEBUG registri sono ancora versando, lo stesso vale per quando si utilizza -l warning e --logfile

enter image description here


Qualche idea sul motivo per cui Celery ignorerebbe le impostazioni del registro?


Ulteriori dettagli:

i registri vengono dal Python libreria suds che emette al logger utilizzando DEBUG.

+0

Eventuali duplicati di [Django sedano Logging Best Practice] (http://stackoverflow.com/questions/13366312/django-celery-logging-best-practice) –

risposta

5

Ho avuto lo stesso problema e decido di regolare livello di log all'interno settings.py:

LOGGING['loggers']['celery'] = { 
           'handlers': ['console', <etc>], 
           'level': <LEVEL_YOU_WANT>, 
           'propagate': True, 
           } 

anche decido di disattivare alcuni registri "non interessanti":

LOGGING['loggers']['celery.redirected'] = { 
              'handlers': ['console', <etc>], 
              'level': <LEVEL_YOU_WANT>, 
              'propagate': False, 
              } 
for i in ['worker', 'concurrency', 'beat']: 
    LOGGING['loggers']['celery.' + i] = { 
           'handlers': [], 
           'level': 'WARNING', 
           'propagate': True, 
           } 
for i in ['job', 'consumer', 'mediator', 'control', 'bootsteps']: 
    LOGGING['loggers']['celery.worker.' + i] = { 
           'handlers': [], 
           'level': 'WARNING', 
           'propagate': True, 
           } 

In questo modo vi permetterà di vedi solo i log dei tuoi compiti, e non i "macchinari" di Celery.

1

Provare a utilizzare il CELERYD_HIJACK_ROOT_LOGGER setting:

celery_instance = Celery('django_app') 
celery_instance.add_defaults({ 
    'CELERYD_HIJACK_ROOT_LOGGER': False, 
})