910 lines
41 KiB
Groff
910 lines
41 KiB
Groff
|
.TH EXIM 8
|
||
|
.SH exim
|
||
|
exim \- Mail Transfer Agent
|
||
|
.SH SYNOPSIS
|
||
|
.B exim
|
||
|
.I "[options] arguments ..."
|
||
|
.br
|
||
|
.B mailq
|
||
|
.I "[options] arguments ..."
|
||
|
.br
|
||
|
.B rmail
|
||
|
.I "[options] arguments ..."
|
||
|
.br
|
||
|
.B rsmtp
|
||
|
.I "[options] arguments ..."
|
||
|
.br
|
||
|
.B runq
|
||
|
.I "[options] arguments ..."
|
||
|
.br
|
||
|
.B sendmail
|
||
|
.I "[options] arguments ..."
|
||
|
.SH "DESCRIPTION"
|
||
|
.B Exim
|
||
|
is a mail transport agent (MTA) developed at the University of
|
||
|
Cambridge for use on Unix systems connected to the Internet. It is
|
||
|
freely available under the terms of the GNU General Public Licence. In
|
||
|
style it is similar to Smail 3, but its facilities are more extensive,
|
||
|
and in particular it has some defences against mail bombs and
|
||
|
unsolicited junk mail, in the form of options for refusing messages
|
||
|
from particular hosts, networks, or senders.
|
||
|
.PP
|
||
|
Exim's command line takes the standard Unix form of a sequence of
|
||
|
options, each starting with a hyphen character, followed by a number
|
||
|
of arguments. The options are compatible with the main options of
|
||
|
Sendmail, and there are also some additional options, some of which
|
||
|
are compatible with Smail 3. Certain combinations of options do not
|
||
|
make sense, and provoke an error if used. The form of the arguments
|
||
|
depends on which options are set.
|
||
|
.PP
|
||
|
If Exim is called under the name mailq, it behaves as if the option
|
||
|
-bp were present before any other options. This is for compatibility
|
||
|
with some systems that contain a command of that name in one of the
|
||
|
standard libraries, symbolically linked to /usr/lib/sendmail.
|
||
|
.PP
|
||
|
If Exim is called under the name rsmtp it behaves as if the option -bS
|
||
|
were present before any other options, for compatibility with
|
||
|
smail. The -bS option is used for reading in a number of messages in
|
||
|
batched SMTP format.
|
||
|
.PP
|
||
|
If Exim is called under the name rmail it behaves as if the option -i
|
||
|
were present before any other options, for compatibility with
|
||
|
smail. The -i option is used for reading a message that should not be
|
||
|
terminated by a dot on a line by itself. The name rmail is used as an
|
||
|
interface by some UUCP systems.
|
||
|
.PP
|
||
|
If Exim is called under the name runq it behaves as if the option -q
|
||
|
were present before any other options, for compatibility with
|
||
|
smail. The -q option causes a single queue-runner process to be
|
||
|
started.
|
||
|
.SH LIMITATIONS
|
||
|
For the benefit of those reading this overview to see whether Exim is
|
||
|
of interest to them, its limitations are listed first.
|
||
|
.TP
|
||
|
.B ANSI-C
|
||
|
Exim is written in ANSI C. This should not be much of a limitation
|
||
|
these days. However, to help with systems that lack a true ANSI C
|
||
|
library, Exim avoids making any use of the value returned by the
|
||
|
sprintf() function, which is one of the main incompatibilities. It has
|
||
|
its own version of strerror() for use with SunOS4 and any other system
|
||
|
that lacks this function, and a macro can be defined to turn memmove()
|
||
|
into bcopy() if necessary.
|
||
|
.TP
|
||
|
.B Filenames
|
||
|
Exim uses file names that are longer than 14 characters.
|
||
|
.TP
|
||
|
.B Bangpaths
|
||
|
Exim is intended for use as an Internet mailer, and therefore handles
|
||
|
addresses in RFC 822 domain format only. It cannot handle 'bang
|
||
|
paths', though simple two-component bang paths can be converted by a
|
||
|
straightforward rewriting configuration.
|
||
|
.TP
|
||
|
.B Domains required
|
||
|
Exim insists that every address it handles has a domain attached. For
|
||
|
incoming local messages, domainless addresses are automatically
|
||
|
qualified with a configured domain value. Configuration options
|
||
|
specify from which remote systems unqualified addresses are
|
||
|
acceptable.
|
||
|
.TP
|
||
|
.B Transports
|
||
|
The only external transport currently implemented is an SMTP transport
|
||
|
over a TCP/IP network (using sockets), suitable for machines on the
|
||
|
Internet. However, a pipe transport is available, and there are
|
||
|
facilities for writing messages to files in 'batched SMTP' format;
|
||
|
this can be used to send messages to some other transport
|
||
|
mechanism. Batched SMTP input is also catered for.
|
||
|
.SH FEATURES
|
||
|
Exim follows the same general approach of decentralized control that
|
||
|
Smail 3 does. There is no central process doing overall management of
|
||
|
mail delivery. However, unlike Smail, the independent delivery
|
||
|
processes share data in the form of 'hints', which makes delivery more
|
||
|
efficient in some cases. The hints are kept in a number of DBM
|
||
|
files. If any of these files are lost, the only effect is to change
|
||
|
the pattern of delivery attempts and retries.
|
||
|
.PP
|
||
|
Many configuration options can be given as expansion strings, and as
|
||
|
these can include file lookups, much of Exim's operation can be made
|
||
|
table-driven if desired. For example, it is possible to do local
|
||
|
delivery on a machine on which the users do not have accounts.
|
||
|
.PP
|
||
|
Regular expressions are available in a number of configuration
|
||
|
parameters.
|
||
|
.PP
|
||
|
Domain lists can include file lookups, making it possible to support a
|
||
|
large number of local domains.
|
||
|
.PP
|
||
|
Exim has flexible retry algorithms, applicable to mail routing as well as
|
||
|
to delivery.
|
||
|
.PP
|
||
|
Exim contains header and envelope rewriting facilities.
|
||
|
.PP
|
||
|
Unqualified addresses are accepted only from specified hosts or networks.
|
||
|
.PP
|
||
|
Exim can perform multiple deliveries down the same SMTP channel after
|
||
|
deliveries to a host have been delayed.
|
||
|
.PP
|
||
|
Exim can be configured to do local deliveries immediately but to leave
|
||
|
remote deliveries until the message is picked up by a queue-runner
|
||
|
process. This increases the likelihood of multiple messages being sent
|
||
|
down a single SMTP connection.
|
||
|
.PP
|
||
|
When copies of a message have to be delivered to more than one remote
|
||
|
host, up to a configured maximum number of remote deliveries can be
|
||
|
done in parallel.
|
||
|
.PP
|
||
|
Exim supports optional checking of incoming return path (sender) and
|
||
|
receiver addresses as they are received by SMTP.
|
||
|
.PP
|
||
|
SMTP calls from specific machines, optionally from specific idents,
|
||
|
can be locked out, and incoming SMTP messages from specific senders
|
||
|
can also be locked out.
|
||
|
.PP
|
||
|
It is possible to control which hosts may use the Exim host as a relay
|
||
|
for onward transmission of mail; the control can be made to depend on
|
||
|
the address domain.
|
||
|
.PP
|
||
|
Messages on the queue can be 'frozen' and 'thawed' by the
|
||
|
administrator.
|
||
|
.PP
|
||
|
The maximum size of message can be specified. Exim can handle a
|
||
|
number of independent local domains on the same machine; each domain
|
||
|
can have its own alias files, etc. These are commonly called "virtual
|
||
|
domains".
|
||
|
.PP
|
||
|
Exim stats a user's home directory before looking for a .forward file,
|
||
|
in order to detect the case of a missing NFS mount.
|
||
|
.PP
|
||
|
Exim contains an optional built-in mail filtering facility. This
|
||
|
enables users to set up their own mail filtering in a straightfoward
|
||
|
manner without the need to run an external program. There can also be
|
||
|
a system filter file that applies to all messages.
|
||
|
.PP
|
||
|
There is support for multiple user mailboxes controlled by prefixes or
|
||
|
suffixes on the user name, either via the filter mechanism or through
|
||
|
multiple .forward files.
|
||
|
.PP
|
||
|
Periodic warnings are automatically sent to messages' senders when
|
||
|
delivery is delayed - the time between warnings is configurable.
|
||
|
.PP
|
||
|
A queue run can be manually started to deliver just a particular
|
||
|
portion of the queue, or those messages with a recipient whose address
|
||
|
contains a given string.
|
||
|
.PP
|
||
|
Exim can be configured to run as root all the time, except when
|
||
|
performing local deliveries, which it always does in a separate
|
||
|
process under an appropriate uid and gid. Alternatively, it can be
|
||
|
configured to run as root only when needed; in particular, it need not
|
||
|
run as root when receiving incoming messages or when sending out
|
||
|
messages over SMTP.
|
||
|
.PP
|
||
|
I have tried to make the wording of delivery failure messages clearer
|
||
|
and simpler, for the benefit of those less-experienced people who are
|
||
|
now using email.
|
||
|
.PP
|
||
|
The Exim Monitor is an optional extra; it displays information about
|
||
|
Exim's processing in an X window, and an administrator can perform a
|
||
|
number of control actions from the window interface.
|
||
|
.SH METHOD OF OPERATION
|
||
|
When Exim receives a message, it writes two files in its spool
|
||
|
directory. The first contains the envelope information, the current
|
||
|
status of the message, and the headers, while the second contains the
|
||
|
body of the message. The status of the message includes a complete
|
||
|
list of recipients and a list of those that have already received the
|
||
|
message. The header file gets updated during the course of delivery if
|
||
|
necessary.
|
||
|
.PP
|
||
|
A message remains in the spool directory until it is completely
|
||
|
delivered to its recipients or to an error address, or until it is
|
||
|
deleted by an administrator or by the user who originally created
|
||
|
it. In cases when delivery cannot proceed - for example, when a
|
||
|
message can neither be delivered to its recipients nor returned to its
|
||
|
sender, the message is marked 'frozen' on the spool, and no more
|
||
|
deliveries are attempted. The administrator can thaw such messages
|
||
|
when the problem has been corrected, and can also freeze individual
|
||
|
messages by hand if necessary.
|
||
|
.PP
|
||
|
As delivery proceeds, Exim writes timestamped information about each
|
||
|
address to a per-message log file; this includes any delivery error
|
||
|
messages. This log is solely for the benefit of the administrator. All
|
||
|
the information Exim itself needs for delivery is kept in the header
|
||
|
spool file. The message log file is deleted with the spool files. If a
|
||
|
message is delayed for more than a configured time, a warning message
|
||
|
is sent to the sender. This is repeated whenever the same time elapses
|
||
|
again without delivery being complete.
|
||
|
.PP
|
||
|
The main delivery processing elements of Exim are called directors,
|
||
|
routers, and transports. Code for a number of these is provided, and
|
||
|
compile-time options specify which ones are actually included in the
|
||
|
binary. Directors handle addresses that include one of the local
|
||
|
domains, routers handle remote addresses, and transports do actual
|
||
|
deliveries.
|
||
|
.SH TRUSTED AND ADMIN USERS
|
||
|
Some Exim options are available only to "trusted users" and others are
|
||
|
available only to "admin users".
|
||
|
.PP
|
||
|
A trusted user is root or the Exim user (if defined) or any user
|
||
|
listed in the trusted_users configuration option, or any user, if the
|
||
|
currently set group is one of those listed in the trusted_groups
|
||
|
configuration option. Trusted users are permitted to use the -f option
|
||
|
to specify the senders of messages that are passed to Exim through the
|
||
|
local interface, and also to specify host names, host addresses,
|
||
|
protocol names, and ident values. Thus they are able to insert
|
||
|
messages into Exim's queue locally that have the characteristics of
|
||
|
messages received from a remote host.
|
||
|
.PP
|
||
|
An admin user is root or the Exim user (if defined) or any user that
|
||
|
is a member of the Exim group (if defined). The current group does not
|
||
|
have to be the Exim group. Admin users are permitted to operate on
|
||
|
messages in the queue, for example, to force delivery failures. It is
|
||
|
also necessary to be an admin user in order to see the full
|
||
|
information provided by the Exim monitor.
|
||
|
.SH OPTIONS
|
||
|
Exim's command options are as follows:
|
||
|
.TP
|
||
|
.B -bd
|
||
|
Run Exim as a daemon, awaiting incoming SMTP connections. This option
|
||
|
can be used only by an admin user. If either of the -d or -dm options
|
||
|
are set, the daemon does not disconnect from the controlling
|
||
|
terminal. By default, Exim listens for incoming connections on all the
|
||
|
host's interfaces, but it can be restricted to specific interfaces by
|
||
|
setting the local_interfaces option in the configuration file. The
|
||
|
standard SMTP port is used, but this can be varied by means of the -oX
|
||
|
option. Most commonly, the -bd option is combined with the -q<time>
|
||
|
option, to cause periodic queue runs to happen as well.
|
||
|
|
||
|
The process id of a daemon that is both listening and starting queue
|
||
|
runners is written to a file called exim-daemon.pid in Exim's spool
|
||
|
directory, unless the -oX option is used, in which case the file
|
||
|
name is exim-daemon.<port-number>.pid. If a daemon is run with only
|
||
|
one of -bd and -q<time>, then that option is added on to the end of
|
||
|
the file name, allowing sites that run two separate daemons to
|
||
|
distinguish them.
|
||
|
|
||
|
It is possible to change the directory in which these pid files are
|
||
|
written by changing the setting of PID_FILE_PATH in Local/Makefile.
|
||
|
Further details are given in the comments in src/EDITME.
|
||
|
|
||
|
The SIGHUP signal can be used to cause the daemon to re-exec itself.
|
||
|
This should be done whenever Exim's configuration file is changed,
|
||
|
or a new version of Exim is installed. It is not necessary to do
|
||
|
this when other files (e.g. alias files) are changed.
|
||
|
.TP
|
||
|
.B -bf <filename>
|
||
|
Run Exim in filter testing mode; the file is the filter file to be
|
||
|
tested, and a test message must be supplied on the standard input.
|
||
|
If there are no message-dependent tests in the filter, an empty file
|
||
|
can be supplied. If the test file does not begin with the special
|
||
|
line
|
||
|
|
||
|
# Exim filter
|
||
|
|
||
|
then it is taken to be a normal .forward file, and is tested for
|
||
|
validity under that interpretation. The result of this command,
|
||
|
provided no errors are detected, is a list of the actions that Exim
|
||
|
would try to take if presented with the message for real. More
|
||
|
details of filter testing are given in the separate document
|
||
|
entitled "Exim's User interface to mail filtering".
|
||
|
|
||
|
When testing a filter file, various parameters that would normally
|
||
|
be taken from the envelope recipient address of a message can be set
|
||
|
by means of additional command line options. These are:
|
||
|
|
||
|
-bfd <domain> default is the qualify domain
|
||
|
-bfl <local_part>default is the logged in user
|
||
|
-bfp <local_part_prefix> default is null
|
||
|
-bfs <local_part_suffix> default is null
|
||
|
|
||
|
The local part should always be set to the incoming address with any
|
||
|
prefix or suffix stripped, because that is how it appears when a
|
||
|
message is actually being delivered.
|
||
|
.TP
|
||
|
.B -bi
|
||
|
Sendmail interprets the -bi option as a request to rebuild its alias
|
||
|
file. Exim does not have the concept of a single alias file, and so
|
||
|
it cannot mimic this behaviour. However, calls to /usr/lib/sendmail
|
||
|
-bi tend to appear in various scripts such as NIS make files, so the
|
||
|
option must be recognized.
|
||
|
|
||
|
If -bi is encountered, the command specified by the bi_command
|
||
|
configuration option is run, under the uid and gid of the caller of
|
||
|
Exim. If the -oA option is used, its value is passed to the command
|
||
|
as an argument. The command set by bi_command may not contain
|
||
|
arguments. The command can use the exim_dbmbuild utility, or some
|
||
|
other means, to rebuild alias files if this is required. If the
|
||
|
bi_command option is not set, then calling Exim with -bi is a no-op.
|
||
|
.TP
|
||
|
.B -bm
|
||
|
Accept an incoming, locally-generated message on the current input,
|
||
|
and deliver it to the addresses given as the command arguments
|
||
|
(except when -t is also given - see below). Each argument can be a
|
||
|
comma-separated list of RFC 822 addresses. This is the default
|
||
|
option, and is assumed if no other conflicting option is present.
|
||
|
The message may or may not be delivered immediately, depending on
|
||
|
the setting of the -od option and the queue_only and queue_smtp
|
||
|
configuration options.
|
||
|
|
||
|
The format of the message must be as defined in RFC 822, except
|
||
|
that, for compatibility with sendmail and smail, a line of the form
|
||
|
|
||
|
From sender Fri Jan 5 12:55 GMT 1996
|
||
|
|
||
|
is permitted to appear at the start of the message. The Solaris 2
|
||
|
version of the "mail" command inserts such a line, though there is
|
||
|
no mention of it in the sendmail man page. The sender specified in
|
||
|
this line is treated as if it were given as the argument to the -f
|
||
|
option.
|
||
|
.TP
|
||
|
.B -bp
|
||
|
List the contents of the mail queue on the current output. Each
|
||
|
message on the queue is displayed as in the following example:
|
||
|
|
||
|
25m 2.9K 0t5C6f-0000c8-00 <alice@wonderland.fict.book>
|
||
|
red.king@looking-glass.fict.book
|
||
|
<other addresses>
|
||
|
|
||
|
The first line contains the amount of time the message has been on
|
||
|
the queue (in this case 25 minutes), the size of the message (2.9K),
|
||
|
the unique identifier for the message, and the message sender, as
|
||
|
contained in the envelope. If the message is a delivery error
|
||
|
message, the sender address is empty, and appears as <>. If the
|
||
|
message is frozen (attempts to deliver it are suspended) then the
|
||
|
text '*** frozen ***' is displayed at the end of this line.
|
||
|
|
||
|
The recipients of the message (taken from the envelope, not the
|
||
|
headers) are displayed on subsequent lines. Those addresses to which
|
||
|
the message has already been delivered are marked with the letter D.
|
||
|
If an original address gets expanded into several addresses via an
|
||
|
alias or forward file, the original is displayed with a 'D' when
|
||
|
deliveries for all of its child addresses are completed.
|
||
|
.TP
|
||
|
.B -bP
|
||
|
If this option is given with no arguments, it causes the values of
|
||
|
all Exim's main configuration options to be written to the standard
|
||
|
output. The values of one or more specific options can be requested
|
||
|
by giving their names as arguments, for example:
|
||
|
|
||
|
exim -bP qualify_domain local_domains
|
||
|
|
||
|
If configure_file is given, the name of the runtime configuration
|
||
|
file is output. If log_file_path or pid_file_path are given, the
|
||
|
names of the directories where log files and daemon pid files are
|
||
|
written are output, respectively. If these values are unset, log
|
||
|
files are written in a subdirectory of the spool directory called
|
||
|
log, and pid files are written directly into the spool directory.
|
||
|
|
||
|
If one of the words director, router, or transport is given,
|
||
|
followed by the name of an appropriate driver instance, the option
|
||
|
settings for that driver are output. For example:
|
||
|
|
||
|
exim -bP transport local_delivery
|
||
|
|
||
|
The generic driver options are output first, followed by the
|
||
|
driver's private options. A list of the names of drivers of a
|
||
|
particular type can be obtained by using one of the words
|
||
|
director_list, router_list, or transport_list, and a complete list
|
||
|
of all drivers with their option settings can be obtained by using
|
||
|
directors, routers, or drivers.
|
||
|
.TP
|
||
|
.B -brt
|
||
|
This option is for testing retry rules, and it must be followed by
|
||
|
up to three arguments. It causes Exim to look for a retry rule that
|
||
|
matches the values and to output it on the standard output. For
|
||
|
example:
|
||
|
|
||
|
exim -brt bach.comp.mus
|
||
|
Retry rule: *.comp.mus F,2h,15m; FG,4d,30m;
|
||
|
|
||
|
See chapter 30 for a description of Exim's retry rules. The first
|
||
|
argument, which is required, can be a complete address in the form
|
||
|
local_part@domain, or it can be just a domain name. The second
|
||
|
argument is an optional second domain name; if no retry rule is
|
||
|
found for the first argument, the second is tried. This ties in with
|
||
|
Exim's behaviour when looking for retry rules for remote hosts - if
|
||
|
no rule is found that matches the host, one that matches the mail
|
||
|
domain is sought. The final argument is the name of a specific
|
||
|
delivery error, as used in setting up retry rules, for example
|
||
|
'quota_3d'.
|
||
|
.TP
|
||
|
.B -brw
|
||
|
This option is for testing address rewriting rules, and it must be
|
||
|
followed by a single argument, consisting of either a local part
|
||
|
without a domain, or a complete address with a fully-qualified
|
||
|
domain. Exim outputs how this address would be rewritten for each
|
||
|
possible place it might appear.
|
||
|
.TP
|
||
|
.B -bS
|
||
|
This option is used for batched SMTP input, where messages have been
|
||
|
received from some external source by an alternative transport
|
||
|
mechanism. It causes Exim to accept one or more messages by reading
|
||
|
SMTP on the standard input, but to generate no responses. All errors
|
||
|
are reported by sending mail. If the caller is trusted, then the
|
||
|
senders in the MAIL FROM commands are believed; otherwise the sender
|
||
|
is always the caller of Exim. Unqualified senders and receivers are
|
||
|
not rejected (there seems little point) but instead just get
|
||
|
qualified. Receiver verification and administrative rejection is not
|
||
|
done, even if configured. HELO and EHLO act as RSET; VRFY, EXPN, ETRN,
|
||
|
HELP, and DEBUG act as NOOP; QUIT quits.
|
||
|
.TP
|
||
|
.B -bs
|
||
|
This option causes Exim to accept one or more messages by reading SMTP
|
||
|
commands on the standard input, and producing SMTP replies on the
|
||
|
standard output. Some user agents use this interface as a way of
|
||
|
passing locally-generated messages to the MTA. The option can also be
|
||
|
used to run Exim from inetd, as an alternative to using a listening
|
||
|
daemon, in which case the standard input is the connected socket. Exim
|
||
|
distinguishes between the two cases by attempting to read the IP
|
||
|
address of the peer connected to the standard input. If it is not a
|
||
|
socket, the call to getpeername() fails, and Exim assumes it is
|
||
|
dealing with a local message.
|
||
|
|
||
|
If the caller of Exim is trusted, then the senders of messages are
|
||
|
taken from the SMTP MAIL FROM commands. Otherwise the content of these
|
||
|
commands is ignored and the sender is set up as the calling user.
|
||
|
.TP
|
||
|
.B -bt
|
||
|
Run in address testing mode, in which each argument is taken as an
|
||
|
address to be tested. The results are written to the standard
|
||
|
output. If no arguments are given, Exim runs in an interactive manner,
|
||
|
prompting with > for addresses to be tested. Each address is handled
|
||
|
as if it were the recipient address on a message and passed to the
|
||
|
appropriate directors or routers.
|
||
|
.TP
|
||
|
.B -bV
|
||
|
Write the current version number, compilation number, and compi-
|
||
|
lation date of the exim binary to the standard output.
|
||
|
.TP
|
||
|
.B -bv
|
||
|
Verify the addresses that are given as the arguments to the command,
|
||
|
and write the results to the standard output. Verification differs
|
||
|
from address testing (the -bt option) in that directors and routers
|
||
|
that have no_verify set are skipped, and if the address is accepted by
|
||
|
a director or router that has fail_verify set, verification
|
||
|
fails. This is the same logic that is used when verifying addresses on
|
||
|
incoming messages (see the sender_verify and receiver_verify options).
|
||
|
|
||
|
If the -v (or -d) option is not set, the output consists of a single
|
||
|
line for each address, stating whether it was verified or not, and
|
||
|
giving a reason in the latter case. Otherwise, more details are given
|
||
|
of how the address has been handled, and in the case of aliases or
|
||
|
forwarding, the generated addresses are also considered.
|
||
|
.TP
|
||
|
.B -C <filename>
|
||
|
Read the runtime configuration from the given file instead of from
|
||
|
the default file specified by the CONFIGURE_FILE compile-time set-
|
||
|
ting. When this option is used by an unprivileged caller, Exim gives
|
||
|
up its root privilege immediately, and runs with the real and
|
||
|
effective uid and gid set to those of the caller, to avoid any
|
||
|
security exposure. It does not do this if the caller is root or the
|
||
|
exim user. The facility is useful for ensuring that configuration
|
||
|
files are syntactically correct, but cannot be used for test
|
||
|
deliveries, unless the caller is privileged, or unless it's an
|
||
|
exotic configuration that does not require privilege. No check is
|
||
|
made on the owner or group of the file specified by this option.
|
||
|
.TP
|
||
|
.B -d<number>
|
||
|
Sets a debug level, causing debugging information to be written to the
|
||
|
standard error file. Whitespace between -d and the number is
|
||
|
optional. If no number is given, 1 is assumed, and the higher the
|
||
|
number, the more output is produced. A value of zero turns debugging
|
||
|
output off. A value of 9 gives the maximum amount of general
|
||
|
information, 10 gives in addition details of the interpretation of
|
||
|
filter files, and 11 or higher also turns on the debugging option for
|
||
|
DNS lookups.
|
||
|
.TP
|
||
|
.B -df
|
||
|
If this option is set and STDERR_FILE was defined when Exim was built,
|
||
|
debugging information is written to the file defined by that variable
|
||
|
instead of to the standard error file. This option provides a way of
|
||
|
obtaining debugging information when Exim is run from inetd.
|
||
|
.TP
|
||
|
.B -dm
|
||
|
This option causes information about memory allocation and freeing
|
||
|
operations to be written to the standard error file.
|
||
|
.TP
|
||
|
.B -E
|
||
|
This option specifies that an incoming message is a locally-generated
|
||
|
delivery failure message. It is used internally by Exim when handling
|
||
|
delivery failures and is not intended for external use. Its only
|
||
|
effect is to stop Exim generating certain messages to the mailmaster,
|
||
|
as otherwise message cascades could occur in some situations. As part
|
||
|
of the same option, a message id may follow the characters -E. If it
|
||
|
does, the log entry for the receipt of the new message contains the
|
||
|
id, following 'R=', as a cross reference.
|
||
|
.TP
|
||
|
.B -ex
|
||
|
There are a number of sendmail options starting with -oe which seem to
|
||
|
be called by various programs without the leading o in the option. For
|
||
|
example, the vacation program uses -eq. Exim treats all options of the
|
||
|
form -ex as synonymous with the corresponding -oex options.
|
||
|
.TP
|
||
|
.B -F <string>
|
||
|
Set the sender's full name for use when a locally-generated message
|
||
|
is being accepted. In the absence of this option, the user's "gecos"
|
||
|
entry from the password file is used. As users are generally
|
||
|
permitted to alter their "gecos" entries, no security considerations
|
||
|
are involved. White space between -F and the <string> is optional.
|
||
|
.TP
|
||
|
.B -f <address>
|
||
|
Set the address of the sender of a locally-generated message. This
|
||
|
option can normally be used only by root or the Exim user or by one
|
||
|
of the configured trusted users. In other cases, the sender of a
|
||
|
local message is always set up as the user who ran the exim command,
|
||
|
and -f is ignored, with one exception. If the special setting -f <>
|
||
|
is used by an untrusted user, it does not affect the sender for the
|
||
|
purposes of managing the Sender: and From: headers, but it does have
|
||
|
the effect of causing any SMTP transmissions to be sent out with
|
||
|
|
||
|
MAIL FROM: <>
|
||
|
|
||
|
and local deliveries to contain
|
||
|
|
||
|
Return-path: <>
|
||
|
|
||
|
when configured to contain Return-path: headers. The filtering code
|
||
|
treats such a message as an error message, and won't generate
|
||
|
messages as a result of reading it.
|
||
|
|
||
|
White space between -f and the <string> is optional. The sender of a
|
||
|
locally-generated message can also be set by an initial 'From' line
|
||
|
in the message - see the description of -bm above.
|
||
|
.TP
|
||
|
.B -h <number>
|
||
|
This option is accepted for compatibility with sendmail, but at
|
||
|
present has no effect. (In sendmail it overrides the 'hop count'
|
||
|
obtained by counting Received headers.)
|
||
|
.TP
|
||
|
.B -i
|
||
|
This option, which has the same effect as -oi, specifies that a dot
|
||
|
on a line by itself should not terminate an incoming, non-SMTP
|
||
|
message. I can find no documentation for this option in Solaris 2.4
|
||
|
sendmail, but the mailx command in Solaris 2.4 uses it.
|
||
|
.TP
|
||
|
.B -M
|
||
|
The arguments are interpreted as a list of message ids, and Exim runs
|
||
|
a delivery attempt on each message in turn. Retry hints for any of the
|
||
|
addresses are overridden - this option forces Exim to try to deliver
|
||
|
even if the normal retry time has not yet been reached. If any of the
|
||
|
messages is frozen, it is automatically thawed before the delivery
|
||
|
attempt, provided that the caller is an admin user.
|
||
|
.TP
|
||
|
.B -Mar <message-id> <address> <address> ...
|
||
|
The first argument must be a message id, and the remaining ones must
|
||
|
be email addresses. Exim adds the addresses to the list of recipi-
|
||
|
ents of the message. However, if the message is active (in the middle
|
||
|
of a delivery attempt), its status is not altered. This option can be
|
||
|
used only by an admin user.
|
||
|
.TP
|
||
|
.B -Meb <message-id>
|
||
|
This runs, under /bin/sh, the command defined in the shell variable
|
||
|
VISUAL or, if that is not defined, EDITOR or, if that is not defined,
|
||
|
the command vi, on a copy of the spool file containing the body of
|
||
|
message (eb = Edit Body). If the editor exits normally, then the
|
||
|
result of editing replaces the spool file. The message is locked
|
||
|
during this process, so no delivery attempts can occur. Note that the
|
||
|
first line of the spool file is its own name; care should be taken not
|
||
|
to disturb this. The thinking behind providing this feature is that an
|
||
|
administrator who has had to mess around with the addresses to get a
|
||
|
message delivered might want to add some (grumbly) comment at the
|
||
|
start of the message text. This option can be used only by an admin
|
||
|
user.
|
||
|
.TP
|
||
|
.B -Mes <message-id> <address>
|
||
|
There must be exactly two arguments. The first argument must be a
|
||
|
message id, and the second one an email address. Exim changes the
|
||
|
sender address in the message to the given address, which must be a
|
||
|
fully qualified address, or '<>'. However, if the message is active
|
||
|
(in the middle of a delivery attempt), its status is not altered.
|
||
|
This option can be used only by an admin user.
|
||
|
.TP
|
||
|
.B -Mmad <message-id>
|
||
|
Exim marks the all recipient addresses in the message as already
|
||
|
delivered. However, if the message is active (in the middle of a
|
||
|
delivery attempt), its status is not altered. This option can be used
|
||
|
only by an admin user.
|
||
|
.TP
|
||
|
.B -Mmd <message-id> <address> <address> ...
|
||
|
The first argument must be a message id, and the remaining ones must
|
||
|
be email addresses. Exim marks the given addresses as already
|
||
|
delivered. However, if the message is active (in the middle of a
|
||
|
delivery attempt), its status is not altered. This option can be used
|
||
|
only by an admin user.
|
||
|
.TP
|
||
|
.B -MC <transport> <hostname> <sequence number> <message id>
|
||
|
This option is not intended for use by outside callers. It is used
|
||
|
internally by Exim to invoke another instance of itself to deliver a
|
||
|
waiting message using an existing SMTP channel, which is passed as the
|
||
|
standard input and output. Details are given in chapter 43. This must
|
||
|
be the final option, and the caller must be root or the Exim user in
|
||
|
order to use it.
|
||
|
.TP
|
||
|
.B -Mc
|
||
|
The arguments are interpreted as a list of message ids, and Exim runs
|
||
|
a delivery attempt on each message in turn, but unlike the -M option,
|
||
|
it does check for retry hints, and respects any that are found. This
|
||
|
option is not very useful to external callers (except for testing). It
|
||
|
is provided for internal use by Exim when it needs to re-invoke itself
|
||
|
in order to regain root privilege for a delivery (see chapter 44).
|
||
|
.TP
|
||
|
.B -Mf
|
||
|
The arguments are interpreted as a list of message ids, and each
|
||
|
message is marked 'frozen'. This prevents any delivery attempts taking
|
||
|
place until the message is 'thawed', either manually or as a result of
|
||
|
the auto_thaw configuration option. However, if any of the messages is
|
||
|
active (in the middle of a delivery attempt), its status is not
|
||
|
altered. This option can be used only by an admin user.
|
||
|
.TP
|
||
|
.B -Mg
|
||
|
The arguments are interpreted as a list of message ids, and Exim gives
|
||
|
up trying to deliver those messages. A delivery error message is sent,
|
||
|
containing the text 'cancelled by administrator'. However, if any of
|
||
|
the messages is active, its status is not altered. This option can be
|
||
|
used only by an admin user.
|
||
|
.TP
|
||
|
.B -Mt
|
||
|
The arguments are interpreted as a list of message ids, and each
|
||
|
message that was 'frozen' is now 'thawed', so that delivery attempts
|
||
|
can resume. However, if any of the messages is active, its status is
|
||
|
not altered. This option can be used only by an admin user.
|
||
|
.TP
|
||
|
.B -Mrm
|
||
|
The arguments are interpreted as a list of message ids, and each
|
||
|
message is completely removed from Exim's queue, and forgotten.
|
||
|
However, if any of the messages is active, its status is not
|
||
|
altered. This option can be used only by an admin user or by the user
|
||
|
who originally caused the message to be placed on the queue.
|
||
|
.TP
|
||
|
.B -m
|
||
|
This is apparently a synonym for -om that is accepted by sendmail, so
|
||
|
Exim treats it that way too.
|
||
|
.TP
|
||
|
.B -N
|
||
|
This is a debugging option that inhibits delivery of a message at the
|
||
|
transport level. It implies at least -d1. Exim goes through many of
|
||
|
the motions of delivery - it just doesn't actually transport the
|
||
|
message, but instead behaves as if it had successfully done so. The
|
||
|
log, for example, will contain entries as if the message had been
|
||
|
delivered. Only root or the exim user are allowed to use -N with -bd,
|
||
|
-q, or -M. In other words, an ordinary user can use it only when
|
||
|
supplying an incoming message.
|
||
|
.TP
|
||
|
.B -oA <file name>
|
||
|
This option is used by Sendmail in conjunction with -bi to specify an
|
||
|
alternative alias file name. Exim handles -bi differently; see the
|
||
|
description above.
|
||
|
.TP
|
||
|
.B -oB <n>
|
||
|
This is a debugging option which limits the maximum number of SMTP
|
||
|
deliveries down one channel to <n>, overriding the value set in the
|
||
|
smtp transport. If <n> is omitted, the limit is set to 1 (no
|
||
|
batching).
|
||
|
.TP
|
||
|
.B -odb
|
||
|
This option applies to all modes in which Exim accepts incoming
|
||
|
messages, including the listening daemon. It requests 'background'
|
||
|
delivery of such messages, which means that the accepting process
|
||
|
automatically starts another delivery process for each message
|
||
|
received. Exim does not wait for such processes to complete (it can
|
||
|
take some time to perform SMTP deliveries). This is the default action
|
||
|
if none of the -od options are present.
|
||
|
.TP
|
||
|
.B -odf
|
||
|
This option (compatible with smail) requests 'foreground' (syn-
|
||
|
chronous) delivery when Exim has accepted a locally-generated mess-
|
||
|
age. For the daemon it is exactly the same as -odb. For a single
|
||
|
message received on the standard input, if the protection regime
|
||
|
permits it (see chapter 44), Exim converts the reception process into
|
||
|
a delivery process. In other cases, it creates a new delivery process,
|
||
|
and then waits for it to complete before proceeding.
|
||
|
.TP
|
||
|
.B -odi
|
||
|
This option is synonymous with -odf. It is provided for compati-
|
||
|
bility with sendmail.
|
||
|
.TP
|
||
|
.B -odq
|
||
|
This option applies to all modes in which Exim accepts incoming
|
||
|
messages, including the listening daemon. It specifies that the
|
||
|
accepting process should not automatically start a delivery attempt
|
||
|
for each message received. Messages are placed on the queue, and
|
||
|
remain there until a subsequent queue-running process encounters
|
||
|
them. The queue_only configuration option has the same effect.
|
||
|
.TP
|
||
|
.B -odqr
|
||
|
This option applies to all modes in which Exim accepts incoming
|
||
|
messages, including the listening daemon. It causes Exim to process
|
||
|
local addresses when a message is received, but not even to try
|
||
|
routing remote addresses. Contrast with -odqs below, which does the
|
||
|
routing, but not the delivery. The remote addresses will be picked up
|
||
|
by the next queue runner. The queue_remote configuration option has
|
||
|
the same effect.
|
||
|
.TP
|
||
|
.B -odqs
|
||
|
This option is a hybrid between -odb and -odq. A delivery process is
|
||
|
started for each incoming message, the addresses are all processed,
|
||
|
and local deliveries are done in the normal way. However, if any SMTP
|
||
|
deliveries are required, they are not done at this time. Such messages
|
||
|
remain on the queue until a subsequent queue-running process
|
||
|
encounters them. Because routing was done, Exim knows which messages
|
||
|
are waiting for which hosts, and so a number of messages for the same
|
||
|
host will get sent in a single SMTP connection. The queue_smtp
|
||
|
configuration option has the same effect.
|
||
|
.TP
|
||
|
.B -oem
|
||
|
If an error is detected while a non-SMTP message is being received
|
||
|
(e.g. a malformed address), the error is reported to the sender in a
|
||
|
mail message. This is the default option. After a message has been
|
||
|
successfully received, any subsequent delivery errors are always
|
||
|
reported in this way.
|
||
|
.TP
|
||
|
.B -oep
|
||
|
If an error is detected while a non-SMTP message is being received,
|
||
|
the error is reported by writing a message to the standard error file
|
||
|
(stderr).
|
||
|
.TP
|
||
|
.B -oeq
|
||
|
This option is supported for compatibility with sendmail, but has the
|
||
|
same effect as -oep.
|
||
|
.TP
|
||
|
.B -oew
|
||
|
This option is supported for compatibility with sendmail, but has the
|
||
|
same effect as -oem.
|
||
|
.TP
|
||
|
.B -oi
|
||
|
This option, which has the same effect as -i, specifies that a dot on
|
||
|
a line by itself should not terminate an incoming, non-SMTP message.
|
||
|
.TP
|
||
|
.B -oMa <host address>
|
||
|
This option sets the sender host address value, and can be used only
|
||
|
by a trusted caller. The value is used in log entries and can appear
|
||
|
in Received headers. The option is intended for use when handing to
|
||
|
Exim messages received by other means.
|
||
|
.TP
|
||
|
.B -oMr <protocol name>
|
||
|
This option sets the received protocol value, and can be used only by
|
||
|
a trusted caller. The value is used in log entries and can appear in
|
||
|
Received headers. The option is intended for use when handing to Exim
|
||
|
messages received by other means.
|
||
|
.TP
|
||
|
.B -oMs <host name>
|
||
|
This option sets the sender host name value, and can be used only by a
|
||
|
trusted caller. The value is used in log entries and can appear in
|
||
|
Received headers. The option is intended for use when handing to Exim
|
||
|
messages received by other means.
|
||
|
.TP
|
||
|
.B -oMt <ident string>
|
||
|
This option sets the sender ident value, and can be used only by a
|
||
|
trusted caller. The value is used in log entries and can appear in
|
||
|
Received headers. The option is intended for use when handing to Exim
|
||
|
messages received by other means.
|
||
|
.TP
|
||
|
.B -om
|
||
|
In sendmail, this option means 'me too', indicating that the sender of
|
||
|
a message should receive a copy of the message if the sender appears
|
||
|
in an alias expansion. Exim always does this, so the option does
|
||
|
nothing.
|
||
|
.TP
|
||
|
.B -or <time>
|
||
|
This option sets a timeout value for incoming non-SMTP messages. If it
|
||
|
is not set, Exim will wait forever for the standard input. The value
|
||
|
can also be set using the accept_timeout configuration vari- able. The
|
||
|
format used for specifying times is described in section 7.6.
|
||
|
.TP -ov
|
||
|
This option has exactly the same effect as -v.
|
||
|
.TP
|
||
|
.B -oX <number>
|
||
|
This option is relevant only when the -bd option is also given. It
|
||
|
specifies an alternative TCP/IP port number for the listening daemon,
|
||
|
and is useful for testing. When used, the process number of the daemon
|
||
|
is written to a file whose name is exim- daemon.<number>.pid in Exim's
|
||
|
spool directory.
|
||
|
.TP
|
||
|
.B -q
|
||
|
If the -q option is not followed by a time value, it requests a single
|
||
|
queue run operation. This option can be used only by an admin
|
||
|
user. Exim starts up a delivery process for each (inactive) message on
|
||
|
the queue in turn, and waits for it to finish before starting the next
|
||
|
one. When all the queued messages have been considered, the original
|
||
|
process terminates. In other words, a single pass is made over the
|
||
|
waiting mail. Use -q with a time (see below) if you want this to be
|
||
|
repeated periodically.
|
||
|
|
||
|
Exim processes the waiting messages in an unpredictable order. It
|
||
|
isn't very random, but it is likely to be different each time, which
|
||
|
is all that matters. If one particular message screws up a remote MTA,
|
||
|
other messages to the same MTA have a chance of getting through if
|
||
|
they get tried first.
|
||
|
|
||
|
However, it is possible to cause the messages to be processed in
|
||
|
lexical id order, which is essentially the order in which they
|
||
|
arrived, and to start this operation at a particular point by
|
||
|
following the -q option with a starting message id. For example:
|
||
|
|
||
|
exim -q 0t5C6f-0000c8-00
|
||
|
|
||
|
This causes Exim to skip any messages whose ids are lexically less
|
||
|
than the given id. A second id can also be given to stop the queue run
|
||
|
before the end. See also the -R option.
|
||
|
.TP
|
||
|
.B -q <time>
|
||
|
This version of the -q option (which again can be run only by an admin
|
||
|
user) causes Exim to run as a daemon, starting a queue-running process
|
||
|
at intervals specified by the given time value (whose format is
|
||
|
described in section 7.6). This form of the -q option is commonly
|
||
|
combined with the -bd option, in which case a single daemon process
|
||
|
handles both functions. A common way of starting up a combined daemon
|
||
|
at system boot time is to use a command such as
|
||
|
|
||
|
/opt/exim/bin/exim -bd -q30m
|
||
|
|
||
|
Such a daemon listens for incoming SMTP calls, and also fires up a
|
||
|
queue-runner process every 30 minutes. The process id of such a daemon
|
||
|
is written to a file called exim-daemon.pid in Exim's spool directory,
|
||
|
unless the -oX option has been used, in which case the file is called
|
||
|
exim-daemon.<port-number>.pid. The location of the pid file can be
|
||
|
changed by defining PID_FILE_PATH in Local/Makefile. If a daemon is
|
||
|
started without -bd then the -q option used to start it is added to
|
||
|
the pid file name.
|
||
|
.TP
|
||
|
.B -qf
|
||
|
This option operates like -q, and may appear with or without a
|
||
|
following time. The difference is that a delivery attempt is forced
|
||
|
for each message, whereas with -q only those addresses that have
|
||
|
passed their retry times are tried.
|
||
|
.TP
|
||
|
.B -qfl
|
||
|
This option operates like -ql, and may appear with or without a
|
||
|
following time. The difference is that a delivery attempt is forced
|
||
|
for each message, whereas with -ql only those local addresses that
|
||
|
have passed their retry times are tried.
|
||
|
.TP
|
||
|
.B -ql
|
||
|
This option operates like -q, and may appear with or without a
|
||
|
following time. The difference is that only local addresses are
|
||
|
considered for delivery. Note that -ql cannot detect apparently remote
|
||
|
addresses that actually turn out to be local when their domains get
|
||
|
fully qualified.
|
||
|
.TP -R <string>
|
||
|
This option is similar to -q with no time value, except that, when
|
||
|
scanning the messages on the queue, Exim processes only those that
|
||
|
have at least one undelivered address containing the given string,
|
||
|
which is checked in a case-independent way. However, once a message is
|
||
|
selected, all its addresses are processed. For the first message
|
||
|
containing a matching address, Exim overrides any retry information
|
||
|
and forces a delivery attempt. This makes it straightforward to
|
||
|
initiate delivery for all messages to a given domain after a host has
|
||
|
been down for some time. When the SMTP command ETRN is permitted (see
|
||
|
the smtp_etrn options), its effect is to run Exim with the -R option.
|
||
|
.TP
|
||
|
.B -r
|
||
|
This is a documented (for sendmail) obsolete alternative name for -f.
|
||
|
.TP
|
||
|
.B -t
|
||
|
When Exim is receiving a locally-generated, non-SMTP message on the
|
||
|
current input, the -t option causes the recipients of the message to
|
||
|
be obtained from the To, Cc, and Bcc headers in the message instead of
|
||
|
from the command arguments. If there are any arguments, they specify
|
||
|
addresses to which the message is not to be delivered. That is, the
|
||
|
argument addresses are removed from the recipients list obtained from
|
||
|
the headers. If a Bcc header is present, it is removed from the
|
||
|
message unless there is no To or Cc header, in which case a Bcc header
|
||
|
with no data is created, in accordance with RFC 822.
|
||
|
.TP
|
||
|
.B -v
|
||
|
This option has exactly the same effect as -d1; it causes Exim to be
|
||
|
'verbose' and produce some output describing what it is doing on the
|
||
|
standard error file. In particular, if an SMTP connection is made, the
|
||
|
SMTP dialogue is shown.
|
||
|
.TP
|
||
|
.B -x
|
||
|
AIX uses -x for a private purpose ('mail from a local mail program has
|
||
|
National Language Support extended characters in the body of the mail
|
||
|
item'). It sets -x when calling the MTA from its mail command. Exim
|
||
|
ignores this option.
|
||
|
.SH "SEE ALSO"
|
||
|
sendmail(8), mailwrapper(8), mailer.conf(5).
|
||
|
.SH AUTHOR
|
||
|
This manual page was stitched together by Christoph Lameter,
|
||
|
<clameter@debian.org>, from the original documentation coming with the
|
||
|
sourcepackage for the Debian GNU/Linux system, and cleaned up a little
|
||
|
by Tim Cutts <tjrc1@scalopus.bio.cam.ac.uk>. Modifications for NetBSD
|
||
|
made by Andy Doran <ad@NetBSD.org>.
|