[叶子]在自己的服务器上搭建自己的邮箱

2022-10-24 13:53:52 浏览数 (1)

前言:

这可能是我写的文章中为数不多的有全程完整截图的、不是在完工后再来回忆的文章,但并不是因为我一开始就打算写这篇教程,而是搭建邮箱这玩意我做了”双份“——先在我自己的服务器上面给我自己搭建,确认成功了、各项功能都正常了我才在 @gaoice 的服务器上面搭建,并同时边搭建边截图,之所以我写这个,是因为我在给自己的服务器搭建的时候走了太多的弯路,过程太曲折,以至于在完工之后我觉得有必要写这么一篇文章来记录这个过程。但是我并不打算在这篇文章里面详细讲我走的弯路的具体情况,这篇文章主要还是讲搭建这件事本身。

废话不多说了,现在开始正文部分。宝塔面板上面本来有一个邮局插件是可以用于搭建邮箱的,但奈何它总能给我整出点新花样,我便只好选择放弃它了。首先要把端口给空出来,下面贴出poste官方文档里面安装指导篇给出的需要的端口列表,我直接把原文贴了过来,如果看不懂请自行找翻译工具

Ports which are opened by poste.io:

Port number

Purpose

25

SMTP – mostly processing incoming mails

80

HTTP – redirect to https (see options) and authentication for Let’s encrypt service

110

POP3 – standard protocol for accessing mailbox, STARTTLS is required before client auth

143

IMAP – standard protocol for accessing mailbox, STARTTLS is required before client auth

443

HTTPS – access to administration or webmail client

465

SMTPS – Legacy SMTPs port

587

MSA – SMTP port used primarily for email clients after STARTTLS and auth

993

IMAPS – alternative port for IMAP encrypted since connection

995

POP3S – encrypted POP3 since connections

4190

Sieve – remote sieve settings

而三个关于邮件的协议以及它们的加密版本使用的7个端口,宝塔邮局里面的组件至少占了3个(SMTP的25,IMAP的143,还有pop3的110),在设置了ssl证书之后占用的端口会再多出三个(SMTPs的465,IMAPs的993,还有pop3s的995),由于我是从宝塔邮局转别的邮件,所以得先在宝塔的设置里面把相关的服务先停了

停了之后宝塔这边会显示”已停止“,为了确定是真的停了,在本地用nmap扫一下这些需要用到的端口

显示”filtered“意思是防火墙或者安全组没有放通这个端口,显示closed的话就是端口已经放通了,但是没有程序在监听这个端口,然后就按照腾讯云的文档去设置docker的镜像源,设置成腾讯云的内网源

然后通过ssh连接到服务器上,把需要用到的docker镜像给pull下来,上一步的设置镜像源就是为了在这一步省点时间,毕竟走腾讯的内网,会快很多

然后根据官方的安装指导,结合这篇帖子,根据自己的需要以及实际情况,拼凑出完整的一条docker run命令。我这里为了后期更改启动命令方便,我把启动命令设置成了一个放在映射目录中的脚本文件,这样如果后期我需要更改容器的启动命令,那我只需要更改这个脚本的内容就行了

目前脚本里面的内容有点简陋,就一条命令,不过这是因为我暂时没有需要更改它的启动命令,就让它启动一个bash先

在脚本放置完毕、启动命令拼凑完成之后,将启动命令粘贴到ssh里面执行,执行完成之后如果一切顺利,用docker ps命令能看到大概这样的输出

接着在本地再拿nmap扫一下,跟刚才相对比,除了那两个filtered的端口依旧是filtered之外,其它的端口都由close转为open,open表示端口放通了并且有程序在监听这个端口

在上面的命令中,我把容器内的80端口映射到宿主机的8000端口并禁用了https,但我并不想放通8000端口,放通的端口越多,潜在的安全风险就越多,所以接下来就该设置ng的反代了,在宝塔新建一个网站(由于我这次搭建,映射出来的目录本身就是在一个网站下面,网站也事先建好了故跳过这步),PHP版本选择”纯静态“,然后到反向代理那里添加一条环回地址8000端口的反向代理,然后去配置ssl相关的设置

