邮件传输代理(MTA)基础
概述
本教程中,你将学习:
- 使用
mail
命令。 - 创建邮件别名。
- 配置电子邮件转发。
- 了解常见邮件传输代理(MTA),比如,postfix、sendmail、qmail、以及 exim。
控制邮件去向
Linux 系统上的电子邮件是使用 MTA 投递的。你的 MTA 投递邮件到你的系统上的其他用户,并且 MTA 彼此通讯跨越系统投递到全世界。
Sendmail 是最古老的 Linux MTA。它最初起源于 1979 年用于阿帕网(ARPANET)的 delivermail 程序。如今它有几个替代品,在本教程中,我也会介绍它们。
前提条件
为完成本系列教程的大部分内容,你需要具备 Linux 的基础知识,你需要拥有一个 Linux 系统来实践本教程中的命令。你应该熟悉 GNU 以及 UNIX 命令。有时候不同版本的程序的输出格式可能不同,因此,在你的系统中输出的结果可能与我在下面列出的稍有不同。
在本教程中,我使用的是 Ubuntu 14.04 LTS 和 sendmail 8.14.4 来做的演示。
邮件传输
邮件传输代理(比如 sendmail)在用户之间和系统之间投递邮件。大量的因特网邮件使用简单邮件传输协议(SMTP),但是本地邮件可能是通过文件或者套接字等其它可能的方式来传输的。邮件是一种存储和转发的操作,因此,在用户接收邮件或者接收系统和通讯联系可用之前,邮件一直是存储在某种文件或者数据库中。配置和确保 MTA 的安全是非常复杂的任务,它们中的大部分内容都已经超出了本教程的范围。
mail 命令
如果你使用 SMTP 协议传输电子邮件,你或许知道你可以使用许多邮件客户端,包括 mail
、mutt
、alpine
、notmuch
、以及其它基于主机控制台或者图形界面的邮件客户端。mail
命令是最老的、可用于脚本中的、发送和接收以及管理收到的邮件的备用命令。
你可以使用 mail
命令交互式的向列表中的收件人发送信息,或者不使用参数去查看你收到的邮件。清单 1 展示了如何在你的系统上去发送信息到用户 steve 和 pat,同时抄送拷贝给用户 bob。当提示 Cc:
和 subject:
时,输入相应的抄送用户以及邮件主题,接着输入邮件正文,输入完成后按下 Ctrl+D
(按下 Ctrl
键并保持再按下 D
之后全部松开)。
ian@attic4-u14:~$ mail steve,pat
Cc: bob
Subject: Test message 1
This is a test message
Ian
清单 1. 使用 mail
交互式发送邮件
如果一切顺利,你的邮件已经发出。如果在这里发生错误,你将看到错误信息。例如,如果你在接收者列表中输入一个无效的用户名,邮件将无法发送。注意在本示例中,所有的用户都在本地系统上存在,因此他们都是有效用户。
你也可以使用命令行以非交互式发送邮件。清单 2 展示了如何给用户 steve 和 pat 发送一封邮件。这种方式可以用在脚本中。在不同的软件包中 mail
命令的版本不同。对于抄送(Cc:
)有些支持一个 -c
选项,但是我使用的这个版本不支持这个选项,因此,我仅将邮件发送到收件人。
ian@attic4-u14:~$ mail -t steve,pat -s "Test message 2"
来标识,它是清单 3 中的第一封邮件。如果你按下回车键(Enter
),将显示下一封未读邮件的第一页。按下空格楗将显示这个邮件的下一页。当你读完这个邮件并想返回到?
提示符时,按下回车键再次查看下一封邮件,依次类推。在?
提示符下,你可以输入h
再次去查看邮件头。你看过的邮件前面将显示一个R
状态,如清单 4 所示。? h R 1 Ian Shields Tue Dec 12 21:03 16/704 test message R 2 Ian Shields Tue Dec 12 21:04 18/701 Test message 1 >R 3 Ian Shields Tue Dec 12 21:23 15/661 Test message 2 N 4 Bob C Tue Dec 12 21:45 17/653 How about lunch tomorrow? ?
清单 4. 使用
h
去显示邮件头在这个图中,Steve 已经读了三个邮件,但是没有读来自 bob 的邮件。你可以通过数字来选择单个的信息,你也可以通过输入
d
删除你不想要的信息,或者输入3d
去删除第三个信息。如果你输入q
你将退出mbox
文件中,而未读的信息仍然保留在你的收件箱中,默认在/var/mail/$(id -un)
。如清单 5 所示。? h R 1 Ian Shields Tue Dec 12 21:03 16/704 test message R 2 Ian Shields Tue Dec 12 21:04 18/701 Test message 1 >R 3 Ian Shields Tue Dec 12 21:23 15/661 Test message 2 N 4 Bob C Tue Dec 12 21:45 17/653 How about lunch tomorrow? ? q Saved 3 messages in /home/steve/mbox Held 1 message in /var/mail/steve You have mail in /var/mail/steve
清单 5. 使用
q
退出如果你输入
x
而不是使用q
去退出,你的邮箱在退出后将不保留你做的改变。因为这在/var
文件系统中,你的系统管理员可能仅允许邮件在一个有限的时间范围内保留。要重新读取或者以其它方式再次处理保存在你的本地邮箱中的邮件,你可以使用-f
选项去指定想要去读的文件。比如,mail -f mbox
。邮件别名
在前面的节中,看了如何在系统上给许多用户发送邮件。你可以使用一个全限定名字(比如 ian@myexampledomain.com)给其它系统上的用户发送邮件。
有时候你可能希望用户的所有邮件都可以发送到其它地方。比如,你有一个服务器群,你希望所有的 root 用户的邮件都发给中心的系统管理员。或者你可能希望去创建一个邮件列表,将邮件发送给一些人。为实现上述目标,你可以使用别名,别名允许你为一个给定的用户名定义一个或者多个目的地。这个目的地或者是其它用户的邮箱、文件、管道、或者是某个进一步处理的命令。你可以在
/etc/mail/aliases
或者/etc/aliases
中创建别名来实现上述目的。根据你的系统的不同,你可以找到上述其中一个,符号链接到它们、或者其中之一。改变别名文件你需要有 root 权限。别名的格式一般是:
name: addr_1, addr_2, addr_3, ...
这里
name
是一个要别名的本地用户名字(即别名),而addr_1
,addr_2
,… 可以是一个或多个别名。别名可以是一个本地用户、一个本地文件名、另一个别名、一个命令、一个包含文件,或者一个外部地址。因此,发送邮件时如何区分别名呢(addr-N)?