DEV Community

Alin Climente
Alin Climente

Posted on

1

How to create a simple scheduler in Django

If you need to run a function every X minutes/seconds etc. to do some cleanups, trigger some operations you can do a simple scheduler with the help of threading module and django custom cli commands.

Let's say I want to invoke a function every 5 seconds to post something on an external API.

In your django app create a folder/package named management inside that folder create another folder named commands. In the commands folder create a module named runposter.py. In the end you'll have something like this structure yourapp/management/commands/runposter.py.

In this code we use a thread which runs a while loop as long as it's not stopped every 5 seconds. Replace print("posting") with the function/logic you want to run.

# runposter.py
import time
from threading import Thread, Event
from django.conf import settings
from django.core.management.base import BaseCommand


stop_event = Event()


def my_job():
    while not stop_event.is_set():
        try:
            print("posting")
            time.sleep(5)
        except KeyboardInterrupt:
            break
        except Exception as err:
            print(err)
            continue



class Command(BaseCommand):
    help = "Run Poster."

    def handle(self, *args, **options):

        poster = Thread(target=my_job)

        try:
            print("Starting poster...")
            poster.start()
            while poster.is_alive():
                poster.join(timeout=1)
        except KeyboardInterrupt:
            print("Stopping poster...")
            stop_event.set()
            poster.join()
            print("Poster shut down successfully!")

Enter fullscreen mode Exit fullscreen mode

Nice, now open another terminal window and run python manage.py runposter. Command runposter as you can see was created from the module name we've given.

Of course, for something more complex I recommend using rq-scheduler or celery periodic tasks or django-q.

But, for simple cases this should be good enough.

Image of Timescale

Timescale – the developer's data platform for modern apps, built on PostgreSQL

Timescale Cloud is PostgreSQL optimized for speed, scale, and performance. Over 3 million IoT, AI, crypto, and dev tool apps are powered by Timescale. Try it free today! No credit card required.

Try free

Top comments (0)

A Workflow Copilot. Tailored to You.

Pieces.app image

Our desktop app, with its intelligent copilot, streamlines coding by generating snippets, extracting code from screenshots, and accelerating problem-solving.

Read the docs

👋 Kindness is contagious

Discover a treasure trove of wisdom within this insightful piece, highly respected in the nurturing DEV Community enviroment. Developers, whether novice or expert, are encouraged to participate and add to our shared knowledge basin.

A simple "thank you" can illuminate someone's day. Express your appreciation in the comments section!

On DEV, sharing ideas smoothens our journey and strengthens our community ties. Learn something useful? Offering a quick thanks to the author is deeply appreciated.

Okay