在一切都设置完成之后就可以通过域名访问刚刚搭建的邮箱,由于是首次使用,所以它会先跳到首次使用的设置页面,设置好邮件服务器的主机名和管理员邮箱的地址与密码,这里需要注意的是主机名最好是设置的跟域名一样,有条件的给服务器的IP上ptr记录会更好(腾讯这边的ptr记录得花钱买,1k5 元/年/5条,这个价格令我望而生畏,买不起),不然容易进垃圾箱(虽说由于未知原因,这个 @gaoice 的自建邮箱还是逃不过Gmail的垃圾箱,而我自己的就没事。。。)

在完成初始配置之后去到”virtual domains“设置里面点你域名右边的”show“,然后点”create new key“

如果一切顺利,它顶部会显示”new dkim keys generated,update your dns settings“,并在刚才显示”create new key“的地方显示你的dkim记录

然后去dns服务提供商那边按照poste给你的信息去添加一条txt的解析,顺带把spf和dmarc的txt记录也添加了

在完事之后去这里验证一下你的dkim等设置,等这里显示dkim、spf、dmarc都pass了之后再去mail-tester那边测试

因为mailtester这边免费用户一天只能测三次,而上面的dkim测试就没有限制,故不要因为dkim、spf、dmarc等问题导致的意外而浪费每天仅有的三次测试机会

最后来一张绝望的Gmail截图

写在最后:

我之前在自己服务器上面搭建的时候,最开始用的宝塔,在刚开始搭建的时候是能收到邮件的,那个时候我25端口是没有放通的好像,但是不知道什么时候开始,突然收不到邮件,我以为是宝塔发疯,便上网搜寻其它的类似的组件包,上网搜索过很多资料,最后唯一对我有用的就是这篇,看了这篇之后考虑过ewomail、iredmail、mailcow和poste.io,ireadmail和ewomail都是丢给你一个脚本让你自己在服务器上面跑,ewomail同时还是开源的,文档也很详细,也免费提供一定的技术支持,而ireadmail不知道是否开源,文档也没怎么详细讲,最关键似乎不提供官方免费技术支持,网上也没多少相关资料,mailcow搞不太懂,最开始是先尝试的ewomail,结果最后登不上去,只好再找别的,后来发现poste.Io的文档也挺详细,而且官方支持docker部署,就照着官方文档结合网上的一些资料搭建起来了,不过刚搭建好也是收不到邮件,后来找腾讯云的客服才知道,25端口的入方向是得放通的,放通25端口之后,就一切顺利了。但是很多IDC是默认阻塞掉25端口的出方向的,不过这实测并不太影响发邮件,25端口如果真心想搭建邮件服务器的话出方向的影响并不大,正如poste官方文档里面客户端设置的示例中说所的一样

Do not use port 25 at all as it is reserved for communication for remote mailservers only. Even if it will work you might be affected by unnecessary connection testing and various slowdowns. Some ISPs also blocks customers outbound connections to 25 due fighting with SPAM so it might be impossible to connect to your mailserver from various places. Connections to port 465/587 are mostly tolerated. 翻译:完全不要使用端口 25,因为它仅用于远程邮件服务器的通信。即使它会起作用,您也可能会受到不必要的连接测试和各种减速的影响。由于与垃圾邮件的斗争,一些 ISP 还会阻止客户与 25 的出站连接,因此可能无法从各个地方连接到您的邮件服务器。大多数情况下可以容忍连接到端口 465/587。

实测在配置了ssl之后,25端口在出方向的阻塞并不影响发件,但是入方向会影响收件,不过这个是在自己的可控范围内,因为25端口的入站方向是由自己控制的

参考资料:

  • Poste.io官方文档/开始使用
  • Poste.io官方文档/客户端设置
  • 轻量应用服务器 安装 Docker 并配置镜像加速源 – 最佳实践 – 文档中心 – 腾讯云#使用腾讯云 Docker 镜像源加速镜像下载
  • 邮件服务器 Poste 五分钟搭建 | NewPants

0 人点赞