Я хочу настроить супервизора для управления gunicorn в моем проекте django 1.6 с использованием переменной среды для SECRET_KEY.
Я установил свой секретный ключ в .bashrc как
export SECRET_KEY=[my_secret_key]
И у меня есть оболочка script, чтобы запустить guniororn:
NAME="myproject"
LOGFILE=/home/django/myproject/log/gunicorn.log
LOGDIR=$(dirname $LOGFILE)
NUM_WORKERS=3
DJANGO_WSGI_MODULE=myproject.wsgi
USER=django
GROUP=django
IP=0.0.0.0
PORT=8001
echo "Starting $NAME"
cd /home/django/myproject/myproject
source /home/django/.virtualenvs/myproject/bin/activate
test -d $LOGDIR || mkdir -p $LOGDIR
exec gunicorn ${DJANGO_WSGI_MODULE} \
--name $NAME \
--workers $NUM_WORKERS \
--user=$USER --group=$GROUP \
--log-level=debug \
--bind=$IP:$PORT
--log-file=$LOGFILE 2>>$LOGFILE
Затем, чтобы сконфигурировать мой проект gunicorn server в супервизоре:
[program:my_django_project]
directory=/home/django/my_django_project/my_django_project
command=/home/django/my_django_project/my_django_project/gunicorn.sh
user=django
autostart=true
autorestart=true
stdout_logfile=/home/django/my_django_project/log/supervisord.log
stderr_logfile=/home/django/my_django_project/log/supervisor_error.log
Если я запускаю пушки, используя мою оболочку script, это не вызывает никакой ошибки, но когда я запускаю ее с помощью супервизора, она терпит неудачу, и я вижу в журналах, что она не "находит" мой SECRET_KEY.
Каков правильный способ настройки супервизора для чтения моих переменных оболочки (я не буду хранить их в моем .bashrc, если нет более подходящего способа)?