Provided by: xjobs_20120412-1_amd64 bug

NAME

       xjobs - construct command line and execute jobs in parallel

SYNOPSIS

       xjobs [options] [utility [argument ...]]

DESCRIPTION

       xjobs  reads  job  descriptions  line by line and executes them in parallel. It limits the
       number of parallel executing jobs and starts new jobs when  jobs  finish.   Therefore,  it
       combines  the  arguments from every input line with the utility and arguments given on the
       command line. If no utility is given as an argument to xjobs, then the first  argument  on
       every  job line will be used as utility. To execute utility xjobs searches the directories
       given in the PATH environment variable and uses the first file found in these directories.

       xjobs is most useful on multiprocessor machines when one needs  to  execute  several  time
       consuming commands that could possibly be run in parallel. With xjobs this can be achieved
       easily, and it is possible to limit the load of the machine to a useful value.   It  works
       similar  to  xargs, but starts several processes simultaneously and gives only one line of
       arguments to each utility call.

       By using I/O redirectors the standard input, output, and error stream of executed jobs can
       be  redirected.  Use  <  to  redirect standard input, > to redirect standard output, >! to
       redirect standard output and overwrite an existing file, >> to append standard  output  to
       an  existing  file,  >&  to redirect both standard output and standard error output to the
       same file, and >>& to append both standard output and standard error output  to  the  same
       file.

       If  passed  on  the command line, these operators specify the default I/O redirection that
       can be overwritten by specifying another redirector to a  specific  job  on  its  argument
       line.   After  all  these  operators  a  filename  is  expected. See EXAMPLES below for an
       example.  If you  need  more  advanced  shell  features  than  the  redirection  operators
       supported by xjobs, then use as utility a shell of your preference.

       Every  job  line  can  be preceeded by a "cd directory;" command that tells xjobs in which
       directory the job shall be executed. For every line this can only be used once.  For  more
       complex scripting, please pass the line to execute to a shell of your choice.

       xjobs  constructs  the  arguments  of the jobs to execute from each input line. Each input
       line will create a  seperate  job,  whereas  newline  character  are  handled  as  regular
       whitespace  by  xargs.  To  be  able to include whitespace charakters in arguments, either
       preceed them with a backslash or quote them  with  single  or  doublequote  charakters.  A
       backslash  charakter  preceeding  a  newline will make xjobs ignore the newline character,
       thus giving you the ability to pass arguments for a single job across multiple  lines.  To
       include  quotation marks in quoted arguments, preceed them with a backslash.  Lines passed
       to xjobs beginning with a # charakter are interpreted as comments.

       Finally, xjobs also includes a mechanism for serializing the execution.  Like this  it  is
       possible  to  parallelize  independent jobs and sequence jobs that have a dependency. This
       can be achieved by inserting a line that only consists of  two  percentage  charakters  in
       sequence  (%%).   All jobs before this sequence point are executed at the requested number
       of jobs in parallel. When hitting the sequence point xjobs  waits  for  all  processes  to
       finish and then continues starting jobs that follow the sequence point.

       When  passing a named pipe (i.e. a file name created by mkfifo) via option -s as an input,
       xjobs will close and reopen the fifo when reaching end-of-file. Like this it  is  possible
       to  setup  an  xjobs  server  and  sending  jobs to this server from muliple programs. See
       section EXAMPLES below for an example.

OPTIONS

       -j <jobs>
              Sets the maximum number of jobs that are started in parallel. The default value  is
              to  limit  the number executing jobs is equal to the number of online processors in
              the system. If the number passed as <jobs> is followed by an  'x'  charakter  (e.g.
              2.5x),  the value is multiplied with the number of online processors before setting
              the job limit. I.e.  having a machine with 4 online processors and passing 2.5x  as
              an argument to option -j will yield a joblimit of 10 jobs.

       -s <script>
              Use file script instead of the standard input to read the job descriptions.

       -n     Redirect standard output and standard error output of executed jobs to /dev/null.

       -l <num>
              Combine the arguments of <num> input lines for a single job.

       -p     Start jobs interactively, prompting the user.

       -q <num>
              Limits the number of queued jobs to num elements. Normally xjobs reads in jobs from
              standard input or the give script and queues them if  they  cannot  be  started  at
              once.  With this option, xjobs will stop reading as soon as num jobs are queued and
              restart reading when a new job has been started. Like  this  xjobs  allocates  less
              memory.  Use this option, if you pass huge number of jobs to xjobs, to limit memory
              consumption. It can also increase performance of xjobs, but be sure that  jobs  get
              fed fast enough to xjobs.

       -1     Pass  one  argument  per  job,  which  is  expected  to be terminated by a new-line
              character. No argument parsing is performed. That way it is more  easy  to  process
              jobs  where  arguments  may  include  whitespace  character  or  other  tokens that
              influence argument parsing.

       -0     Same as -1, but as a job and argument termination character a  null-character  (\0)
              is  expected instead of a new-line character. That way also arguments with new-line
              character can be processed without escape sequences.

       -V     Print the version number of xjobs and exit.

       -v <level>
              Set verbosity of xjobs to level. Valid leves  are:  0=silent,  1=error,  2=warning,
              3=info, 4=debug. The default level of verbosity is 3.

EXAMPLES

       If you have a lot of .zip files that you want to extract, then use xjobs like this:

       $ ls -1 *.zip | xjobs unzip

       If you want to do the same without getting the output of each unzip task on your terminal,
       then try this:

       $ ls -1 *.zip | xjobs -n unzip

       To gzip all *.bak files in a given directory hierarchy, use it the following way:

       $ find . -name '*.bak' | xjobs gzip

       To generate index files for a set of *.jar files, you can use the redirection  feature  of
       xjobs, and do the following:

       $ ls -1 *.jar | sed 's/\(.*\)/\1 > \1.idx/' | xjobs jar tf

       If you also want to capture the error output, than use >& instead of >.

       You  can also use it to execute several different commands. Therefore, write a script file
       that contains every job you want to execute and pass it to xjobs with the option -s:

       $ cat - > script
       unzip my.zip
       tar xf my.tar
       lame --silent my.wav my.mp3
       crypt notsecret < mydata > secretfile
       ^D
       $ xjobs -s script

       To be able to queue up jobs from multiple sources with xjobs, use a named pipe and pass it
       explicitly as input script. Then write the jobs to the named pipe:
       $ mkfifo /var/run/my_named_pipe
       $ xjobs -s /var/run/my_named_pipe &
       $ echo unzip 1.zip >> /var/run/my_named_pipe
       $ echo tar cf /backup/myhome.tar /home/me >> /var/run/my_named_pipe

ENVIRONMENT VARIABLES

       PATH Determines the location of command.

AUTHORS

       Thomas Maier-Komor <thomas@maier-komor.de>
       Donations via PayPal are welcome!

HOMEPAGE

       http://www.maier-komor.de/xjobs.html

LICENSE

       GNU General Public License Version 2

SEE ALSO

       xargs(1)