簡體   English   中英

Django,Celery Supervisor:秘密密鑰錯誤:django.core.exceptions.ImproperlyConfigured:SECRET_KEY設置不得為空

[英]Django, Celery Supervisor: Secret Key Error: django.core.exceptions.ImproperlyConfigured: The SECRET_KEY setting must not be empty

我有一個django 1.11.4,python3.5,gunicorn 19.7.1服務器和主管,redis 2.10.6和celery 4.1.0。

我的文件結構如下:

samy_python
├── celery.py
├── __init__.py
├── settings
├── urls.py
├── wsgi.py
website
├── static
├── templates
├── samy
|    ├── samy_firebase.py
|    ├── tasks.py
├── views.py

我的秘密在於:

# settings.py
SECRET_KEY = os.environ.get("secret_KEY")

我的celery主管conf文件是:

[program:gunicorn]

....
environment = secret_KEY="12345"
.....

[program:celery]
directory=/home/username/Projects/samy/samy_python
command=/home/username/Projects/samy/samy_python/env/bin/celery --app=samy_python.celery.app worker -B -l info
user=username
stdout_logfile=/var/log/celery/celery.log
stderr_logfile=/var/log/celery/celery.log
autostart=false
autorestart=false
startsecs=10

我的芹菜文件:

# celery.py

from __future__ import absolute_import
import os
import logging
logger = logging.getLogger('myapp.celery.py')

from celery import Celery
from django.conf import settings

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "samy_python.settings")

# Celery App
# TODO
# [START Celery App]
app = Celery('samy_python')
app.config_from_object('django.conf:settings')
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)

# [END Celery App]

我的初始化文件:

# __init__.py

from __future__ import absolute_import
from .celery import app as celery_app

在我的celery的settings.py文件中的配置:

BROKER_URL = 'redis://localhost:6379/1'
CELERY_RESULT_BACKEND = 'redis://localhost:6379/1'
CELERY_ACCEPT_CONTENT = ['application/json']
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'

錯誤可能來自哪里,在我的settings.py文件中,我使用一個env變量來設置環境。 (生產,開發或測試):

DEBUG = False
DJANGO_TESTING = False
DJANGO_DEVELOPMENT = False
DJANGO_ENV = os.environ.get('DJANGO_ENV')

if DJANGO_ENV == 'DJANGO_TESTING':
    DJANGO_TESTING = True
elif DJANGO_ENV == 'DJANGO_DEVELOPMENT':
    DJANGO_DEVELOPMENT = True

然后,設置Firebase憑據和Google Api憑據。 然后,我使用以下命令從例如samy_firebase.py中獲取憑據:

from django.conf import settings
if settings.DJANGO_TESTING == True:
    logger.info('Firebase Config: Test DB')

我不確定最后一部分是否相關,但這是我一直收到的錯誤:

   Traceback (most recent call last):
  File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/kombu/utils/objects.py", line 42, in __get__
    return obj.__dict__[self.__name__]
KeyError: 'data'

During handling of the above exception, another exception occurred:

    Traceback (most recent call last):
      File "/home/dorian/Projects/samy/samy_python/env/bin/celery", line 11, in <module>
        sys.exit(main())
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/__main__.py", line 14, in main
        _main()
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/bin/celery.py", line 326, in main
        cmd.execute_from_commandline(argv)
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/bin/celery.py", line 488, in execute_from_commandline
        super(CeleryCommand, self).execute_from_commandline(argv)))
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/bin/base.py", line 281, in execute_from_commandline
        return self.handle_argv(self.prog_name, argv[1:])
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/bin/celery.py", line 480, in handle_argv
        return self.execute(command, argv)
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/bin/celery.py", line 412, in execute
        ).run_from_argv(self.prog_name, argv[1:], command=argv[0])
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/bin/worker.py", line 219, in run_from_argv
        *self.parse_options(prog_name, argv, command))
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/bin/base.py", line 403, in parse_options
        self.parser = self.create_parser(prog_name, command)
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/bin/base.py", line 419, in create_parser
        self.add_arguments(parser)
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/bin/worker.py", line 275, in add_arguments
        default=conf.worker_state_db,
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/utils/collections.py", line 130, in __getattr__
        return self[k]
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/utils/collections.py", line 431, in __getitem__
        return getitem(k)
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/utils/collections.py", line 280, in __getitem__
        return mapping[_key]
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/collections/__init__.py", line 982, in __getitem__
        if key in self.data:
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/kombu/utils/objects.py", line 44, in __get__
        value = obj.__dict__[self.__name__] = self.__get(obj)
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/app/base.py", line 148, in data
        return self.callback()
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/app/base.py", line 911, in _finalize_pending_conf
        conf = self._conf = self._load_config()
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/app/base.py", line 921, in _load_config
        self.loader.config_from_object(self._config_source)
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/loaders/base.py", line 133, in config_from_object
        self._conf = force_mapping(obj)
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/celery/utils/collections.py", line 50, in force_mapping
        if isinstance(m, (LazyObject, LazySettings)):
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/django/utils/functional.py", line 238, in inner
        self._setup()
      File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/django/conf/__init__.py", line 41, in _setup
        self._wrapped = Settings(settings_module)
File "/home/dorian/Projects/samy/samy_python/env/lib/python3.5/site-packages/django/conf/__init__.py", line 129, in __init__
    raise ImproperlyConfigured("The SECRET_KEY setting must not be empty.")
django.core.exceptions.ImproperlyConfigured: The SECRET_KEY setting must not be empty.

另外,gunicorn效果很好,因此如果我不啟動芹菜程序,它會接收環境變量。 另外,如果我在settings.py文件中將密鑰設置為“ 12345”,它將啟動。

像這樣在env中設置secret_KEY:

export SECRET_KEY="#mysecret_key"

並檢查:

echo $SECRET_KEY

然后在您的Django設置中,更改為:

SECRET_KEY = os.environ.get("SECRET_KEY")

有關詳細的參考檢查: 讀取和設置環境變量

將環境變量添加到超級用戶conf文件的[program:celery]部分。 目前,它僅適用於gunicorn

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM