第15章 使用Postfix与Dovecot收发电子邮件

章节概述:

本章节从电子邮局系统的组成角色开始讲起,了解MUA、MTA与MDA的作用,熟悉熟悉SMTP、POP3与IMAP4邮局协议。

学习postfix与dovecot服务程序的使用方法并逐条讲解配置参数,完整演示了部署基础电子邮局系统以及设置用户别名邮箱的方法。

本章目录结构

  • 15.1 电子邮局系统
  • 15.2 部署基础电子邮局系统
    • 15.2.1 配置Postfix服务程序
    • 15.2.2 配置Dovecot服务程序
    • 15.2.3 用户使用邮局系统
  • 15.3 设置用户别名邮箱
15.1 电子邮局系统

1971年由美国国防部资助的的ARPANET科研项目遇到了严峻问题——参于科研项目的科学家在不同的地方工作,不能及时的分享各自的研究成果,迫切的需要一种能够借助于网络且建立在计算机之间的传输数据的方法。 当时麻省理工学院Ray Tomlinson博士也是ARPANET项目的科研成员,当年秋天他使用软件SNDMSG向自己另一台电脑发出了人类历史上第一封Email邮件。

Ray Tomlinson博士决定选择"@"符号作为用户名与主机地址的间隔符。

邮件应用协议包括:

简单邮件传输协议(SMTP),用来发送或中转发出的电子邮件,占用tcp 25端口。

第三版邮局协议(POP3),用于将服务器上把邮件存储到本地主机,占用tcp 110端口。

第四版互联网信息访问协议(IMAP4),用于在本地主机上访问邮件,占用tcp 143端口。

电子邮件系统(E-mail,即Electronic mail system)由三部分组成

用户代理MUA(Mail User Agent):用于收发邮件。

邮件传输代理MTA(Mail Transfer Agent):将来自于MUA的邮件转发给指定用户。

邮件投递代理MDA(Mail Delivery Agent):将来自于MTA的邮件保存到本机的收件箱中。

电子邮件系统与大多数的网络应用协议有本质的不同,例如前面讲过的文本传输协议(FTP),FTP服务程序就像拨打电话一样,需要对方当前也保持在线,否则会报错连接超时。但电子邮件的发送者则并不需要等待投递工作完成,因为如果对方服务器宕机了,则会将要发送的内容自动的暂时保存到本地,检测到对方服务器恢复后再次投递。另外如果您想搭建企业级的电子邮件系统,请考虑下面几点:

反垃圾与反病毒模块:阻止垃圾邮件或病毒邮件对企业邮箱的干扰。

邮件加密:保证邮件内容不被嗅探、篡改。

邮件监控审核:监控全体职员邮件中有无敏感词,透露企业资料等。

稳定性:有较好的防DDOS攻击的能力,保证系统在线率等。

15.2 部署基础电子邮局系统

单独的使用Postfix服务程序并不能让用户完成收发邮件的操作,因为一个基础的电子邮局系统至少需要有SMTP服务器、POP3/IMAP服务器,为了能够部署一个基础的电子邮局系统,我们需要使用到下面的软件:

Postfix:提供邮件发送服务,即SMTP。

Dovecot:提供邮件收取服务,即POP3。

OutLook Express:客户端收发邮件的工具。

Postfix(发送邮件)+Dovectot(接收邮件)+OutLook(客户端工具)

配置本地主机名
修改本地主机名的配置文件:

[[email protected] ~] # vim /etc/hostname
mail.linuxprobe.com
[[email protected]~] # hostname
mail.linuxprobe.com

若要为用户提供linuxprobe域的电子邮局系统,则需先在DNS服务器中增加A记录和MX记录:

@ IN MX 10 mail.linuxprobe.com.
mail IN A 192.168.10.10

这样配置解析记录后,主机名即为mail.linuxprobe.com,而邮件域为@linuxprobe.com

(请读者自行使用nmtui工具将网卡的DNS地址配置妥当即可)

15.2.1 配置Postfix服务程序

Postfix是一款由IBM出资研发的免费开源的邮局服务程序,兼容于Sendmail服务程序,即Sendmail用户可以很方便的迁移到Postfix程序,且收发件性能远超过Sendmail,能够自动增加减少进程的数量,保证邮局系统的高性能与稳定性,另外Postfix是由诸多的小模块组成,每个小模块完成特定的功能,使得管理员可以灵活的组合这些模块。
停止iptables防火墙:

[[email protected] ~]# systemctl disable iptables

红帽RHEL7系统中默认已安装postfix邮局服务程序:

[[email protected] ~]# yum install postfix
Loaded plugins: langpacks, product-id, subscription-manager
rhel7 | 4.1 kB 00:00
(1/2): rhel7/group_gz | 134 kB 00:00
(2/2): rhel7/primary_db | 3.4 MB 00:00
Package 2:postfix-2.10.1-6.el7.x86_64 already installed and latest version
Nothing to do

Postfix邮局服务程序的配置文件如下:

编辑
文件 作用
/usr/sbin/postfix 主服务程序
/etc/postfix/master.cf master主程序的配置文件。
/etc/postfix/main.cf postfix服务的配置文件。
/var/log/maillog 记录邮件传递过程的日志。

第1步:查看Postfix服务程序主配置文件:

[[email protected]~]# cat /etc/postfix/main.cf

配置文件足足有679行!但不用担心,绝大部分都是注释信息,我们只学习这些参数即可:

编辑
参数 作用
myhostname 邮局系统的主机名。
mydomain 邮局系统的域名。
myorigin 从本机寄出邮件的域名名称。
inet_interfaces 监听的网卡接口。
mydestination 可接收邮件的主机名或域名。
mynetworks 设置可转发那些主机的邮件。
relay_domains 设置可转发那些网域的邮件

