Supervisor, Celery, Virtualenvwrapper, Django: Failed to import django parameters even when pythonpath is added to the environment

Can anyone see what I'm doing wrong here? No matter what I try, I can not get it to correctly determine the settings for Django. Works great when run manually in a terminal in active virtual space.

Supervisor

[program:celery_beetlejuice]
command = /home/padraic/.virtualenvs/beetlejuice/bin/python /home/padraic/CodeDev/beetlejuice/beetlejuice_django/manage.py celeryd -B -E -l INFO
directory=/home/padraic/CodeDev/beetlejuice/beetlejuice_django
environment=PYTHONPATH="/home/padraic/CodeDev/beetlejuice/beetlejuice_django", DJANGO_SETTINGS_MODULE="beetlejuice_django.settings"
user = padraic
autostart=true
autorestart=true
stdout_logfile=/home/padraic/CodeDev/beetlejuice/beetlejuice_django/logs/celeryd.log
stderr_logfile=/home/padraic/CodeDev/beetlejuice/beetlejuice_django/logs/celeryd.log
redirect_stderr=true
priority=998
numprocs=1

Traceback

Traceback (most recent call last):
  File "manage.py", line 10, in <module>
    execute_from_command_line(sys.argv)
  File "/home/padraic/.virtualenvs/beetlejuice/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 453, in execute_from_command_line
    utility.execute()
  File "/home/padraic/.virtualenvs/beetlejuice/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 392, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/home/padraic/.virtualenvs/beetlejuice/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 263, in fetch_command
    app_name = get_commands()[subcommand]
  File "/home/padraic/.virtualenvs/beetlejuice/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 109, in get_commands
    apps = settings.INSTALLED_APPS
  File "/home/padraic/.virtualenvs/beetlejuice/local/lib/python2.7/site-packages/django/conf/__init__.py", line 53, in __getattr__
    self._setup(name)
  File "/home/padraic/.virtualenvs/beetlejuice/local/lib/python2.7/site-packages/django/conf/__init__.py", line 48, in _setup
    self._wrapped = Settings(settings_module)
  File "/home/padraic/.virtualenvs/beetlejuice/local/lib/python2.7/site-packages/django/conf/__init__.py", line 134, in __init__
    raise ImportError("Could not import settings '%s' (Is it on sys.path?): %s" % (self.SETTINGS_MODULE, e))
ImportError: Could not import settings 'beetlejuice_django.settings' (Is it on sys.path?): 
+4
source share
1 answer

Sigh ... found out a mistake ...

So! I have a settings.py file that contains:

[settings.py]
import os
BEETLEJUICE_STATE = os.environ.get('BTJC_STATE',  None)

if BEETLEJUICE_STATE == 'LOCAL':
    from local_settings import *
elif BEETLEJUICE_STATE == 'DEV':
    from development_settings import *
elif BEETLEJUICE_STATE == 'PROD':
    from production_settings import *
else:
    raise ImportError

<aside>
... - ( ). , " ", :

settings/
    __init__.py
    base.py
    local.py
    test.py
    production.py

... , ,
 python manage.py runserver --settings='settings.production'
... base.py .
</aside>

... BTJC_STATE, virtualenvwrapper postactivate, , , celeryd , ! ImportError, , : = (

, , ... , -, ImproperlyConfigured - , , .conf , .

[program:celery_beetlejuice]
<snip>
environment=BTJC_STATE='LOCAL'
<snip>

, , , ( , api ..), virtualenv.

, , =)

+4

All Articles