Skip to main content

A queue service for quickly running scripts sequentially to use all your CPUs efficiently

Project description

Inspired with code from https://github.com/fastai/fastgpu

fastcpu

A queue service for quickly developing scripts that use all your CPUs efficiently

PULL REQUESTS WELCOME!

fastcpu provides a single command, fastcpu_poll, which polls a directory to check for scripts to run, and then runs them on the first available CPU. If no CPUs are available, it waits until one is. If more than one CPU is available, multiple scripts are run in parallel, one per CPU. (Note currently the CPU load checking is not implemented, the scripts are run sequentially at polling interval)

Installation

pip install fastcpu

How to use

--help provides command help:

$ fastgpu_poll --help

optional arguments:

  -h, --help                         show this help message and exit
  --path PATH                        Path containing `to_run` directory (default: .)
  --exit_when_empty EXIT_WHEN_EMPTY  Exit when `to_run` is empty (default: 1)
  --poll_interval POLL_INTERVAL      The duration between polls (default: 0.1)
  --terminate_timout                 The timeout at which point we kill the running script in seconds, -1 to never terminate

If installed via pip there is a handy command line method available

fastcpu_poll --path /path/to/scripts --exit_when_empty 0 --poll_interval 60

If running as a module

python -m fastcpu.cli --path /path/to/scripts --exit_when_empty 0 --poll_interval 60

The above examples will run scrips located in the to_run subdirectory of the directory being monitored The program will not exit when there are no scripts left to run, it will keep polling since we set that to 0 the polling interval is 60 seconds, it can be set as fractions of a second e.g 0.1

once the program starts it creates the following directory structure. you can then your scripts in the to_run folder, and the scrips are run sequentially

.
├── complete
├── fail
├── out
├── running
└── to_run
    ├── script_example1.sh
    └── script_example2.sh

fastcpu_poll will run each script in to_run in sorted order. Each script will be assigned to one CPU (future)

Once a script is selected to be run, it is moved into a directory called running. Once it's finished, it's moved into complete or fail as appropriate. stdout and stderr are captured to files with the same name as the script, plus stdout or stderr appended.

If exit_when_empty is 1 (which is the default), then once all scripts are run, fastcpu_poll will exit. If it is 0 then fastcpu_poll will continue running until it is killed; it will keep polling for any new scripts that are added to to_run.

Development

local testing

python -m fastcpu.cli --path test_scripts --exit_when_empty 1 --poll_interval 5 --terminate_timeout 12

Troubleshooting

If you get permission denied error in stderr logs check that your scripts are executable

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

fastcpu-1.5.0.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

fastcpu-1.5.0-py3-none-any.whl (7.6 kB view details)

Uploaded Python 3

File details

Details for the file fastcpu-1.5.0.tar.gz.

File metadata

  • Download URL: fastcpu-1.5.0.tar.gz
  • Upload date:
  • Size: 6.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.8.5

File hashes

Hashes for fastcpu-1.5.0.tar.gz
Algorithm Hash digest
SHA256 836488f9362159e83a24af5b0253d266f14b70f8c5ca2436c021c0827bf6e79e
MD5 33a92f98e57c3c1bee2b63e86cb89057
BLAKE2b-256 94d113ed6bd917dffbaf5593791fe5e4edf8666ee5974fc0f93932950da56027

See more details on using hashes here.

File details

Details for the file fastcpu-1.5.0-py3-none-any.whl.

File metadata

  • Download URL: fastcpu-1.5.0-py3-none-any.whl
  • Upload date:
  • Size: 7.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.8.5

File hashes

Hashes for fastcpu-1.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9233875f5145289427db8d81e02becfa92d2ecd7339ebc3435cbb1e90e171e1c
MD5 d5cb880aff5b528c32ab1cf608e7c85d
BLAKE2b-256 2502b766056cf2f97a4355cb1b518862543e19a3cf50df0d14e38dbdb40f1b11

See more details on using hashes here.

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