pexec is a command-line driven utility for Linux or other Unix-like operating systems which allows the user to execute "for ~ do ~ done" like shell loops in parallel. The specified command or (a piece of) script can be executed on both local and remote host computers, in the case of remote execution, ssh is used to build a secure tunnel between the hosts. Like in shell loops, a pre-defined shell (environmental) variable is varied during the loop which is passed transparently to the command or script. pexec is a free software, and part of the GNU project. It is available[1] under the terms of GPLv3 as well as it is part of the current Debian testing release[2].
Contents |
The most common usage is to replace the shell loop, for example
for x in alpha bravo charlie delta echo ; do do_something $x done
to the form of
pexec -r alpha bravo charlie delta echo -e x -o - -c \ 'do_something $x'
where the set with the 5 elements of "alpha" "bravo" "charlie" "delta" and "echo" defines the possible values for the (environmental) variable $x. The program pexec features also
Such optional features can be requested using command-line arguments. By default, pexec tries to detect the number of CPUs and uses all of them.