2

我正在celery使用django. 很长一段时间以来,一切都运行良好,但最近我在celery. 现在我的日志配置有以下内容:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'verbose': {
            'format': '[%(levelname)s %(asctime)s %(thread)d] %(module)s:%(funcName)s - %(message)s'
        },
        'simple': {
            'format': '%(levelname)s %(message)s'
        },
        },
    'filters': {
        'require_debug_false': {
            '()': 'django.utils.log.RequireDebugFalse'
        }
    },
    'handlers': {
        'mail_admins': {
            'level': 'ERROR',
            'filters': ['require_debug_false'],
            'class': 'django.utils.log.AdminEmailHandler'
        },
        'mail_admins_critical': {
            'level': 'CRITICAL',
            'filters': ['require_debug_false'],
            'class': 'django.utils.log.AdminEmailHandler'
        },
        'file': {
            'level': 'DEBUG',
            'class': 'logging.handlers.TimedRotatingFileHandler',
            'formatter': 'verbose',
            'filename': '/tmp/django.log',
            'when' : 'midnight',
            'interval' : 1
        },
        'celery': {
            'level': 'DEBUG',
            'class': 'logging.handlers.TimedRotatingFileHandler',
            'formatter': 'verbose',
            'filename': '/tmp/celery.log',
            'when' : 'midnight',
            'interval' : 1
        },
        'console': {
            'level': 'DEBUG',
            'formatter': 'verbose',
            'class': 'logging.StreamHandler'
        },
    },
    'loggers': {
        'main.logger': {
            'handlers': ['file', 'console', 'mail_admins_critical'],
            'level': 'INFO',
            'propagate': True,
        },
        'celery.logger': {
            'handlers': ['celery', 'console', 'mail_admins_critical'],
            'level': 'INFO',
            'propagate': True,
        },
        'django.request': {
            'handlers': ['mail_admins'],
            'level': 'ERROR',
            'propagate': True,
        },
    }
}

对于所有celery文件,我将以下内容放在顶部:logger = get_task_logger('celery.logger')

我注意到 celery 的日志文件有用户www-data,并且在首次创建日志文件(celery.log)时没有写权限。如何更改权限,以便默认情况下可以?直到最近我才开始遇到这个问题......

我阅读了以下内容:

https://groups.google.com/forum/?fromgroups=#!topic/celery-users/wUHlE1piHu8

http://docs.celeryproject.org/en/latest/reference/celery.app.log.html

编辑

当我将记录的行更改为此:

logger = get_task_logger(__name__)

并放入CELERYD_HIJACK_ROOT_LOGGER = False我的settings.py,它仍然劫持我的主记录器(main.logger)。有没有办法阻止它?然后它将需要对该日志文件的权限,否则......

4

1 回答 1

1

celery git repo 中的通用初始化脚本为此使用了一个专用目录,例如:

/var/log/celery/worker1.log
/var/log/celery/worker2.log
/var/log/celery/beat.log

然后,您可以授予www-data在此目录中创建和读取文件的权限:

sudo chmod 755 /var/log/celery
sudo chown www-data:www-data /var/log/celery

您不应该为非特权用户授予对 /var/log 顶级目录的写访问权,因此使用子目录是一种很好的做法。

于 2013-02-14T16:26:27.337 回答