Skip to main content

Generic worker that performs concurrent tasks using coroutine.

Project description

coworker

Generic worker that performs concurrent tasks using coroutine.

Quick Start Tutorial

Define how a task is performed – takes a single input and optionally returns a result:

from coworker import Coworker

class SquareWorker(Coworker):
    async def do_task(self, task):  # Task can be anything, such as a tuple with a callable and args.
        return task * task

To run in the background forever and add tasks:

import asyncio

async def background_worker_example():
    worker = SquareWorker(max_concurrency=5,    # Only 5 tasks will run concurrently
                          auto_start=True)      # Automatically start worker in the background after adding tasks
                                                # and exits too when done.

    # Mulitiple tasks -- get all results after everything is done
    tasks = list(range(100))
    results = await asyncio.gather(*worker.add_tasks(tasks))
    print(results)  # results = [0, 1, 4, 9, ...]

    # Mulitiple tasks -- get first completed
    tasks = list(range(10))
    for task in asyncio.as_completed(worker.add_tasks(tasks)):
        print(await task)  # results = 0, 1, 4, 9, ...

    # Single task
    result = await worker.add_tasks(2)
    print(result)   # result = 4

# Run async usage example
asyncio.run(background_worker_example())

To run for a list of tasks and stop worker when finished:

task_futures = asyncio.run(SquareWorker().start([1, 2, 3]))
print([t.result() for t in task_futures])   # [1, 4, 9]

Project details


Download files

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

Source Distribution

coworker-1.0.4.tar.gz (14.1 kB view hashes)

Uploaded Source

Built Distribution

coworker-1.0.4-py3-none-any.whl (5.5 kB view hashes)

Uploaded Python 3

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