Skip to main content

A multiprocessing distributed task queue for Django

Project description

image0 image1 downloads

Django Q2 is a fork of Django Q. Big thanks to Ilan Steemers for starting this project. Unfortunately, development has stalled since June 2021. Django Q2 is the new updated version of Django Q, with dependencies updates, docs updates and several bug fixes. Original repository: https://github.com/Koed00/django-q

Features

  • Multiprocessing worker pool

  • Asynchronous tasks

  • Scheduled, cron and repeated tasks

  • Signed and compressed packages

  • Failure and success database or cache

  • Result hooks, groups and chains

  • Django Admin integration

  • PaaS compatible with multiple instances

  • Multi cluster monitor

  • Redis, IronMQ, SQS, MongoDB or ORM

  • Rollbar and Sentry support

Changes compared to the original Django-Q:

  • Dropped support for Disque (hasn’t been updated in a long time)

  • Dropped Redis, Arrow and Blessed dependencies

  • Updated all current dependencies

  • Added tests for Django 4.x and 5.x

  • Added Turkish language

  • Improved admin area

  • Fixed a lot of issues

See the changelog for all changes.

Requirements

Tested with:

  • Python 3.9 to 3.13.

  • Django 4.2 to 6.0.

Brokers

Installation

  • Install the latest version with pip:

    $ pip install django-q2
  • Add django_q to your INSTALLED_APPS in your projects settings.py:

    INSTALLED_APPS = (
        # other apps
        'django_q',
    )
  • Run Django migrations to create the database tables:

    $ python manage.py migrate
  • Choose a message broker, configure and install the appropriate client library.

Read the full documentation at https://django-q2.readthedocs.org

Configuration

All configuration settings are optional. e.g:

# settings.py example
Q_CLUSTER = {
    'name': 'myproject',
    'workers': 8,
    'recycle': 500,
    'timeout': 60,
    'compress': True,
    'cpu_affinity': 1,
    'save_limit': 250,
    'queue_limit': 500,
    'label': 'Django Q',
    'redis': {
        'host': '127.0.0.1',
        'port': 6379,
        'db': 0,
    }
}

For full configuration options, see the configuration documentation.

Management Commands

For the management commands to work, you will need to install Blessed: <https://github.com/jquast/blessed>

Start a cluster with:

$ python manage.py qcluster

Monitor your clusters with:

$ python manage.py qmonitor

Monitor your clusters’ memory usage with:

$ python manage.py qmemory

Check overall statistics with:

$ python manage.py qinfo

Creating Tasks

Use async_task from your code to quickly offload tasks:

from django_q.tasks import async_task, result

# create the task
async_task('math.copysign', 2, -2)

# or with a reference
import math.copysign

task_id = async_task(copysign, 2, -2)

# get the result
task_result = result(task_id)

# result returns None if the task has not been executed yet
# you can wait for it
task_result = result(task_id, 200)

# but in most cases you will want to use a hook:

async_task('math.modf', 2.5, hook='hooks.print_result')

# hooks.py
def print_result(task):
    print(task.result)

For more info see Tasks

Schedule

Schedules are regular Django models. You can manage them through the Admin page or directly from your code:

# Use the schedule function
from django_q.tasks import schedule

schedule('math.copysign',
         2, -2,
         hook='hooks.print_result',
         schedule_type=Schedule.DAILY)

# Or create the object directly
from django_q.models import Schedule

Schedule.objects.create(func='math.copysign',
                        hook='hooks.print_result',
                        args='2,-2',
                        schedule_type=Schedule.DAILY
                        )

# Run a task every 5 minutes, starting at 6 today
# for 2 hours
from datetime import datetime

schedule('math.hypot',
         3, 4,
         schedule_type=Schedule.MINUTES,
         minutes=5,
         repeats=24,
         next_run=datetime.utcnow().replace(hour=18, minute=0))

# Use a cron expression
schedule('math.hypot',
         3, 4,
         schedule_type=Schedule.CRON,
         cron = '0 22 * * 1-5')

For more info check the Schedules documentation.

Development

There is an example project that you can use to develop with. Docker (compose) is being used to set everything up. Please note that you will have to restart the django-q container when changes have been made to tasks or django-q. You can start the example project with:

make dev

Create a superuser with:

make createsuperuser

Testing

Running tests is easy with docker compose, it will also start the necessary databases. Just run:

make test

Locale

Currently available in English, German, Turkish, and French. Translation pull requests are always welcome.

Acknowledgements

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_q2-1.10.0.tar.gz (86.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_q2-1.10.0-py3-none-any.whl (106.2 kB view details)

Uploaded Python 3

File details

Details for the file django_q2-1.10.0.tar.gz.

File metadata

  • Download URL: django_q2-1.10.0.tar.gz
  • Upload date:
  • Size: 86.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.4 CPython/3.11.15 Linux/6.17.0-1010-azure

File hashes

Hashes for django_q2-1.10.0.tar.gz
Algorithm Hash digest
SHA256 cc805008986c560ed4e0a3ef08776c1b41f403a60477b2726a2545ae64b71504
MD5 af05af862a24d6c73e5efefcdcfb8065
BLAKE2b-256 38eaa97c24d04345b20afd3f04711642d7f27921dd8bbaba8ebfdbb77448be0a

See more details on using hashes here.

File details

Details for the file django_q2-1.10.0-py3-none-any.whl.

File metadata

  • Download URL: django_q2-1.10.0-py3-none-any.whl
  • Upload date:
  • Size: 106.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.4 CPython/3.11.15 Linux/6.17.0-1010-azure

File hashes

Hashes for django_q2-1.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7746c1cb7178551d81f25f47603ed29b80599e93d82ffd198c493a2b2323f3b5
MD5 a9bdcbccf9b3d8dd6dadea37680e2ca8
BLAKE2b-256 ab7292b531a3f794f1869a89e480045c82fd1cf27a98a73a83402ff7ad3f3234

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page