Chancy¶
A postgres-backed task queue for Python.
Key Features:¶
Jobs support priorities, retries, timeouts, scheduling, global rate limits, memory limits, global uniqueness, error capture, cancellation, and more
Minimal dependencies (only psycopg3 required)
Plugins for a
dashboard
,workflows
,cron jobs
, and much moreOptional transactional enqueueing for atomic job creation
asyncio & sync APIs for easy integration with existing codebases
100% open & free - no enterprise or paid features. Checkout the repo on GitHub.
Quick Start¶
Install Chancy & its CLI:
pip install chancy[cli]
Create a new file called worker.py
:
from chancy import Chancy, job
@job(queue="default")
def hello_world(*, name: str):
print(f"Hello, {name}!")
chancy = Chancy("postgresql://localhost/postgres")
Then run the database migrations:
chancy --app worker.chancy misc migrate
Declare a queue:
chancy --app worker.chancy queue declare default --concurrency 10
Push a job:
chancy --app worker.chancy queue push worker.hello_world --kwargs '{"name": "world"}'
Start a worker:
chancy --app worker.chancy worker start
Install Chancy:
pip install chancy
Create a new file called worker.py
:
import asyncio
from chancy import Chancy, Worker, Queue, job
@job(queue="default")
def hello_world(*, name: str):
print(f"Hello, {name}!")
chancy = Chancy("postgresql://localhost/postgres")
async def main():
async with chancy:
# Run the database migrations
await chancy.migrate()
# Declare a queue
await chancy.declare(Queue("default", concurrency=10))
# Push a job
await chancy.push(hello_world.job.with_kwargs(name="World"))
# Start the worker (ctrl+c to exit)
async with Worker(chancy) as worker:
await worker.wait_for_shutdown()
if __name__ == "__main__":
asyncio.run(main())
Congratulations! You’ve just run your first Chancy job. Next, explore the How To or plugins.
Dashboard¶
Chancy comes with a built-in dashboard
-
no need to run a separate service like Flower.
data:image/s3,"s3://crabby-images/33ae3/33ae3f6a5b533cdb64a405a355c95c771048c90e" alt="Jobs page"
data:image/s3,"s3://crabby-images/8e0e1/8e0e1dfd3d8bb2fd8af5732302c13e8ec3ddc25a" alt="Failed job page"
data:image/s3,"s3://crabby-images/e808d/e808d1ca375f9823b06d4a11fba951dabc92ccc7" alt="Queue page"
data:image/s3,"s3://crabby-images/2a507/2a5078660afff1159a59d05d934bb56856a3529b" alt="Worker page"
Similar Projects¶
With the addition of modern Postgres features like LISTEN/NOTIFY
and
SELECT FOR UPDATE...SKIP LOCKED
, postgres-backed task queues have
become a viable alternative to other task queues built on RabbitMQ or
redis like celery. As such the space is exploding with new projects.
Here are some of the most popular ones if Chancy doesn’t fit your
needs:
Project |
Language |
Note |
---|---|---|
Python |
The defacto Python task queue |
|
Python |
||
Elixir |
Inspired many of the features in Chancy |
|
Go |
||
Go |
||
Go |
||
Node.js |
||
Node.js |
||
Perl |