编辑Postfix服务程序的主配置文件(修改5处参数,另外需要将参数前面的井号(#)去掉才可生效):

[[email protected]~] # vim /etc/postfix/main.cf
//修改第76行的邮局主机名。
myhostname = mail.linuxprobe.com
//修改第83行的邮局域名。
mydomain = linuxprobe.com
//修改第99行的寄出邮件域名,$mydomain的值已在上面定义。
myorigin = $mydomain
//修改第116行的监听网卡。
inet_interfaces = all
//修改第164行的可接收邮件的主机名和域名。
mydestination = $myhostname, $mydomain

第2步:创建邮局帐号:

[[email protected]~] # useradd boss
[[email protected]~] # echo "linuxprobe" | passwd --stdin boss
Changing password for user boss. passwd: all authentication tokens updated successfully.

第3步:启动Postfix服务程序:

[[email protected]~] # systemctl restart postfix
[[email protected]~] # systemctl enable postfix
ln -s ‘/usr/lib/systemd/system/postfix.service‘ ‘/etc/systemd/system/multi-user.target.wants/postfix.service‘

因为在红帽RHCSA、RHCE或RHCA考试后都要重启您的实验机再执行判分脚本。

所以请读者在日常工作中也要记得将需要的服务加入到开机启动项中:”systemctl enable postfix“。

15.2.2 配置Dovecot服务程序

第1步:安装Dovecot服务程序:

[[email protected]~] # yum install dovecot -y
Loaded plugins: langpacks, product-id, subscription-manager
………………省略部分安装过程………………
Installing: dovecot x86_64 1:2.2.10-4.el7 rhel7 3.2 M
Installing for dependencies: clucene-core x86_64 2.3.3.4-11.el7 rhel7 528 k
………………省略部分安装过程………………
Complete!

第2步:修改Dovecot程序主配置文件:

[[email protected]~] # vim /etc/dovecot/dovecot.conf
//修改第24行的支持邮局协议。
protocols = imap pop3 lmtp
//然后追加允许明文认证(25行)。
disable_plaintext_auth = no
//修改第48行的允许登陆网段地址,全部允许即为(0.0.0.0/0)。
login_trusted_networks = 192.168.10.0/24

第3步:配置邮件的格式与存储路径。<
编辑dovecot的配置文件(将第25行的注释符(#号)去掉):

[[email protected]~] # vim /etc/dovecot/conf.d/10-mail.conf
mail_location = mbox:~/mail:INBOX=/var/mail/%u

第4步:创建邮件的存储目录:

[[email protected]~] # su - boss
Last login: Sat Aug 15 16:15:58 CST 2015 on pts/1
[[email protected] ~]$ mkdir -p mail/.imap/INBOX

第5步:启动Dovecot服务程序:

[root@mail~] # systemctl restart dovecot
[root@mail~] # systemctl enable dovecot
ln -s ‘/usr/lib/systemd/system/dovecot.service‘ ‘/etc/systemd/system/multi-user.target.wants/dovecot.service‘

因为在红帽RHCSA、RHCE或RHCA考试后都要重启您的实验机再执行判分脚本。

所以请读者在日常工作中也要记得将需要的服务加入到开机启动项中:”systemctl enable dovcot“。

15.2.3 用户使用邮局系统

您可以在《软件资源库》下载到Windows7系统以及OutLook2007邮件管理工具,系统网卡请按要求配置IP地址:

编辑
主机名称 操作系统 IP地址
邮局服务器 红帽RHEL7操作系统 192.168.10.10
DNS服务器 红帽RHEL7操作系统 192.168.10.20
用户端主机 微软Windows7系统  

在outlook中登陆boss用户后尝试给[email protected]发送邮件。

  • 第1步:开启OutLook程序。

  • 第2步:选择开始配置电子邮件帐户。

  • 第3步:选择默认的邮局服务器类型。

  • 第4步:填写创建的邮箱帐号和密码。

  • 第5步:等待连接邮局服务器。

  • 第6步:选择非加密的链接方式。

  • 第7步:在页面上邮件,选择“新邮件”。

  • 第8步:填写收件人与邮件内容后发送。

登陆到邮局服务器(192.168.10.10)后查看root用户的邮件:

[[email protected]~] # mail
Heirloom Mail version 12.5 7/5/10.Type ? for help.
"/var/mail/root": 3 messages 3 unread >
U 1 [email protected] Fri Jul 10 09:58 1631/123113 "[abrt] full crash r"
U 2 Anacron Sat Aug 15 13:33 18/624 "Anacron job ‘cron.dai"
U 3 boss Sat Aug 15 19:02 118/3604 "Hello~"
&> 3
Message 3:
From [email protected] Sat Aug 15 19:02:06 2015
Return-Path:
X-Original-To: [email protected]
Delivered-To: [email protected]
From: "boss"
To:
Subject: Hello~
Date: Sat, 15 Aug 2015 19:02:06 +0800
Content-Type: text/plain; charset="gb2312"
当您收到这封邮件时,证明我的邮局系统实验已经成功!
> quit
Held 3 messages in /var/mail/root
时间: 2024-08-24 10:16:55

第15章 使用Postfix与Dovecot收发电子邮件的相关文章

第15章 使用Postfix与Dovecot部署邮件系统

电子邮件系统基于邮件协议来完成电子邮件的传输,常见的邮件协议有下面这些. 简单邮件传输协议(Simple Mail Transfer Protocol,SMTP):用于发送和中转发出的电子邮件,占用服务器的25/TCP端口.邮局协议版本3(Post Office Protocol 3,POP3):用于将电子邮件存储到本地主机,占用服务器的110/TCP端口.Internet消息访问协议版本4(Internet Message Access Protocol 4,IMAP):用于在本地主机上访问邮

linux学习14章-使用DHCP动态管理主机地址和15章使用Postfix与Dovecot部署邮件系统

2019年12月14日 动态主机配置协议(DHCP)是一种基于UDP协议且仅限于在局域网内部使用的网络协议,主要用于大型的局域网环境或者存在较多移动办公设备的局域网环境中,其主要用途是为局域网内部的设备或网络供应商自动分配IP地址等参数. 简单来说,DHCP协议就是让局域网中的主机自动获得网络参数的服务.在图14-1所示的拓扑图中存在多台主机,如果手动配置每台主机的网络参数会相当麻烦,日后维护起来也让人头大.而且当机房内的主机数量进一步增加时(比如有100台,甚至1000台),这个手动配置以及维

使用Postfix和Dovecot收发电子邮件

邮件应用协议包括: 简单邮件传输协议(SMTP),用来发送或中转发出的电子邮件,占用tcp 25端口. 第三版邮局协议(POP3),用于将服务器上把邮件存储到本地主机,占用tcp 110端口. 第四版互联网信息访问协议(IMAP4),用于在本地主机上访问邮件,占用tcp 143端口. 搭建企业级的电子邮件系统,请考虑下面几点: 反垃圾与反病毒模块:阻止垃圾邮件或病毒邮件对企业邮箱的干扰. 邮件加密:保证邮件内容不被嗅探.篡改. 邮件监控审核:监控全体职员邮件中有无敏感词,透露企业资料等. 稳定性

15 使用Postfix与Dovecot部署邮件系统

15 使用Postfix与Dovecot部署邮件系统 电子邮件系统基于邮件协议来完成电子邮件的传输,常见的邮件协议有下面这些. 简单邮件传输协议(Simple Mail Transfer Protocol,SMTP):用于发送和中转发出的电子邮件,占用服务器的25/TCP端口. 邮局协议版本3(Post Office Protocol 3):用于将电子邮件存储到本地主机,占用服务器的110/TCP端口. Internet消息访问协议版本4(Internet Message Access Prot

Linux与云计算——第二阶段Linux服务器架设 第九章:Mail电子邮件服务器架设—postfix和Dovecot

Linux与云计算--第二阶段Linux服务器架设 第九章:Mail电子邮件服务器架设-postfix和Dovecot 安装Postfix 安装Postfix来配置SMTP服务器. SMTP使用25/TCP. [1] Postfix 是CentOS系统默认安装,哪怕你选择了最小安装,如果确认没有安装,请先安装. [[email protected] ~]# yum -y install postfix [2] 使用Dovecot's SASL 来配置SMTP认证. [[email protect

邮件接收中Postfix、Dovecot、Squirrelmail、MySQL、AMaVis、Clam AntiVirus和SpamAssasin的功能解析

参考网址的教程:https://workaround.org/ispmail/lenny/bigpicture 邮件接收过程中各个软件的功能分布流程 在收发电子邮件的过程中,Postfix.Dovecot.Squirrelmail.MySQL.AMaVis.Clam AntiVirus和SpamAssasin的功能分类流程图如下所示: 电子邮件采用SMTP协议,通过TCP端口25进入邮件服务器.Postfix通过监控这个端口,接收电子邮件并进行一些基本检查.这些检查比如:发件人是否在黑名单?邮件

Linux+postfix+extmail+dovecot打造基于web页面的邮件系统

Linux+postfix+extmail+dovecot打造基于web页面的邮件系统 linuxwebmysqlapacheredhat数据库服务器 Linux+postfix+extmail+dovecot打造基于web页面的邮件系统 最终效果图: 准备阶段:需要手动下载的软件包: postfix-2.6.5.tar.gz courier-authlib-0.62.4.tar.bz2 eextmail-1.2.tar.gz xtman-1.1.tar.gz Time-HiRes-1.9707

Postfix+courier-authlib+dovecot+Extmail与Extman邮箱系统

Postfix+courier-authlib+dovecot+Extmail与Extman实现web服务的邮件服务器 一.环境准备 1. 系统环境 centos7.x Linux mail.apicloud.com 3.10.0-862.3.3.el7.x86_64 #1 SMP Fri Jun 15 04:15:27 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux 2. 软件环境 #删除自带的Postfix软件 yum remove postfix #yum 

搭建 Postfix、Dovecot 邮件服务

搭建 Postfix.Dovecot 邮件服务 准备域名 任务时间:15min ~ 20min 域名注册 如果您还没有域名,可以在腾讯云上选购,过程可以参考下面的视频. 视频 - 在腾讯云上购买域名 域名解析 域名购买完成后, 需要将域名解析到实验云主机上,实验云主机的 IP 为: <您的 CVM IP 地址> 在腾讯云购买的域名,可以到控制台添加解析记录,过程可参考下面的视频: 视频 - 如何在腾讯云上解析域名 完成该实验共需要添加两条记录: A 记录 记录类型:A 主机记录:@ 记录值:&