Django : Конфигурация Celery с Rabbit MQ внутри docker
У меня уже есть контейнер rabbitmq, который запускается с моим django vm. Вот файл docker-compose.yml:
version: "3.8"
services:
web:
build: ./src
ports:
- "${PORT}:${PORT}"
depends_on:
- message
tty: true
stdin_open: true
container_name: ${COMPOSE_PROJECT_NAME}_app
expose:
- ${PORT}
links:
- message
env_file:
- .env
restart: unless-stopped
volumes:
- ./src:/code
message:
container_name: ${COMPOSE_PROJECT_NAME}_broker
image: rabbitmq:3.9.12-management
ports:
- "5672:5672"
- "15672:15672"
restart: always
volumes:
- ./data:/var/lib/rabbitmq/
env_file:
- .env
environment:
- RABBITMQ_DEFAULT_USER=${RABBITMQ_DEFAULT_USER}
- RABBITMQ_DEFAULT_PASS=${RABBITMQ_DEFAULT_PASS}
После установки celery с pypi и следуя Первым шагам, я создал файл **celery.py **, который находится в той же папке, что urls.py и settings.py, и, читая документацию, я использовал то же правило для _init.py.
celery.py :
from __future__ import absolute_import
import os
from celery import Celery
from django.conf import settings
# Set the default Django settings module for the 'celery' program.
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'project.settings.base')
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 apps.
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)
@app.task(bind=True)
def debug_task(self):
print(f'Request: {self.request!r}')
init.py:
from __future__ import absolute_import
# This will make sure the app is always imported when
# Django starts so that shared_task will use this app.
from .celery import app as celery_app
__all__ = ('celery_app',)
Внутри settings.py(base.py), конфигурации сельдерея:
# Celery Configuration Options
BROKER_URL = 'django://'
CELERY_RESULT_BACKEND = 'amqp://guest:guest@localhost:5672//'
CELERY_ACCEPT_CONTENT = ['application/json']
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'
Структура папок сегодня выглядит примерно так:
├── project
│ ├── asgi.py
│ ├── celery.py
│ ├── __init__.py
│ ├── settings
│ │ └── base.py
Но внутри контейнера djando, запустив '' celery worker '', я получил такую проблему:
consumer: Cannot connect to amqp://guest:**@127.0.0.1:5672//: [Errno 111] Connection refused.
Trying again in 2.00 seconds... (1/100)
Я проверил изменение конфигураций настроек celery, брокера и т.д. Похоже, что django не распознает URL брокера. Кто-нибудь может мне помочь?