Skip to main content

A thread pool that auto-manages the number of worker threads and is compatible with the "futures" module ThreadPoolExecutor interface.

Project description

# CollapsingThreadPoolExecutor

The CollapsingThreadPoolExecutor is inspired by and compatible with the ThreadPoolExecutor from the
"futures" module, it operates differently in that worker threads are handled with a stack which results in the same worker or workers doing all the work (and idle workers being destroyed).

## How to install

$ pip install collapsing-thread-pool-executor

## How to develop

**Prerequisites**

* python3 w/ pip
* python2 w/ pip
* virtualenvwrapper
* entr

**Set up the environments**

$ mkvirtualenv -p `which python2.7` collapsing-thread-pool-executor-py2
$ pip install .
$ pip install -r requirements.txt

$ mkvirtualenv -p `which python3` collapsing-thread-pool-executor-py3
$ pip install .
$ pip install -r requirements.txt

**Watch the tests**

# watch python2 tests in one window
$ workon collapsing-thread-pool-executor-py2
$ find ./ -name '*.py' | entr -c py.test -v --log-level=DEBUG collapsing_thread_pool_executor

# watch python3 tests in one window
$ workon collapsing-thread-pool-executor-py3
$ find ./ -name '*.py' | entr -c py.test -v --log-level=DEBUG collapsing_thread_pool_executor

## Examples

The example below will execute `some_task()` 100 times; as `some_task()` should take a second to execute and as we've allocated 10 workers, the whole thing should take about 10 seconds.

import time

from collapsing_thread_pool_executor import CollapsingThreadPoolExecutor

def some_task():
time.sleep(1)

# all arguments are optional
pool = CollapsingThreadPoolExecutor(
workers=10,
thread_name_prefix='SomePool',
permitted_thread_age_in_seconds=60,
)

for i in range(0, 100):
pool.submit(some_task)


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

Built Distribution

File details

Details for the file collapsing-thread-pool-executor-2018.5.tar.gz.

File metadata

File hashes

Hashes for collapsing-thread-pool-executor-2018.5.tar.gz
Algorithm Hash digest
SHA256 e53440298dda071e116319666145917212a28ad9bb305ee38925dd3baf1e3aed
MD5 6ab70b9dec79f24edbe31ba25a0ccab3
BLAKE2b-256 7fe52b996074c8e3eab865f0bac3d8e9ad2088a3ec5650535783a001bce511ce

See more details on using hashes here.

Provenance

File details

Details for the file collapsing_thread_pool_executor-2018.5-py3-none-any.whl.

File metadata

File hashes

Hashes for collapsing_thread_pool_executor-2018.5-py3-none-any.whl
Algorithm Hash digest
SHA256 dc4b8b1ab6b6416d4666156f60cd680534572e09c6958825b99543e96691bd42
MD5 ef0ef01114e9d72db8f2dadd6151cb57
BLAKE2b-256 d398c1456d60494b236456ed5bb9df42441ee4804c732e5e9f0e28ecc81c1841

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