百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Ubuntu搭建强健的邮箱服务器(一)(ubuntu 搭建邮件服务器)

nanshan 2024-11-17 14:12 41 浏览 0 评论

邮箱大家都常用,如果是个人使用,那么用第三方的邮箱就好了。但如果面向客户或企业管理,那么用第三方邮箱就不大方便了。有时我们的一些软件项目需要用邮箱发送验证码或推送一些推广信息什么的,使用第三方邮箱就更不合适了,这时搭建一个自己的邮箱服务器就非常有必要了。然而搭建一个邮箱服务器并非没有门槛,要了解一定的相关理论与技术是必要条件。就目前而言,网上能找到的可行的方案或教程可以说凤毛麟角,这就阻碍了许多同学前进的步伐。从今天开始,我会写一个系统的教程,以最优化及性价比的角度教大家如何搭建一个邮箱服务器。我会从几个方面讲述,一定要认真仔细的学习完这个系列的教程,相信你一定能够搭建一个自己的强健的邮箱服务器。绝对的童叟无欺。完成本教程的环境基础是:ubuntu22、nginx、mysql、postfix、dovecot。还要有一个你自己的域名,本教程示例域名为 example.com 及相关的二级域名。

一些术语

让我们先来快速了解一些术语,因为当我们了解了这些术语的时候就能知道这些见鬼的东西到底是什么。

MTA:邮件传输代理Mail Transfer Agent,基于 SMTP 协议(简单邮件传输协议)的服务端,比如 Postfix、Exim、Sendmail 等。SMTP 服务端彼此之间进行相互通信。

MUA: 邮件用户代理Mail User Agent,你本地的邮件客户端,例如 : Evolution、KMail、Claws Mail 或者 Thunderbird(LCTT 译注 : 例如国内的 Foxmail)。

POP3:邮局协议Post-Office Protocol版本 3,将邮件从 SMTP 服务器传输到你的邮件客户端的的最简单的协议。POP 服务端是非常简单小巧的,单一的一台机器可以为数以千计的用户提供服务。

IMAP: 交互式消息访问协议Interactive Message Access Protocol,许多企业使用这个协议因为邮件可以被保存在服务器上,而用户不必担心会丢失消息。IMAP 服务器需要大量的内存和存储空间。

TLS:传输套接层Transport socket layer是 SSL(安全套接层Secure Sockets Layer)的改良版,为 SASL 身份认证提供了加密的传输服务层。

SASL:简单身份认证与安全层Simple Authentication and Security Layer,用于认证用户。SASL进行身份认证,而上面说的 TLS 提供认证数据的加密传输。

StartTLS: 也被称为伺机 TLS 。如果服务器双方都支持 SSL/TLS,StartTLS 就会将纯文本连接升级为加密连接(TLS 或 SSL)。如果有一方不支持加密,则使用明文传输。StartTLS 会使用标准的未加密端口 25 (SMTP)、 110(POP3)和 143 (IMAP)而不是对应的加密端口 465(SMTP)、995(POP3) 和 993 (IMAP)。

工作模式

用postfix构建的邮件系统至少有两种工作模式,第一种是利用本地Linux账号进行邮件收发,比如本地系统有用户root或someone,那么就有root@example.com和someone@example.com两个email地址。这里的root和someone是你的ubuntu上的账户,这些账户可以通过 /etc/passwd这个文件查看,也就是本地账户。这个example.com就是你的域名。 第二种称为虚拟用户账户,这种用户是postfix管理的,不在/etc/passwd中出现,他们只为邮件操作而生,所以称为“虚拟用户”。他们难过postfix的映射关系在系统中映射有独立的硬盘空间。但同时这些用户又跟本地Linux系统内固有的真实账号没有关联。这两种工作模式的部署方法差异极大,本教程以虚拟用户配置为主,各位同学在参考网上教程的时候,首先要确认它是建立在哪个模式下的,否则容易张冠李戴,出现很多令人头疼的问题。

运行流程

对于电子邮件,我们有可能存在的一个误区是,将smtp和pop3按照字面的意思去理解,即smtp只管发件,pop3则只负责收件。其实并不完全是这样。下面是一封电子邮件在互联网上的投递流程:

发件人:me@qq.com 收件人:you@gmail.com

me@qq.com 用邮件客户端(比如outlook)写了一封邮件给you@gmail.com,点下发送按钮后,邮件首先会发送到smtp.qq.com

smtp.qq.com 检索到这封邮件的收件人域名是gmail.com,于是通过互联网(WAN)将邮件发送到smtp.gmail.com

smtp.gmail.com确认收下邮件后,将它转存到邮件服务器的硬盘中待收。

通过观察以上流程,你会发现smtp服务器其实身兼了 “收、发” 两个功能。 对于smtp.qq.com而言,是发送。 而从smtp.gmail.com的角度来看,则是接收。那么,咱们平时经常说起的 “收件服务器pop3” 又是怎么回事呢,整个流程似乎看不到它的身影?

