Skip to main content

A library of composable Python executors

Project description

Build Status Coverage Status

This library is intended for use with the `concurrent.futures <https://docs.python.org/3/library/concurrent.futures.html>`__ module. It includes a collection of Executor implementations in order to extend the behavior of Future objects.

Features

  • Futures with implicit retry

  • Futures with implicit cancel on executor shutdown

  • Futures with transformed output values

  • Futures with a default timeout

  • Futures resolved by a caller-provided polling function

  • Synchronous executor

  • Convenience API for creating executors

See the API documentation for detailed information on usage.

Example

This example combines the map and retry executors to create futures for HTTP requests running concurrently, decoding JSON responses within the future and retrying on error.

import requests
from concurrent.futures import as_completed
from more_executors import Executors


def get_json(response):
    response.raise_for_status()
    return (response.url, response.json())


def fetch_urls(urls):
    # Configure an executor:
    # - run up to 4 requests concurrently, in separate threads
    # - run get_json on each response
    # - retry up to several minutes on any errors
    executor = Executors.\
        thread_pool(max_workers=4).\
        with_map(get_json).\
        with_retry()

    # Submit requests for each given URL
    futures = [executor.submit(requests.get, url)
               for url in urls]

    # Futures API works as normal; we can block on the completed
    # futures and map/retry happens implicitly
    for future in as_completed(futures):
        (url, data) = future.result()
        do_something(url, data)

Changelog

v1.6.0 - Introduce TimeoutExecutor - Use monotonic clock in RetryExecutor - Avoid some uninterruptible sleeps on Python 2.x - Minor improvements to logging

License

GPLv3

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

more-executors-1.6.0.tar.gz (14.2 kB view details)

Uploaded Source

Built Distribution

more_executors-1.6.0-py2.py3-none-any.whl (31.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file more-executors-1.6.0.tar.gz.

File metadata

File hashes

Hashes for more-executors-1.6.0.tar.gz
Algorithm Hash digest
SHA256 230a92870e91b3834ccb00fbaa23480e2e9a12031503cd4d8d008214b3e2174a
MD5 6c35ba5f0ae86441f44e2ccd21fb1ba0
BLAKE2b-256 961aa67a4de416241c72654c6dcf6c02f4b6c3008d4976054b32574c582863f9

See more details on using hashes here.

Provenance

File details

Details for the file more_executors-1.6.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for more_executors-1.6.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 26fc6aa54aa3315ba258b3aa48c6859c7cc95d64aa6d3944e518b54932a68d16
MD5 9c8c474a5bd774a265c7bbf8f27ddcce
BLAKE2b-256 48bb6ac5d1391de8b2938ebf8bbe77529a2437720d24ca71b0e5c751cf74bea7

See more details on using hashes here.

Provenance

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