Skip to main content

A database backed job scheduler for Django RQ with Django

Project description

Django RQ Scheduler

Django CI badge

A database backed job scheduler for Django RQ. Based on original django-rq-scheduler - Now supports Django 4.0.

This allows remembering scheduled jobs, their parameters, etc.

Installation

  1. Use pip to install:
pip install django-rq-scheduler
  1. In settings.py, add django_rq and scheduler to INSTALLED_APPS:

    INSTALLED_APPS = [
        ...
        'django_rq',
        'scheduler',
        ...
    ]
    
  2. Configure Django RQ. See https://github.com/ui/django-rq#installation

    Add at least one Redis Queue to your settings.py:

    RQ_QUEUES = {
      'default': {
          'HOST': 'localhost',
          'PORT': 6379,
          'DB': 0,
          'PASSWORD': 'some-password',
          'DEFAULT_TIMEOUT': 360,
      },
    }
    
  3. Run migrations.

    ./manage.py migrate
    

Usage

Making a method in your code a schedulable job to be run by a worker.

See http://python-rq.org/docs/jobs/ or https://github.com/ui/django-rq#job-decorator

An example:

myapp.jobs.py

from django_rq import job

@job
def count():
    return 1 + 1

Scheduling a Job

Scheduled Job

  1. Sign into the Django Admin site, http://localhost:8000/admin/ and locate the Django RQ Scheduler section.

  2. Click on the Add link for Scheduled Job.

  3. Enter a unique name for the job in the Name field.

  4. In the Callable field, enter a Python dot notation path to the method that defines the job. For the example above, that would be myapp.jobs.count

  5. Choose your Queue. Side Note: The queues listed are defined in the Django Settings.

  6. Enter the time the job is to be executed in the Scheduled time field. Side Note: Enter the date via the browser's local timezone, the time will automatically convert UTC.

  7. Click the Save button to schedule the job.

Repeatable Job

  1. Sign into the Django Admin site, http://localhost:8000/admin/ and locate the Django RQ Scheduler section.

  2. Click on the Add link for Repeatable Job

  3. Enter a unique name for the job in the Name field.

  4. In the Callable field, enter a Python dot notation path to the method that defines the job. For the example above, that would be myapp.jobs.count

  5. Choose your Queue. Side Note: The queues listed are defined in the Django Settings.

  6. Enter the time the first job is to be executed in the Scheduled time field. Side Note: Enter the date via the browser's local timezone, the time will automatically convert UTC.

  7. Enter an Interval, and choose the Interval unit. This will calculate the time before the function is called again.

  8. In the Repeat field, enter the number of time the job is to be ran. Leaving the field empty, means the job will be scheduled to run forever.

  9. Click the Save button to schedule the job.

Advanced usage using jobs with args

django-rq-scheduler supports

from django_rq import job
@job
def job_args_kwargs(*args, **kwargs):
    func = "test_args_kwargs({})"
    args_list = [repr(arg) for arg in args]
    kwargs_list = [k + '=' + repr(v) for (k, v) in kwargs.items()]
    return func.format(', '.join(args_list + kwargs_list))

Schedule job with custom arguments to be calculated when scheduling

  1. Sign into the Django Admin site, http://localhost:8000/admin/ and locate the Django RQ Scheduler section.

  2. Click on the Add link for Scheduled Job.

  3. Enter a unique name for the job in the Name field.

  4. In the Callable field, enter a Python dot notation path to the method that defines the job. For the example above, that would be myapp.jobs.job_args_kwargs

  5. Choose your Queue. Side Note: The queues listed are defined in the Django Settings.

  6. Enter the time the job is to be executed in the Scheduled time field. Side Note: Enter the date via the browser's local timezone, the time will automatically convert UTC.

  7. Click the Save button to schedule the job.

  8. Add arguments to the job, pick argument type.

  9. Add arguments with keys to the job, pick argument type and value.

Reporting issues or Features requests

Please report issues via GitHub Issues .

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-rq-scheduler-2022.9.tar.gz (15.9 kB view details)

Uploaded Source

Built Distribution

django_rq_scheduler-2022.9-py3-none-any.whl (17.7 kB view details)

Uploaded Python 3

File details

Details for the file django-rq-scheduler-2022.9.tar.gz.

File metadata

  • Download URL: django-rq-scheduler-2022.9.tar.gz
  • Upload date:
  • Size: 15.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.13

File hashes

Hashes for django-rq-scheduler-2022.9.tar.gz
Algorithm Hash digest
SHA256 6a3877642ebd2d58999c0f8cfa77cb40c716765bb5cb8cc2ef40f5a2901e469e
MD5 007973c28d141387f84f0813437be72b
BLAKE2b-256 adfbd6d0d7b221dace494773e91ecd7946ded23741b0ce8bd5e1b36f1fba81e9

See more details on using hashes here.

File details

Details for the file django_rq_scheduler-2022.9-py3-none-any.whl.

File metadata

File hashes

Hashes for django_rq_scheduler-2022.9-py3-none-any.whl
Algorithm Hash digest
SHA256 eae9d404b5c18a38dd525ef3b61ab2a3d026773c18589d449bdce037bb7995ad
MD5 058bd90594be32fbbbda858dbe500559
BLAKE2b-256 314ac7cf4167573fca6d4ce08f57d2b110cddcf02d107c005e5b487aa903ee57

See more details on using hashes here.

Supported by

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