postfix基本设置与配置指南

这份说明的目标是告诉你如何在企业环境下为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邮件服务器收到一封新消息的时候,它将首先被放入接收队列中。下面的图表展示了新邮件处理的主要组件。

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你需要在终端中输入

dig mx yourdomain.com

安装 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 25

Postfix将出现下面这样的终端提示,这样你就可以输入一些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>

为一个账号创建别名

下面的代码讲述了怎样设置一个别名。这个步骤是可选的,因为我们稍後会配置虚拟邮件域名的。加入这个步骤的目的是保证你在需要的时候明白如何配置。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wwydwj.html