mirror of
https://git.savannah.gnu.org/git/parallel.git
synced 2024-11-24 23:17:55 +00:00
parallel: small optimization for --pipe
This commit is contained in:
parent
d173d70602
commit
48199a88fe
|
@ -1,3 +1,17 @@
|
||||||
|
Postkort:
|
||||||
|
- Forside kun figur
|
||||||
|
- Bagside:
|
||||||
|
- Logo med figur - evt gnu.org/s/parallel
|
||||||
|
- kort grå tekst, der forklarer hvad det er.
|
||||||
|
- Eet eksempel: parallel gzip ::: *
|
||||||
|
- Link til video. http://nd.gd/0s
|
||||||
|
|
||||||
|
GNU parallel is a UNIX-tool for running commands in parallel.
|
||||||
|
To gzip all files running one job per CPU write:
|
||||||
|
parallel gzip ::: *
|
||||||
|
Watch the intro video to learn more: http://nd.gd/0s
|
||||||
|
Or read more about GNU parallel: www.gnu.org/s/parallel
|
||||||
|
|
||||||
job->start():
|
job->start():
|
||||||
$jobslot = Global::jobslot->$sshlogin
|
$jobslot = Global::jobslot->$sshlogin
|
||||||
|
|
||||||
|
|
|
@ -158,9 +158,9 @@ cc:Peter Simons <simons@cryp.to>, Sandro Cazzaniga <kharec@mandriva.org>,
|
||||||
Christian Faulhammer <fauli@gentoo.org>, Ryoichiro Suzuki <ryoichiro.suzuki@gmail.com>,
|
Christian Faulhammer <fauli@gentoo.org>, Ryoichiro Suzuki <ryoichiro.suzuki@gmail.com>,
|
||||||
Jesse Alama <jesse.alama@gmail.com>
|
Jesse Alama <jesse.alama@gmail.com>
|
||||||
|
|
||||||
Subject: GNU Parallel 2011XXXX ('?') released
|
Subject: GNU Parallel 2011XX22 ('Pakistan') released
|
||||||
|
|
||||||
GNU Parallel 2011XXXX ('?') has been released. It is
|
GNU Parallel 2011XX22 ('Pakistan') has been released. It is
|
||||||
available for download at: http://ftp.gnu.org/gnu/parallel/
|
available for download at: http://ftp.gnu.org/gnu/parallel/
|
||||||
|
|
||||||
New in this release:
|
New in this release:
|
||||||
|
@ -173,6 +173,12 @@ New in this release:
|
||||||
* Review with idea for {..} and {...} in Japanese. Thanks to ichii386.
|
* Review with idea for {..} and {...} in Japanese. Thanks to ichii386.
|
||||||
http://d.hatena.ne.jp/ichii386/20110426
|
http://d.hatena.ne.jp/ichii386/20110426
|
||||||
|
|
||||||
|
* Upgrade GNU Parallel using Macports. Thanks to Phil Hollenback.
|
||||||
|
http://www.hollenback.net/index.php/MacportsParallel
|
||||||
|
|
||||||
|
* Robert from Echo One discusses using processes instead of threads:
|
||||||
|
http://rrees.wordpress.com/2011/04/25/many-cores-many-threads/
|
||||||
|
|
||||||
* Bug fixes and man page updates.
|
* Bug fixes and man page updates.
|
||||||
|
|
||||||
|
|
||||||
|
|
21
src/parallel
21
src/parallel
|
@ -108,12 +108,20 @@ sub spreadstdin {
|
||||||
$recerror = "parallel: Warning: --recend unmatched. Is --blocksize too small?";
|
$recerror = "parallel: Warning: --recend unmatched. Is --blocksize too small?";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($::opt_regexp) {
|
||||||
|
# If $recstart/$recend contains '|' this should only apply to the regexp
|
||||||
|
$recstart = "(?:".$recstart.")";
|
||||||
|
$recend = "(?:".$recend.")";
|
||||||
|
} else {
|
||||||
|
# $recstart/$recend = printf strings (\n)
|
||||||
|
$recstart =~ s/\\([rnt'"\\])/"qq|\\$1|"/gee;
|
||||||
|
$recend =~ s/\\([rnt'"\\])/"qq|\\$1|"/gee;
|
||||||
|
}
|
||||||
|
my $recendrecstart = $recend.$recstart;
|
||||||
|
|
||||||
while(read(STDIN,substr($buf,length $buf,0),$::opt_blocksize)) {
|
while(read(STDIN,substr($buf,length $buf,0),$::opt_blocksize)) {
|
||||||
# substr above = append to $buf
|
# substr above = append to $buf
|
||||||
if($::opt_regexp) {
|
if($::opt_regexp) {
|
||||||
# If $recstart/$recend contains '|' this should only apply to the regexp
|
|
||||||
$recstart = "(?:".$recstart.")";
|
|
||||||
$recend = "(?:".$recend.")";
|
|
||||||
if($Global::max_number_of_args) {
|
if($Global::max_number_of_args) {
|
||||||
# -N => (start..*?end){n}
|
# -N => (start..*?end){n}
|
||||||
while($buf =~ s/((?:$recstart.*?$recend){$Global::max_number_of_args})($recstart.*)$/$2/os) {
|
while($buf =~ s/((?:$recstart.*?$recend){$Global::max_number_of_args})($recstart.*)$/$2/os) {
|
||||||
|
@ -130,13 +138,10 @@ sub spreadstdin {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
# $recstart/$recend = printf strings (\n)
|
|
||||||
$recstart =~ s/\\([rnt'"\\])/"qq|\\$1|"/gee;
|
|
||||||
$recend =~ s/\\([rnt'"\\])/"qq|\\$1|"/gee;
|
|
||||||
if($Global::max_number_of_args) {
|
if($Global::max_number_of_args) {
|
||||||
# -N => (start..*?end){n}
|
# -N => (start..*?end){n}
|
||||||
my $i = 0;
|
my $i = 0;
|
||||||
while(($i = nindex(\$buf,$recend.$recstart,$Global::max_number_of_args)) != -1) {
|
while(($i = nindex(\$buf,$recendrecstart,$Global::max_number_of_args)) != -1) {
|
||||||
$i += length $recend; # find the actual splitting location
|
$i += length $recend; # find the actual splitting location
|
||||||
my $record = substr($buf,0,$i);
|
my $record = substr($buf,0,$i);
|
||||||
substr($buf,0,$i) = "";
|
substr($buf,0,$i) = "";
|
||||||
|
@ -145,7 +150,7 @@ sub spreadstdin {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
# Find the last recend-recstart in $buf
|
# Find the last recend-recstart in $buf
|
||||||
my $i = rindex($buf,$recend.$recstart);
|
my $i = rindex($buf,$recendrecstart);
|
||||||
if($i != -1) {
|
if($i != -1) {
|
||||||
$i += length $recend; # find the actual splitting location
|
$i += length $recend; # find the actual splitting location
|
||||||
my $record = substr($buf,0,$i);
|
my $record = substr($buf,0,$i);
|
||||||
|
|
|
@ -1415,6 +1415,26 @@ can be written like this:
|
||||||
B<cat list | parallel "do_something {} scale {.}.jpg ; do_step2 <{} {.}" | process_output>
|
B<cat list | parallel "do_something {} scale {.}.jpg ; do_step2 <{} {.}" | process_output>
|
||||||
|
|
||||||
|
|
||||||
|
=head1 EXAMPLE: Rewriting nested for-loops
|
||||||
|
|
||||||
|
Nested for-loops like this:
|
||||||
|
|
||||||
|
(for x in `cat xlist` ; do
|
||||||
|
for y in `cat ylist` ; do
|
||||||
|
do_something $x $y
|
||||||
|
done
|
||||||
|
done) | process_output
|
||||||
|
|
||||||
|
can be written like this:
|
||||||
|
|
||||||
|
B<cat xlist | parallel cat ylist \| parallel -I {o} do_something {} {o} | process_output>
|
||||||
|
|
||||||
|
The above will run N*N jobs in parallel if parallel normally runs N jobs. To
|
||||||
|
ensure the output order is the same as the input and only run N jobs do:
|
||||||
|
|
||||||
|
B<cat xlist | parallel -k cat ylist \| parallel -j1 -kI {o} do_something {} {o} | process_output>
|
||||||
|
|
||||||
|
|
||||||
=head1 EXAMPLE: Group output lines
|
=head1 EXAMPLE: Group output lines
|
||||||
|
|
||||||
When running jobs that output data, you often do not want the output
|
When running jobs that output data, you often do not want the output
|
||||||
|
@ -1501,8 +1521,8 @@ B<cat bigfile | parallel --pipe --block 10M grep foo>
|
||||||
=head1 EXAMPLE: Using remote computers
|
=head1 EXAMPLE: Using remote computers
|
||||||
|
|
||||||
To run commands on a remote computer SSH needs to be set up and you
|
To run commands on a remote computer SSH needs to be set up and you
|
||||||
must be able to login without entering a password (B<ssh-agent> may be
|
must be able to login without entering a password (The commands
|
||||||
handy).
|
B<ssh-copy-id> and B<ssh-agent> may help you do that).
|
||||||
|
|
||||||
To run B<echo> on B<server.example.com>:
|
To run B<echo> on B<server.example.com>:
|
||||||
|
|
||||||
|
@ -1643,6 +1663,8 @@ Print the number on the opposing sides of a six sided die:
|
||||||
|
|
||||||
B<parallel -a <(seq 6) -a <(seq 6 -1 1) echo>
|
B<parallel -a <(seq 6) -a <(seq 6 -1 1) echo>
|
||||||
|
|
||||||
|
B<parallel echo :::: <(seq 6) <(seq 6 -1 1)>
|
||||||
|
|
||||||
Convert files from all subdirs to PNG-files with consecutive numbers
|
Convert files from all subdirs to PNG-files with consecutive numbers
|
||||||
(useful for making input PNG's for B<ffmpeg>):
|
(useful for making input PNG's for B<ffmpeg>):
|
||||||
|
|
||||||
|
@ -1693,12 +1715,12 @@ job. wget is too - if the webpages are small.
|
||||||
The content of the file jobs_to_run:
|
The content of the file jobs_to_run:
|
||||||
|
|
||||||
ping -c 1 10.0.0.1
|
ping -c 1 10.0.0.1
|
||||||
wget http://status-server/status.cgi?ip=10.0.0.1
|
wget http://example.com/status.cgi?ip=10.0.0.1
|
||||||
ping -c 1 10.0.0.2
|
ping -c 1 10.0.0.2
|
||||||
wget http://status-server/status.cgi?ip=10.0.0.2
|
wget http://example.com/status.cgi?ip=10.0.0.2
|
||||||
...
|
...
|
||||||
ping -c 1 10.0.0.255
|
ping -c 1 10.0.0.255
|
||||||
wget http://status-server/status.cgi?ip=10.0.0.255
|
wget http://example.com/status.cgi?ip=10.0.0.255
|
||||||
|
|
||||||
To run 100 processes simultaneously do:
|
To run 100 processes simultaneously do:
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue