Back to Celery

Example Django project using Celery

examples/django/README.rst

5.6.31.7 KB
Original Source

============================================================== Example Django project using Celery

Contents

proj/

This is a project in itself, created using django-admin.py startproject proj, and then the settings module (proj/settings.py) was modified to add demoapp to INSTALLED_APPS

proj/celery.py

This module contains the Celery application instance for this project, we take configuration from Django settings and use autodiscover_tasks to find task modules inside all packages listed in INSTALLED_APPS.

demoapp/

Example generic app. This is decoupled from the rest of the project by using the @shared_task decorator. This decorator returns a proxy that always points to the currently active Celery instance.

Installing requirements

The settings file assumes that rabbitmq-server is running on localhost using the default ports. More information here:

https://docs.celeryq.dev/en/latest/getting-started/brokers/rabbitmq.html

In addition, some Python requirements must also be satisfied:

.. code-block:: console

$ pip install -r requirements.txt

Starting the worker

.. code-block:: console

$ celery -A proj worker -l INFO

Running a task

.. code-block:: console

$ python ./manage.py shell
>>> from demoapp.tasks import add, mul, xsum
>>> res = add.delay_on_commit(2, 3)
>>> res.get()
5

.. note::

The ``delay_on_commit`` method is only available when using Django,
and was added in Celery 5.4. If you are using an older version of Celery,
you can use ``delay`` instead.