我正在尝试按照用户指南app.conf.humanize(with_defaults=False)
中的示例打印 celery 的配置。但是我在使用时总是得到一个空字符串,我知道配置更改是有效的,因为我可以看到使用的更改。with_defaults=False
.humanize(with_defaults=True)
我猜想添加配置app.conf.config_from_object('myconfig')
是将配置设置加载为“默认值”,那么有没有办法以非默认方式在模块myconfig
中加载配置?
这是我的源代码:
#myconfig.py
worker_redirect_stdouts_level='INFO'
imports = ('tasks',)
和
#tasks.py
from celery import Celery
app = Celery()
app.config_from_object('myconfig')
print "config: %s" % app.conf.humanize(with_defaults=False)
@app.task
def debug(*args, **kwargs):
print "debug task args : %r" % (args,)
print "debug task kwargs: %r" % (kwargs,)
我开始使用 celeryenv PYTHONPATH=. celery worker --loglevel=INFO
并打印config:
(如果我更改为with_defaults=True
我得到预期的完整输出)。