ref: 6102d74e3db07c1bcc862dcda1db9e12be6a6362
dir: /sys/man/8/qer/
.TH QER 8 .SH NAME qer, runq \- queue management for spooled files .SH SYNOPSIS .B qer [ .B -q .I subdir ] [ .B -f .I file ] .I root tag reply args .br .B runq [ .B -adER ] [ .B -f .I file ] [ .B -q .I subdir ] [ .B -t .I time ] [ .B -r .I nfiles ] [ .B -n .I njobs ] .I root cmd .SH DESCRIPTION .I Qer creates a control and a data file in a queue directory. The control file contents consist of the .IR tag , .IR reply , and .I args separated by spaces. The data file contains the standard input to .IR qer . The files are created in the directory .IR root / subdi The names of the control and data files differ only in the first character which is `C' and `D' respectively. .IR Mktemp (2) is used to create the actual names of the control and data file. .P Some commands, such as .I fax (see .IR telco (4)), must queue more files than just the data file. Each .I file following a .B \-f flag is copied into the queue directory. The names of the copies differ from the name of the data file only in the first character. The first one starts with 'F', the second 'G', etc. .P Qer takes the following arguments: .TP .B -q subdir Specifies the queue subdirectory to use. If unspecified, the contents of .B /dev/user are used. .TP .B -f file Specifies the files to copy into the queue directory, in the manner described above. .P .I Runq processes the files queued by .IR qer . .I Runq processes all requests in the directory .IR root / subdir , where .I subdir is the argument to .B -q if present, else the contents of .BR /dev/user . Each request is processed by executing the command .I cmd with the contents of the control file as its arguments, the contents of the data file as its standard input, and standard error appended to the error file .BR E.XXXXXX . .P The action taken by .I runq depends on the return status of .IR cmd . If .I cmd returns a null status, the processing is assumed successful and the control, data, and error files are removed. If .I cmd returns an error status containing the word .LR Retry , the files are left to be reprocessed at a later time. For any other status, an error message is mailed to the requester and the files are removed. .I Runq uses the .I reply field in the control file as a mail address to which to send an error notification. The notification contains the contents of the control file to identify the failed request. .P To avoid reprocessing files too often, the following algorithm is used: a data file younger than one hour will not be processed if its error file exists and was last modified within the preceding 10 minutes. A data file older than one hour will not be processed if its error file exists and was last modified within the preceding hour. .PP The following flags are accepted by runq: .TP .B -a Causes runq to process all user directories in sequence, instead of only the directory of the current user. .TP .B -E Causes all files to be reprocessed regardless of the file times. .TP .B -R Instructs .I runq never to give up on a failed queue job, instead leaving it in the queue to be retried. .TP .B -d Causes debugging output on standard error describing the progress through the queues. .TP .B -t Specifies the number of hours that retries will continue after a send failure. The default is 48 hours. .TP .BR -r Limits the number of files that are processed in a single pass of a queue. .I Runq accumulates the entire directory containing a queue before processing any files. When a queue contains many files and the system does not have enough memory, .I runq exits without making progress. This flag forces .I runq to process the directory in chunks, allowing the queue to be drained incrementally. It is most useful in combination with the .I -q flag. .TP .B -n Specifies the number of queued jobs that are processed in parallel from the queue; the default is 1. This is useful for a large queue to be processed with a bounded amount of parallelism. .PP .I Runq is often called from .IR cron (8) by an entry such as .IP .EX 0,10,20,30,40,50 * * * * kremvax /bin/upas/runq -a /mail/queue /mail/lib/remotemail .EE .LP The entry must be a single line; it is folded here only so it fits on the page. .SH FILES .TF \fIroot\fP/\fIuser\fP/[F-Z].XXXXXX .TP .B \fIroot\fP/\fIuser\fP queue directory for .I user .TP .B \fIroot\fP/\fIuser\fP/D.XXXXXX data file .TP .B \fIroot\fP/\fIuser\fP/C.XXXXXX control file .TP .B \fIroot\fP/\fIuser\fP/E.XXXXXX error file .TP .B \fIroot\fP/\fIuser\fP/[F-Z].XXXXXX secondary data files .SH SOURCE .B /sys/src/cmd/upas/q .SH "SEE ALSO" .IR mail (1)