Skip to main content

A library of composable Python executors and futures

Project description

more-executors

Build Status Maintainability Test Coverage

This library is intended for use with the concurrent.futures 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 implicit cancel after timeout
  • Futures with transformed output values (sync & async)
  • Futures resolved by a caller-provided polling function
  • Throttle the number of futures running at once
  • Synchronous executor
  • Bridge concurrent.futures with asyncio
  • Convenience API for creating executors
  • Instrumented with Prometheus

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)

Development

virtualenv and pip may be used to locally install this project from source:

virtualenv ~/dev/python
. ~/dev/python/bin/activate

git clone https://github.com/rohanpm/more-executors
cd more-executors

pip install --editable .

Autotests may be run with pytest:

pip install -r test-requirements.txt
py.test

Submit pull requests against https://github.com/rohanpm/more-executors.

License

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

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-2.9.0.tar.gz (50.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

more_executors-2.9.0-py2.py3-none-any.whl (70.1 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

  • Download URL: more-executors-2.9.0.tar.gz
  • Upload date:
  • Size: 50.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/32.0 requests/2.24.0 requests-toolbelt/0.8.0 urllib3/1.26.8 tqdm/4.62.3 importlib-metadata/4.11.1 keyring/20.0.1 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.5

File hashes

Hashes for more-executors-2.9.0.tar.gz
Algorithm Hash digest
SHA256 5c4a47a060817b655156faf0c648eb0d7330a4fd01bc64f5d559550aa319100c
MD5 eff3aaba2cf2751ddbfb8f9e542ce117
BLAKE2b-256 7ad4d1c0cc0c7ef275ff62bb56241117498fb48bdd21f28551a8b30db2a68f28

See more details on using hashes here.

File details

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

File metadata

  • Download URL: more_executors-2.9.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 70.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/32.0 requests/2.24.0 requests-toolbelt/0.8.0 urllib3/1.26.8 tqdm/4.62.3 importlib-metadata/4.11.1 keyring/20.0.1 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.5

File hashes

Hashes for more_executors-2.9.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 fd1dad4d1b21d622795ec1035aa26ce6f63afba27f9531248b8e4ab213cba548
MD5 162531ac80c21135c2958dcd52797450
BLAKE2b-256 c02ce1294cc437c64dc72f15049887a305287ca18c7a94d89048e4f75c59a7cb

See more details on using hashes here.

Supported by

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