pop3(或imap服务器,与之性质相同)更多的是起一个中转作用,它将存储在邮件服务器硬盘中的邮件转移回邮件客户端(user agent),它只负责从邮件服务器到邮件客户端这段路径,而邮件在广域网上的收发则是smtp要做的事,与pop3没有关系。

pop3与imap的区别是,pop3将邮件拉回本地后,即与服务器脱钩了。imap则更先进一些,它能做到实时将你在邮件客户端的操作反馈回邮件服务器,比如:删除邮件,标记已读等,服务器上的邮件也会做相应的动作。所以无论从浏览器登录邮箱或者客户端软件登录邮箱,看到的邮件以及状态都是一致的。

在Postfix中,你可以通过配置身份验证来增强邮件服务器的安全性。所谓知其然知其所以然,我的教程会先让大家了解相关软件的安装及配置参数详解,最后我会给出一个完整的搭建实例,让这块绊脚石不复存在。

Postfix的安装

Postfix是一个邮件传输代理(MTA),一个用于发送和接收电子邮件的应用程序。它可以配置为仅用于通过本地应用程序发送电子邮件。当您需要定期从应用程序发送电子邮件通知或有大量第三方电子邮件服务提供商不允许的出站流量时,这非常有用。它也是运行成熟的 SMTP 服务器的一种更轻松的替代方案,同时保留了所需的功能。

安装

sudo apt install postfix postfix-mysql opendkim opendkim-tools spf-tools-perl

或使用以下命令安装Postfix:

sudo apt install mailutils

在配置过程中,选择"Internet Site"并使用完整的域名(例如:mail.example.com):

如果在安装过程没有出现交互的配置窗口,则在上面的安装操作完成后执行以下操作来配置基本的参数,这对于我们开始学习的人来说极其重要。

sudo dpkg-reconfigure postfix

配置交互中的各项信息为:

  • 邮件配置的一般类型 : Internet站点
  • 系统邮件名称:example.com(不是mail.example.com)
  • Root 和 postmaster 邮件收件人:您的主要 Linux 帐户的用户名(也就是你正在使用的登录ubuntu系统的用户名,用root权限的用户名)
  • 其他接收邮件的目的地:$myhostname, example.com, mail.example.com, localhost.example.com, localhost,这个目的地就是能代表我们服务器网络地址的域名和本地主机名,后面我会详细说明。
  • 强制同步更新邮件队列?:否
  • 本地网络:127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128
  • 邮箱大小限制:0 (0代表不限制)
  • 本地地址扩展字符:+
  • 要使用的互联网协议:所有

以上操作后将生成如下所示的配置项。

myhostname = mail.example.com

mydomain = example.com

myorigin = $mydomain

inet_interfaces = all

mydestination = $myhostname, localhost.$mydomain, localhost, $mydomain

mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128

此外,请将我们Ubuntu系统的主机名更改为上面配置的myhostname一致的名称。操作如下:

sudo hostnamectl set-hostname mail.example.com

## 用以下命令查看更改后的主机名hostname

hostname -f

## 我们还需要使用命令行文本编辑器(如 Nano)更新文件/etc/hosts

sudo nano /etc/hosts

## 更改如下:

127.0.0.1 localhost

127.0.0.1 mail.example.com

注意,上面的操作一步也不能少,否则失败的概率是极大的。

重启Postfix

sudo systemctl restart postfix

注意:如果您在单个服务器上托管多个域,则其他域也可以使用该mydestination指令传递给 Postfix 。

现在我们已将 Postfix 配置为仅从我们的服务器发送电子邮件,现在将通过向电子邮件地址发送示例消息来测试它。

测试

如果不是通过mailutils安装的Postfix, 则要进行安装邮件测试工具:

sudo apt-get install mailutils

之后,输入以下命令发送邮件测试:

echo "This is the body of the email" | mail -s "This is the subject line" user@example.com

把后面的user@example.com改成你的邮箱地址,可以是你的qq 邮箱、163邮件等等。是的,你没看错,一个最基本的邮箱服务已经搭建成功了。但这只是万里长征的第一步。它只能发邮件,不能收邮件,更谈不上安全等等。到你的邮箱里查看一下吧,这份邮件可能在你的垃圾邮箱里。不过不要担心,这条路我已经替你们给铲平了,接下来,跟着我往前走就可以了。下会见。

相关推荐

人人视频崩了怎么回事 人人视频下架了吗为什么刷不出来了

[海峡网]人人视频挂了吗下架了吗人人视频崩了怎么回事刷不出来了?人人视频发生了什么?怎么都看不成了,暂时还是永久?本来还以为是手机的问题,原来是客户端崩了难怪一直显示服务器异常!追着的美剧突然都下架...

502 bad gateway怎么解决?(502 bad gatewaynginxundefined)

