这份说明的目标是告诉你如何在企业环境下为Postfix邮件服务器作基本的设置。这份说明的主要目的是教会你进行Postfix邮件服务器的基本配置以使其拥有IMAP与POP3功能。但是,你无法在这份说明中学到在Postfix邮件服务器中集成像病毒过滤及垃圾邮件过滤等高级的功能的方法。
这份说明是针对刚开始使用Postfix的用户提供一个基础的认识。其它的高级指南是[:PostfixVirtualMailBoxClamSmtpHowto:Postfix - Postfix 虚拟邮箱和病毒过滤指南]以及[:PostfixCompleteVirtualMailSystemHowto:Postfix - Postfix 完整虚拟邮件系统指南]。如果你是一个 Postfix 的新手,但希望使用那些高级功能的话,你应当事先了解本说明。
安装提示 本指南提供的安装方法,Postfix通过网络来发送及接收邮件并将它们存入用户邮箱中,用户可以通过Courier IMAP 或者 POP3 服务器来回复他们的邮件。用户验证是由 Courier Authdaemon 这个守护进程来完成的。下面的图片表现了这个过程。
Postfix的结构
构件
下面的图片展现了主要的Postfix系统组件,以及它们之间的关键信息流。
黄色椭圆是邮件程序。
黄色方框是邮件队列或文件。
蓝色方框是查找表。
在大方框中运行的程序是由Postfix主驻留守护进程控制的。
大方框中的数字是Postfix邮件系统的属性。
接收邮件
当Postfix邮件服务器收到一封新消息的时候,它将首先被放入接收队列中。下面的图表展示了新邮件处理的主要组件。
邮件是在本地发送的。Postfix邮件发送程序将首先调用邮件丢弃程序将邮件丢弃到“回收站”目录下,在那里,邮件又将被 邮件发送 进程所处理。这个进程执行一些完整性检查,以保护Postfix邮件服务器的工作。
邮件是来自网络的。PostfixSMTP 服务器将接收这些邮件并进行完整性检查,以保护Postfix邮件服务器的工作。
邮件是由Postfix系统自己生成来返回无法传送的返回邮件给发送者。[bounce or defer]进程处理该消息。
邮件被[本地传输代理]转发时,或是通过一个在系统级的别名数据库中的条目,或者通过一个每个用户自己的[.forward]文件中的条目。这被一个没有标签的箭头指明。
邮件由Postfix服务器自己在内部生成,为了向邮件管理员[通知]这个问题(这条路径也被一个没有标签的箭头指明)。Postfix服务器能够配置来向邮件管理员通知SMTP协议的问题,[UCE] 策略的问题,等等。
[cleanup] 守护进程完成对于新邮件处理的最後阶段。它添加了缺失的From:和其他的邮件头信息,将地址重写成标准的user@fully.qualified.domain 格式,并且从邮件头有选择性的展开收到邮件的地址。cleanup守护进程将处理作为一个简单的队列插入到incoming队列,并且通知[|队列管理员]新邮件到达。cleanup守护进程能够配置来在查询[canonical]和 [virtual]表的基础上转换地址。 在cleanup守护进程的请求到来时,[trivial-rewrite]守护进程将地址重写成标准的 user@fully.qualified.domain 形式。
安装 Postfix
在安装中假定你的域名是 'yourdomain.com',并且它有一个有效的 MX 记录叫做'mail.yourdomain.com'。请一定记得将这份指南中的'yourdomain.com'替换成你的真实的域名。并且我还假定你知道”MX记录”是什么。要找出MX你需要在终端中输入
安装 postfix
sudo apt-get install postfix安装mailx软件包来用做mail命令邮件工具的程序。安装这个包来安装mail命令。
sudo apt-get install mailx测试默认的安装
这样添加一个用户。
sudo useradd -m -s /bin/bash fmastersudo passwd fmaster用下面的命令来测试默认的安装。
telnet localhost 25Postfix将出现下面这样的终端提示,这样你就可以输入一些SMTP命令。
Trying 127.0.0.1...Connected to mail.fossedu.org.Escape character is '^]'.220 localhost.localdomain ESMTP Postfix (Ubuntu)在Postfix的提示符下面输入这些代码段。
ehlo localhostmail from: root@localhostrcpt to: fmaster@localhostdataSubjet: My first mail on PostfixHi,Are you there?regards,Admin. (Type the .[dot] in a new Line and press Enter )quit检查'fmaster'的邮箱。
su - fmastermail当你输入mail}命令的时候,终端的输出应该像下面这样。
Mail version 8.1.2 01/15/2001. Type ? for help."/var/mail/fmaster": 2 messages 2 new>N 1 root@localhost Mon Mar 6 12:49 13/479 Just a test N 2 root@localhost Mon Mar 6 12:51 15/487 My first mail&你会观察到邮件被按照数字编号索引了,因此你可以输入你想看的邮件的编号。例如输入'2'来阅读第二封信。阅读完毕使用”q”命令退出。邮件会被写到用户主目录下面的一个叫做'mbox'的文件中。在我们的例子中是'/home/fmaster/mbox'。
mbox型的邮箱中的所有消息被连接并且储存成一个单一的文件。每一个消息的开始被头5个字母是”From”的那一行标示出来,并且每一封消息的末尾有一个空行。
设置Postfix支持Maildir型的邮箱
Maildir 是一个邮件池的格式,这种邮件格式不需要文件锁定来保证消息的完整性,因为邮件以一个特有的名字被保存在一个个单独的文件中。一个Maildir是一个包含3个叫做tmp, new和curd的子目录的目录(常常以Maildir命名)。这些子目录应该在同一个文件系统中。
另一个使用Maildir格式的邮箱的理由是Courier IMAP/POP3服务器只支持Maildir格式的邮箱。
在[这里]能够得到更多关于Maildir的信息。
sudo vi /etc/postfix/main.cf加入下面的代码:
home_mailbox = Maildir/在' mailbox_command = procmail -a “$EXTENSION” '那一行前面加上一个”#“将其注释掉。
重启 Postfix 使改变生效。
sudo /etc/init.d/postfix restart再一次测试你的安装。
安装 courier IMAP 和 POP3
sudo apt-get install courier-popsudo apt-get install courier-imap为postfix增加本地域
sudo vi /etc/postfix/main.cf将你的域名增加到 'mydestination'。增加完成後它看起来应该象这样:
...mydestination = mail.fossedu.org, localhost.localdomain, localhost, yourdoamin.com...将你的本地网络增加到:
sudo vi /etc/postfix/main.cf我假定你的本地网络是 192.168.1.0/24 并且将你的本地网络加入到mynetworks}。完成後它看起来应该像这样:
mynetworks = 127.0.0.0/8, 192.168.1.0/24使Postfix从因特网上接收邮件
使用下面的命令在'/etc/postfix/main.cf'增加'inet_interfaces = all'
sudo vi /etc/postfix/main.cf最後重启Postfix;
sudo /etc/init.d/postfix restart使用下面的代码再一次测试你的安装是否成功:
telnet mail.yourdomain.com 25ehlo yourdmain.commail from: root@yourdomain.comrcpt to: fmaster@yourdomain.comdataSubject: My first mail for my domainHi,Are you there?regards,Admin. (and Enter In a new Line)quit检查'fmaster'的邮箱
su - fmastercd Maildir/newls现在你将看到邮件在一个个单独的文件中了。
测试 Courier POP3
在终端中输入:
telnet mail.yourdomain.com 110使用下面示例代码来测试。注意在你自己的环境中做适当的变通。输出应该像下面这样:
Connected to mail.yourdomain.com (69.60.109.217).Escape character is '^]'.+OK Hello there.在Courier POP3服务器的提示符下面输入下面的代码段。我假定你能够看情况输入'+OK'後的行。
user fmaster+OK Password required.pass password+OK logged in.quit测试 Courier IMAP
在终端输入这些:
telnet mail.yourdomain.com 143使用下面的示例代码来测试。注意在你自己的环境中做适当的变通。输出应该像下面这样:
*OK [CAPABILITY IMAP4rev1 UIDPLUS CHILDREN NAMESPACE THREAD=ORDEREDSUBJECT THREAD=REFERENCES SORT QUOTA IDLE ACL ACL2=UNION STARTTLS XCOURIEROUTBOX=INBOX.Outbox] Courier-IMAP ready. Copyright 1998-2005 Double Precision, Inc. See COPYING for distribution information.在Courier POP3服务器的提示符下面输入下面的代码段
a login fmaster password
a OK LOGIN Ok.
a logout
本地的别名数据库
当邮件要被本地传送时,本地传送代理通过别名数据库来接受每一个名字。这个映射不对邮件头中的地址生效。本地的别名主要是用来实现收发列表,或者直接的将标准的别名例如 postmaster映射成真实的地址。这个表也可用来映射Firstname.Lastname的地址到登录名。
Postfix默认开启别名查询,你可以在main.cf文件中看到这些代码: <pre。 … alias_maps = hash:/etc/aliases … </pre>
为一个账号创建别名
下面的代码讲述了怎样设置一个别名。这个步骤是可选的,因为我们稍後会配置虚拟邮件域名的。加入这个步骤的目的是保证你在需要的时候明白如何配置。