A beat server for Django, with cron-like syntax
Bronski allows you to configure periodic function calls using a Django model.
It is ideally suited to being a task "beat" sever, akin to celery-beat.
$ pip install bronski
Add 'bronski' to your
INSTALLED_APPS
This is only needed to enable the management command.
Create a model in your own app that inherits from
bronski.models.CrontabBase
Create and apply migrations:
$ manage.py makemigrations $ manage.py migrate
Specify your model in settings
CRONTAB_MODEL = "myapp.MyCronModel"
Launch your beat server:
$ ./manage.py bronski
Each minute the bronski
service will scan the model for enabled jobs that
haven't been run in the past 59 seconds. It will then check each to see if its
crontab definition matches the next minute.
For job records that match, their run
method will be called. The default
run
method will:
- get the specified function by calling
self.get_function()
- resolve the
kwargs
to use by callingself.get_kwargs()
- invoke the function with the
kwargs
.
You can override run
in your custom model to, for instance, enqueue jobs:
class Jobs(CrontabBase):
def run(self):
func = self.get_function()
kwargs = self.get_kwargs()
# Celery task API:
func.delay(**kwargs)
# Dramatiq actor API:
func.send(**kwargs)