A very simple asynchronous task/job queue
Project description
Negotium
A simple, lightweight, and easy-to-use task or job queue for Python. It tries to mimic the implementation of celery and celery beat, but without the complexity and overhead. It runs on a single machine, and it is designed to be used in a single process.
For now, it offers only a minimal set of features, which will be expanded. It also currently only supports Redis as the broker; however, it is planned to support other brokers in the future.
Installation
pip install negotium
Usage
# ---- main.py (app entry point) ----
from negotium import Negotium
app = Negotium(broker_url="redis://localhost:6379/0", app_name="my_app")
app.start()
@app.task
def add(x, y):
return x + y
# --- app.py (another module) ----
from main import app
# Run the task asynchronously
add.delay(1, 2)
# Schedule the task to run at a specific time
add.apply_async(args=(1, 2), eta=datetime.datetime.now() + datetime.timedelta(seconds=10))
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
negotium-0.0.1a1.tar.gz
(5.2 kB
view hashes)
Built Distribution
Close
Hashes for negotium-0.0.1a1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | f82044b98862f4e31fc648fde7b0b70bf19ac54c515a89487c607095cee8408b |
|
MD5 | 9d0eec8a19c7696d3e53751db2982076 |
|
BLAKE2b-256 | 95f91942551f06a6bd14dcbb3228888ee1cf8c6b9082ac061692d1f998028f9c |