Сельдерей не может прочитать значение из файла env после запуска супервизором

#django #environment-variables #celery #supervisord

Вопрос:

Я сталкиваюсь с проблемой, с которой, если я запускаю celery worker локально celery -A project worker -l info . Задачи сельдерея могут получать доступ к переменным из файла .env (я использую django-среду для чтения файла .env). Но на производственном сервере это вызывает проблемы после запуска супервайзером. Если ключ не существует в файле .env, он выдает ошибку, как и должно быть в задачах. Но, когда я правильно устанавливаю все переменные, он считывает их без ошибок, но читает их как пустые строки. Я также использую firebase_admin для уведомлений. Та же проблема возникает и с ним.

 import firebase_admin

firebase_admin.initialize_app()
 

Вот как я устанавливаю приложение по умолчанию в settings.py и файл учетной записи службы fcm также находится в моем каталоге проекта. Локально задача уведомления отправляет уведомление должным образом. Но после запуска супервизором он выдает ошибку «Файл не найден». Это довольно сбивает меня с толку.

Ниже приведен мой файл celery.conf:

 from __future__ import absolute_import, unicode_literals

import os
from celery import Celery

# set the default Django settings module for the 'celery' program.
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'project.settings')

app = Celery('project')


# Using a string here means the worker doesn't have to serialize
# the configuration object to child processes.
# - namespace='CELERY' means all celery-related configuration keys
#   should have a `CELERY_` prefix.
app.config_from_object('django.conf:settings', namespace='CELERY')

# Load task modules from all registered Django app configs.
app.autodiscover_tasks()


@app.on_after_configure.connect
def setup_periodic_tasks(sender, **kwargs):
    pass


@app.task(bind=True)
def debug_task(self):
    print(f'Request: {self.request!r}')
 

.env файл:

 ENV_TYPE="STAGING"
SECTET_KEY="SUPER_SECRET_KEY"
 

settings.py .часть чтения файла env:

 import environ

BASE_DIR = Path(__file__).resolve().parent.parent

env = environ.Env()
environ.Env.read_env((BASE_DIR / '.env').as_posix())  # reading .env file
 

Комментарии:

1. можете ли вы поделиться всей supervisor командой, а также путем, по которому вы храните .env файл ?

2. .env хранится в каталоге проекта

3. раздел команд worker.conf —> команда=/главная страница/aaman007/project_dir/venv/bin/сельдерей -Работник проекта —уровень журнала=ИНФОРМАЦИЯ —параллелизм=1

4. поскольку вы получили File Not Found error , просто выведите путь прямо перед местом возникновения ошибки и посмотрите, действительно ли этот путь существует. Это единственный способ отладки.

5. Я сохраняю путь в переменной в файле .env. Даже если весь путь там, он считывает его как пустую строку