Lightweight, agent-based, distributed scheduler
Project description
Cicada scheduler
Centralized Distributed Scheduler
Overview
- Cicada is best understood as a lightweight management layer between linux CRON and the end executables
- It requires a central database for setting up and monitoring schedules
- Schedules can be launched on any node that has registered itself to the database
- Nodes act as agents pulling scheduling information from the database.
Advantages over using only CRON
- A central log is kept of schedule executions and results
- Offers some schedule dependance management
- Non-running schedules can easily be moved from one node to another
- Running schedules can easily be terminated
Execution flow diagram
Setup Central Database
Verified on PostgreSQL versions 12.9 to 15.14
- Execute as postgres user setup/db_and_user.sql
- Change cicada user password
- Execute as cicada user setup/schema.sql
Database ERD
Setup Node
Verified on Ubuntu 18.04, 20.04 LTS and 22.04 LTS
Prerequisites
- ntpd
- cron
- python3.8
# Install Cicada Scheduler
sudo mkdir -p /opt/cicada
sudo chown -R $USER:$USER /opt/cicada
cd /opt/cicada
DIR=$(pwd)
cd $DIR
git clone git@github.com:transferwise/cicada.git .
make python=python3.8
# Update the db_cicada section of the environmental config file
cp $DIR/config/example.yml $DIR/config/definitions.yml
vim $DIR/config/definitions.yml
# Register new Node in Database
$DIR/bin/cicada register_server
# Add linux CRON job to check central scheduler every minute
echo "* * * * * $DIR/venv/bin/python3 $DIR/venv/bin/cicada exec_server_schedules" | crontab
Administration
cli help
cicada --help
(Re)register a server to Cicada
cicada register_server
Add or Update a new schedule
cicada upsert_schedule --help
schedule_id | Id of the schedule
schedule_description | Schedule description and comments
server_id | Id of the server where the schedule will run
schedule_order | run order for the schedule. lowest is first. is_async jobs will be execute in parallel
is_async | 0=Disabled 1=Enabled | is_async jobs execute in parallel
is_enabled | 0=Disabled 1=Enabled
adhoc_execute | 0=Disabled 1=Enabled | Execute at next minute, regardless of other settings
abort_running | 0=Disabled 1=Enabled | If the job is running, it will be terminated as soon as possible
interval_mask | When to execute the command | unix crontab (minute hour dom month dow)
first_run_date | The schedule will not execute before this datetime
last_run_date | The schedule will not execute after this datetime
exec_command | Command to execute
parameters | Parameters for exec_command
adhoc_parameters | If specified, will override parameters for one run
schedule_group_id | Optional field to help with schedule grouping
Launch a schedule once, as soon as possible
- adhoc_execute is a one-time schedule modification.
- As soon as adhoc_execution has been used, it is reset.
cicada upsert_schedule --schedule_id={schedule_id} --adhoc_execute={1}
Launch the next run of a schedule with different parameters
- adhoc_parameters is a one-time schedule modification.
- As soon as adhoc_parameters has been used, it is reset.
cicada upsert_schedule --schedule_id={schedule_id} ==adhoc_parameters={do something diffident}
Abort a running schedule
- abort_running is a one-time schedule modification.
- As soon as abort_running has been used, it is reset.
cicada upsert_schedule --schedule_id={schedule_id} --abort_running={1}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cicada-0.9.0.tar.gz.
File metadata
- Download URL: cicada-0.9.0.tar.gz
- Upload date:
- Size: 27.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4b3438673c83f7b2966f11b2ec915aad63cf923f608d7d7351a5afcfd64a8f01
|
|
| MD5 |
441be132a19f0a43abdaa8c0fac9c74d
|
|
| BLAKE2b-256 |
97183e963652a9a8741990d75531b947f5c74bc4aec77bec42a66f66a8620c97
|
Provenance
The following attestation bundles were made for cicada-0.9.0.tar.gz:
Publisher:
pypipublish.yml on transferwise/cicada
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cicada-0.9.0.tar.gz -
Subject digest:
4b3438673c83f7b2966f11b2ec915aad63cf923f608d7d7351a5afcfd64a8f01 - Sigstore transparency entry: 607803622
- Sigstore integration time:
-
Permalink:
transferwise/cicada@fa713e15a316abf365173251e456e7758ae9db3e -
Branch / Tag:
refs/tags/0.9.0 - Owner: https://github.com/transferwise
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypipublish.yml@fa713e15a316abf365173251e456e7758ae9db3e -
Trigger Event:
release
-
Statement type:
File details
Details for the file cicada-0.9.0-py3-none-any.whl.
File metadata
- Download URL: cicada-0.9.0-py3-none-any.whl
- Upload date:
- Size: 23.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3cd7e3f119f334882a33ac54222c65d50f7e88bedb8eb5f84754f348b23ab590
|
|
| MD5 |
d314398fd4587e09c3e15354157667bc
|
|
| BLAKE2b-256 |
e845d428c49c8b8b7884367274a68a6232cdb4f2c6690700c49726e266d2a13e
|
Provenance
The following attestation bundles were made for cicada-0.9.0-py3-none-any.whl:
Publisher:
pypipublish.yml on transferwise/cicada
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cicada-0.9.0-py3-none-any.whl -
Subject digest:
3cd7e3f119f334882a33ac54222c65d50f7e88bedb8eb5f84754f348b23ab590 - Sigstore transparency entry: 607803627
- Sigstore integration time:
-
Permalink:
transferwise/cicada@fa713e15a316abf365173251e456e7758ae9db3e -
Branch / Tag:
refs/tags/0.9.0 - Owner: https://github.com/transferwise
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypipublish.yml@fa713e15a316abf365173251e456e7758ae9db3e -
Trigger Event:
release
-
Statement type: