The Exim package contains a Mail Transport Agent written by the University of Cambridge, released under the GNU Public License.
Download (HTTP): http://www.exim.org/ftp/exim4/exim-4.43.tar.bz2
Download (FTP): ftp://ftp.exim.org/pub/exim/exim4/exim-4.43.tar.bz2
Download MD5 sum: f8f646d4920660cb5579becd9265a3bf
Download size: 1.4 MB
Estimated disk space required: 14.9 MB
Estimated build time: 0.14 SBU
Required patch for Berkeley DB: http://www.linuxfromscratch.org/blfs/downloads/6.0/exim-4.43-db43-1.patch
Before building Exim, as the root user you should create the group and user exim which will run the exim daemon:
groupadd exim &&
useradd -d /dev/null -c "Exim Daemon" -g exim -s /bin/false exim
If you have Berkeley DB installed, apply the following patch:
patch -Np1 -i ../exim-4.43-db43-1.patch
Install Exim with the following commands:
sed -e 's,^BIN_DIR.*$,BIN_DIRECTORY=/usr/sbin,' src/EDITME | \
sed -e 's,^CONF.*$,CONFIGURE_FILE=/etc/exim.conf,' | \
sed -e 's,^EXIM_USER.*$,EXIM_USER=exim,' | \
sed -e 's,^EXIM_MONITOR,#EXIM_MONITOR,' > Local/Makefile &&
make
Now, as the root user:
make install &&
install -v -m644 doc/exim.8 /usr/share/man/man8 &&
install -v -d -m755 /usr/share/doc/exim-4.43 &&
install -v -m644 doc/* /usr/share/doc/exim-4.43 &&
ln -sv exim /usr/sbin/sendmail
sed -e ... > Local/Makefile: Most of Exim's configuration options are compiled in using the directives in Local/Makefile which is created from the src/EDITME file. This command specifies the minimum set of options. Descriptions for the options are listed below.
BIN_DIRECTORY=/usr/sbin: This installs all of Exim's binaries and scripts in /usr/sbin.
CONFIGURE_FILE=/etc/exim.conf: This installs Exim's main configuration file in /etc.
EXIM_USER=exim: This tells Exim that after the daemon no longer needs root privileges, the process hands off the daemon to the exim user.
#EXIM_MONITOR: This defers building the Exim monitor program, as it requires X Window System support, by commenting out the EXIM_MONITOR line in the Makefile. If you wish to build the monitor program, omit this sed command and issue the following command before building the package (modify Local/eximon.conf, if necessary): cp exim_monitor/EDITME Local/eximon.conf.
ln -s exim /usr/sbin/sendmail: Creates a link to sendmail for applications which need it. Exim will accept most Sendmail command-line options.
To utilize some or all of the dependency packages, you'll need to modify Local/Makefile to include the appropriate directives and parameters to link additional libraries before you build Exim. Local/Makefile is heavily commented with instructions on how to do this. Listed below is additional information to help you link these dependency packages.
To use a backend database other than Berkelely DB, see the instructions at http://www.exim.org/exim-html-4.40/doc/html/spec_4.html#SECT4.3.
For SSL functionality, see the instructions at http://www.exim.org/exim-html-4.40/doc/html/spec_4.html#SECT4.6 and http://www.exim.org/exim-html-4.40/doc/html/spec_37.html#CHAP37.
For tcpwrappers functionality, see the instructions at http://www.exim.org/exim-html-4.40/doc/html/spec_4.html#SECT4.7.
For information about adding authentication mechanisms to the build, see the instructions at http://www.exim.org/exim-html-4.40/doc/html/spec_34.html#SECT34.4 For specific information about using Cyrus-SASL, see section 10 of the doc/NewStuff file located in the source tree.
For information about linking Linux-PAM, see the instuctions at http://www.exim.org/exim-html-4.40/doc/html/spec_11.html#IX935.
For information about linking database engine libraries used for Exim name lookups, see the instuctions at http://www.exim.org/exim-html-4.40/doc/html/spec_9.html#CHAP9.
If you wish to add Readline support to Exim when invoked in “test expansion” (-bv) mode, see the information in section 8 of the doc/NewStuff file located in the source tree.
You may wish to modify the default configuration and send log files to syslog instead of the default /var/spool/exim/log directory. See the information at http://www.exim.org/exim-html-4.40/doc/html/spec_45.html#CHAP45.
A default (nothing but comments) /etc/aliases file is installed during the package installation if this file did not exist on your system. Create the necessary aliases and start the Exim daemon using the following commands:
cat >> /etc/aliases << "EOF" postmaster: root MAILER-DAEMON: root EOF exim -v -bi && /usr/sbin/exim -bd -q15m
To protect an existing /etc/aliases file, the command above appends these aliases to it. This file should be checked and duplicate aliases removed, if present.
The /usr/sbin/exim -bd -q15m command starts the Exim daemon with a 15 minute interval in processing the mail queue. Adjust this parameter to suit your desires.
To automate the running of exim at startup, install the /etc/rc.d/init.d/exim init script included in the blfs-bootscripts-6.0 package.
make install-exim
The bootscript also starts the Exim daemon and dispatches a queue runner process every 15 minutes. Modify the -q[time interval] parameter in /etc/rc.d/init.d/exim, if necessary for your installation.
cycles Exim log files.
searches Exim log files.
is a symlink to the exim-4.43-2 MTA daemon.
is the Exim mail transport agent daemon.
states whether a given recipient address from a given host is acceptable or not.
creates and rebuilds Exim databases.
writes the contents of Exim databases to the standard output.
modifies data in Exim databases.
locks a mailbox file.
removes old records from Exim databases.
generates mail statistics from Exim log files.
queries remote host retry times.
selects messages based on various criteria.
is a utility for selective queue listing.
produces a summary of the messages in the mail queue.
queries running Exim processes.
is a start-up shell script for eximon.bin used to set the required environment variables before running the program.
is a monitor program which displays current information in an X window, and also contains a menu interface to Exim's command line administration options.
Last updated on 2005-02-17 18:40:10 -0700