Ich habe eine Umgebungsvariable in supervisord:Python Key Fehler bei der Umgebungsvariable in supervisord Einstellung
[program:worker]
directory = /srv/app/
command=celery -A tasks worker -Q default -l info -n default_worker.%%h
environment=BROKER="amqp://admin:[email protected]:5672//"
In meinem celeryconfig.py ich dann versuchen, diese Variable wie diese zu lesen.
BROKER = os.environ['BROKER']
Aber ich bekomme immer noch den Schlüssel der Fehler unten, warum?
File "/usr/local/lib/python2.7/dist-packages/celery/loaders/base.py", line 106, in import_module
return importlib.import_module(module, package=package)
File "/usr/lib/python2.7/importlib/__init__.py", line 37, in import_module
__import__(name)
File "/srv/app/celeryconfig.py", line 6, in <module>
BROKER = os.environ['BROKER']
File "/usr/lib/python2.7/UserDict.py", line 23, in __getitem__
raise KeyError(key)
KeyError: 'BROKER
Es ist eine Datei, Dump des ENVs wie in den Kommentaren vorgeschlagen:
{
'SUPERVISOR_GROUP_NAME': 'celery_default_worker',
'TERM': 'linux',
'SUPERVISOR_SERVER_URL': 'unix: ///var/run/supervisor.sock',
'UPSTART_INSTANCE': '',
'RUNLEVEL': '2',
'UPSTART_EVENTS': 'runlevel',
'PREVLEVEL': 'N',
'SUPERVISOR_PROCESS_NAME': 'celery_default_worker',
'UPSTART_JOB': 'rc',
'PWD': '/',
'SUPERVISOR_ENABLED': '1',
'runlevel': '2',
'PATH': '/usr/local/sbin: /usr/local/bin: /sbin: /bin: /usr/sbin: /usr/bin',
'previous': 'N'
}
Seltsam - das sieht beim ersten Durchgang korrekt aus. Möglicherweise wird es beim Debuggen helfen, "mit open ("/tmp/sellery-environment.txt "," w ") als f: f.write (repr (os.environ))' zu deinem 'selleryconfig.py' hinzuzufügen, Überprüfen Sie dann die '/ tmp/sellery-environment.txt' Datei, um zu sehen, was * in Ihrer Umgebung * ist *? –
Bestätigen Sie die Ausführungsreihenfolge. d. h., ob die Umgebungsvariable BROKER zuerst in 'supervisord:' gesetzt wird oder BROKER zuerst in 'SelleryConfig.py' gelesen wird. Wenn 'CeleryConfig.py' zuerst gelesen wird, dann gibt es kein BROKER, da BROKER in 'supervisord' gesetzt ist:' – Vinkal
Hast du 'supervisord' gesagt, die Änderungen zu übernehmen, oder sonst' supervisord' neu starten? –