2015-12-30 07:55:04 +03:00
|
|
|
# GNU Parallel
|
|
|
|
|
2016-01-07 20:31:27 +03:00
|
|
|
> Run commands on multiple CPU cores.
|
2015-12-30 07:55:04 +03:00
|
|
|
|
2016-01-07 20:31:27 +03:00
|
|
|
- Gzip several files at once, using all cores:
|
2015-12-30 07:55:04 +03:00
|
|
|
|
|
|
|
`parallel gzip ::: {{file1}} {{file2}} {{file3}}`
|
|
|
|
|
2016-01-07 20:31:27 +03:00
|
|
|
- Read arguments from stdin, run 4 jobs at once:
|
2015-12-30 07:55:04 +03:00
|
|
|
|
|
|
|
`ls *.txt | parallel -j4 gzip`
|
|
|
|
|
2016-01-07 20:31:27 +03:00
|
|
|
- Convert JPG images to PNG using replacement strings:
|
2015-12-30 07:55:04 +03:00
|
|
|
|
|
|
|
`parallel convert {} {.}.png ::: *.jpg`
|
|
|
|
|
2016-01-07 20:31:27 +03:00
|
|
|
- Parallel xargs, cram as many args as possible onto one command:
|
2015-12-30 07:55:04 +03:00
|
|
|
|
|
|
|
`{{args}} | parallel -X {{command}}`
|
|
|
|
|
2016-01-07 20:31:27 +03:00
|
|
|
- Break stdin into ~1M blocks, feed each block to stdin of new command:
|
2015-12-30 07:55:04 +03:00
|
|
|
|
2016-07-22 23:24:06 +03:00
|
|
|
`cat {{big_file.txt}} | parallel --pipe --block 1M {{command}}`
|
2015-12-30 07:55:04 +03:00
|
|
|
|
2016-01-07 20:31:27 +03:00
|
|
|
- Run on multiple machines via SSH:
|
2015-12-30 07:55:04 +03:00
|
|
|
|
|
|
|
`parallel -S {{machine1}},{{machine2}} {{command}} ::: {{arg1}} {{arg2}}`
|