pool/README.md

20 lines
1.8 KiB
Markdown
Raw Normal View History

2021-08-21 17:43:32 +02:00
# pool.sh a simple processes pool management
2021-08-22 09:25:41 +02:00
**What is pool.sh ?** pool.sh allows you to create simple pools of processes. This is usefull to run several process in parallel such as simulations or computations. It is designed to be used in bash scripts.
2021-08-21 17:43:32 +02:00
**How it works ?**
- Create a pool with `./pool.sh create <poolname> <capacity>`
2021-08-22 09:25:41 +02:00
- Launch a process in a pool with `./pool.sh run <poolname> <command>` which return the process id `<procid>`. If the pool `<poolname>` is full (number of processes equals to `<capacity>`) pool.sh will wait until room has been made in the pool to run `<command>`.
2021-08-21 17:43:32 +02:00
- Get the output of a process with `./pool.sh cat <poolname> <procid>`
- Wait until all the processes are completed with `./pool.sh wait <poolname>`
2021-08-22 09:25:41 +02:00
- Remove a pool with `./pool.sh remove <poolname>`. If processes are still running in the `<poolname>` this call will fail.
- Force the removal of a pool with `./pool.sh remove-force <poolname>`. All running processes will be killed and the pool will be deleted
- Additional properties can be attached to processes with `./pool.sh setp <poolname> <procid> <propname> <propvalue>`. Default properties are `<cmd>`,`<procpid>`,`<startat>`.
2021-08-21 17:43:32 +02:00
- Properties can be retrieve with `./pool.sh getp <poolname> <procid> <propname>`
2021-08-22 09:00:50 +02:00
- Processes in a pool can be paused with `./pool.sh pause <poolname>`
- Processes in a pool can be resumed with `./pool.sh resume <poolname>`
2021-08-21 18:24:45 +02:00
- Available pools can be retrieve with `./pool.sh ls`
- All the processes output file can be retrieve with `./pool.sh ls-output <poolname>`
2021-08-21 17:43:32 +02:00
2021-08-22 09:26:50 +02:00
**Final quote:** No checks are performed the arguments. THus, be sure to use the right ones. The default configuration requires access to the `/tmp` directory and uses name conventions which may clash with the existing content of `/tmp` if you are very unlucky. If in this the case, you can edit `pool.sh` to avoid those clashes.