Skip to main content

Simple Distributed Task Queue : multiprocessing < sidita < celery

Project description

sidita license sidita python version

sidita last version

Overview

What is sidita ?

Sidita is a Python module which implements a distributed task queue featuring an intermediate solution between the multiprocessing module and a task scheduler like Celery.

The Sidita use case corresponds to the case where you need to run CPU bound tasks in parallel and you require an immunity to crashes, memory leaks and overruns. Theses requirements are met by a monitored subprocess implementation.

Where is the Documentation ?

The documentation is available on the sidita Home Page.

What are the main features ?

  • Must be a simple solution to circumvent to the GIL limitation : i.e. distribute and run tasks in parallel on local CPU cores

  • Must be a lightweight solution to Celery : no broker

  • Should be portable on main OS like Unix and Windows

  • Scheduler is implemented using an asyncio event loop and asyncio queue

  • Scheduler queue can be limited on size so as to prevent a memory overshoot at startup

  • Workers are spawned using asyncio subprocess and communicate through a pipe (stdin, stdout)

  • Pass any pickable object as request and response

  • Scheduler monitors workers and restart them when they was killed or they exceeded a memory or timeout threshold

  • Provide basic metrics on workers

Technical details in brief:

  • scheduler run a producer and N consumers coroutines in an asyncio event loop

  • the producer coroutine awaits on queue.put(task) ( if a size limit is set )

  • each consumer coroutine wraps a worker subprocess and await data on the stdout pipe

Technical details in brief:

  • scheduler run a producer and N consumers coroutines in an asyncio event loop

  • the producer coroutine awaits on queue.put(task) ( if a size limit is set )

  • each consumer coroutine wraps a worker subprocess and await data on the stdout pipe

How to install it ?

Look at the installation section in the documentation.

Credits

Authors: Fabrice Salvaire

News

V0 2018-05-01

Started project

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

sidita-1.0.1-py2.py3-none-any.whl (15.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file sidita-1.0.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for sidita-1.0.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 6b33b9279d285b219f5cfa66e17428a97669e3922b714228cacce36a3e02d73e
MD5 2ec04bad585051fba390db67ca1f848f
BLAKE2b-256 80b853000883cfe1921037eedd6451809a055a2e39afb93b2e9445ba2b8b6862

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page