相信许多小伙伴都遇到打开的网页提示502badgateway,502badgateway是提示用户该网址的网关错误,Web服务器作为网关或代理服务器时收到无效的响应,不管怎么刷新怎么重新输入地...

2岁男童眼睛被滴入强酸药水,医生亲身“试”药吓坏了……

平日里,小孩子爱玩爱闹是常事儿,但是大人的注意力如果时不时的掉线可就麻烦了。这一天,杭师大附院眼科陈舒主任医师像往常一样在接诊病人,然而一个孩子的哭闹声引起了她的注意,一群人神情焦灼,簇拥着一个孩子急...

3岁男童误将502胶当滴眼液,幸好妈妈及时处理,医生也为她点赞

小孩子由于心智还不够成熟,因此往往会做出一些危险的事情,甚至对自己造成伤害,这就需要家长的监督和保护。巧也不巧,日常生活中能够对孩子造成威胁的东西实在是太多了,堪称数不胜数,水笔、筷子、桌角,甚至刚拖...

5岁娃把502胶当眼药水滴眼中,爸爸的做法很机智,医生都称赞

文|哑铃妈妈家里有小孩子的一定要注意,在我们的家里存在很多的安全隐患,有的时候连家长都想不到的东西,竟然对孩子带来了伤害。5岁娃把502胶当眼药水滴眼中,爸爸的做法很机智,医生都点赞女孩乐乐长得可爱,...

宝宝误食502胶水,连忙送医救治,医生却夸宝妈做得好

有了孩子之后,妈妈都会变得神经敏感,生怕自己没有把孩子照顾好,但是毕竟一个人的经历是有限的,再加上孩子要是会走路,会说话之后对宝妈来说更是一种挑战,危及可能无时无刻不存在,这不,因为宝妈一转身的功夫,...

记一次Netty「直接内存溢出」导致线上网关项目宕机排查过程

作为一名Java开发者,我们都知道Java进程是运行在Java虚拟机上的,而Java进程要想正常运行则需要向计算机申请内存,其中主要为Java对象实例所占用的堆(heap)内存(当然还有其他的也会占用...

刚刚,突然崩了!网易云音乐紧急回应

今天下午#网易云音乐崩了#登上微博热搜第一在社交平台上,不少网友反馈,网易云音乐疑似崩溃。网友晒出网页端出现“502BadGateway”的服务器错误,同时网易云音乐的移动应用程序也无法正常使用。...

常见状态码(常见的状态码)

一二三四五原则:(即一:消息系列;二:成功系列;三:重定向系列;四:请求错误系列;五:服务器端错误系列。301状态码是永久移动302是临时移动304如果请求头中带有If-None-Match...

8岁男孩眼睛溅入502胶水,妈妈一番操作结果粘得更紧了

家有小孩的爸妈们肯定会多留个心眼照看虽然生活中已经时刻留意可能造成伤害的物品但有时一不留神幼小的孩子就会做出让人担心的事↓↓↓家住深圳的辰辰(化名)今年8岁了3月31日他在家里做手工时想要用未开封的5...

3岁娃滴502胶水在眼睛疼的尖叫,宝妈急中生智,保住孩子眼睛

但还好宝妈急中生智,连忙将孩子带到水龙头处,用水给孩子冲洗了一下眼睛,还用大量的生理盐水来给孩子清洗眼球,之后又立马将孩子送往医院,最后孩子的眼睛也没有什么大碍,拿了点药就能顺利出院了。而502胶水这...

网易云音乐回应App崩了:故障已陆续修复,补偿7天会员

2024年8月19日下午,多名网友反馈称,网易云音乐服务器疑似出现故障,登录网易云音乐APP后发现,个性化推荐和搜索功能均无法使用,并收到“获取数据失败”的提示。此外,网易云音乐的网页端也显示502错...

又崩了!不少人直接傻眼:太离谱!(台湾人到大陆后傻眼)

造车新势力哪吒汽车再被推向舆论风口。5月4日,话题#曝哪吒汽车APP断网#冲上微博热搜App断网无法使用从5月2日开始,陆续有多位网友反映哪吒汽车App断网,App控车无法使用。哪吒汽车App目前出现...

男子误把502胶水当眼药水!千万别犯这种低级错误!

你敢相信吗?有人竟然误把五零二胶水当成了眼药水滴进眼睛里。这可不是什么玩笑话,而是近日发生在武汉的一起真实事件。一名男子因此导致眼角膜严重受损,不得不紧急就医。据武汉大学附属爱尔眼科医院报道,这名男子...

502入眼危机!这份急救指南请牢记(502进入眼中怎么办)

502入眼,真实案例触目惊心生活中,502胶水是常用的黏合剂,以其强力黏合性备受青睐。但它一旦进入眼睛,后果不堪设想,下面这些真实案例,足以让我们警醒。曾有这样一则新闻,一位4岁女童在家玩耍时...

取消回复欢迎 发表评论: