A library of composable Python executors and futures
Project description
more-executors
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
withasyncio
- 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
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
Built Distribution
File details
Details for the file more-executors-2.11.4.tar.gz
.
File metadata
- Download URL: more-executors-2.11.4.tar.gz
- Upload date:
- Size: 52.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.16
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f1b21d72c4c15069e891d9b96bca05f9abde149e3c11ca54630c5a1a5ee8f4b5 |
|
MD5 | 50bcdc8af7ef4791be633f32be0d098c |
|
BLAKE2b-256 | b1aab16e2197fcf2721e0840ebcd88c687fdf0446608260d6a6d1fcb3e175a8d |
File details
Details for the file more_executors-2.11.4-py2.py3-none-any.whl
.
File metadata
- Download URL: more_executors-2.11.4-py2.py3-none-any.whl
- Upload date:
- Size: 71.5 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.16
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a304139c6bece5be18aed7dcff4c48440412cb7cbe90f64ba4572772fcb0407f |
|
MD5 | 7fb3a6613ca7322e0cf16fa48c073ae2 |
|
BLAKE2b-256 | d4abd24c17cc6c68125d631a129bf7cc809460106bcce1959aa8a37453ca95d9 |