24 辛苦的邮政 - SMTP¶
什么是通信?¶
什么是通信?这个可能是一个比较文绉绉的词,说白了就是计算机之间的交流,唠嗑。我们从出生开始就一直在唠嗑。所以你应该对这个词不陌生。你细想一下,你唠嗑是为了啥,是不是在交流我们的需求。而且唠嗑也是我们用来了解某人的方法,比如你看上了一位美女,你直接要微信是不是比较鲁莽,除非你和老师一样帅(开玩笑)。
你是不是应该先去聊聊天,唠唠嗑,然后再要微信。在微信上可以继续的聊天,交流你们之间的感受。因此,交流是将我们的想法与其他人联系起来的机制。
好,现在不要想小姐姐了,想想比较实际的。思考一下每天与你们交流的所有人。和工作中的同事你们会交流什么?是不是会包含项目的进展,项目取得了哪些成功?潜在的困难是什么?回到家中,你还会与朋友和家人就生活中发生的事情进行交流,可能是重要的事,也可能只是一个有趣的事情,也可能是令人兴奋的事情。现在微信比较流行了,但是使用电话也是一种很好的交流方式。你可以给你的朋友打电话。或者是给你刚认识的小姐姐打电话,你先介绍你自己,让这个美女知道他正在和刚才认识的那个帅哥说话。然后你可能会说,嘿,听说市中心有一家新的咖啡店开业?你要不要尝试一下?然后你是不是就和小姐姐有了一次潜在约会的机会。当然这里不是教你怎么约小姐姐,就像电话可以帮助我们交流和交换思想一样,互联网也是一种交流机制(这个才是我们的主题,虽然刚才讲的东西可能才是你最关心的,现在把思想收一下,回到主题上来)。它在我们的生活中发挥着巨大作用,也真真切切的影响着我们如今的沟通方式。只要考虑一下你每天使用 Internet 在计算机上完成的所有工作即可。你可以创建文档和 PPT 来更新你的项目进度,并与同事共享该信息。你可以浏览互联网以阅读自己喜欢的小说。看自己喜欢的小电影。阅读有关电视节目的信息(比如巡回检察组,我之前天天追剧到不行),查看电影放映时间好约小姐姐一起,阅读或查找餐厅评论(去哪里约小姐姐),还可以使用互联网购物。你细想一下所有这些活动都可以通过使用协议来实现。协议是你的计算机用于与包含我们要使用的所有信息的其他网络进行对话的机制。
SMTP 的历史¶
在 1960 年代的计算机初期,人们不得不使用大型主机才能相互通信。下面这个老照片就是大型计算机,你能想象有一个这样的计算机在你家里吗?
我们今天拥有的小型便携式笔记本电脑,平板电脑和智能手机在那个年代是根本不存在的。大多数大型机是由大学,大型企业和政府所有的。随着越来越多的大型机变得普及,所有者也希望与其他大型机所有者建立联系。就好像单机游戏再好玩,你也会希望和别人一起玩,对不对。所以,他们需要找一个办法来进行沟通。因此,在此期间,这些人创建了许多不同的协议,并使用这些协议来允许所有这些大型机相互通信。最终,为了大家能一起玩”魔兽世界“的这个愿望,SMTP 协议诞生了。
SMTP 协议允许这些大型机作为邮件服务器。因为文本能够通过连接的网络从一个大型机发送到另一个大型机。有时,文本可以直接发送给收件人。但有时则要困难一些,文本必须通过几个大型机才能到达目的地。因此,随着越来越多的大型机连接到网络,要传送的文本到达其目的地变得越来越复杂。 SMTP 作为一个协议,可用于在使用大型机的人员之间传输这些文本。随着 SMTP 协议在其早期的发展,它已经进化了很多,正因如此,它也广泛的应用了。 SMTP 协议运行得非常好,最终在 1982 年 8 月成为电子邮件通信的全球标准。在 1982 年,创建了 RFC 821(RFC 821 就是提供了有关什么是 SMTP 以及其如何工作的说明手册)。多年来,SMTP 协议还在不断的完善自己,它在 2008 年 10 月又对自己进行了更新(RFC 5321)
SMTP 是什么?¶
好,了解了 SMTP 的历史,就好像你看了 SMTP 的出生证一样,知道他是什么时候出生的,那我们来认真的了解一下这位好少年,看看他究竟优秀在哪?SMTP 是一个用户用于发送电子邮件时使用的协议。该协议对应的端口是 25,这是所有电子邮件系统都知道的标准,那标准是哪来的呢?当然是因为我们上面提到的 RFC 821 和 5321。
SMTP 协议会在你和小伙伴使用的电子邮件系统之间创建连接或管道。就像当你看到小姐姐时,你会说,嘿,美女,你好。然后,这个小姐姐会回头看你说,嘿,你好,帅哥。这个回头其实也就是我们说的 ACK(确认)。这个 ACK 就打开了你们俩之间的沟通渠道,使你们可以进行对话。你可能会说小姐姐你眼睛真漂亮,小姐姐会笑一下然后说是不是想加微信?这种我们日常每天都进行的来来回回也发生在邮件系统中。你可能说中文,我和同事说英文,那邮件系统呢?使用的是 SMTP 协议作为其语言。 SMTP 协议允许在邮件服务器之间发送一堆基于文本的命令。这些命令会建立连接并允许会话的确认也就是 ACK。我听到你了,你还挺可爱的,这种对话是你向别人发送电子邮件的基本机制。
现在,我们举个例子,比如你要给你的金主爸爸(王老板)发送电子邮件。当你想向王老板发送电子邮件时,你的电子邮件客户端(比如我们熟悉的 Microsoft Outlook)会将消息发送到电子邮件服务器。然后,此服务器与王老板使用的另一个邮件服务器建立连接。每当你发送电子邮件时,都会发生一系列特定的事件。首先,你的 SMTP 客户端或 Outlook 将联系你的 SMTP 服务器,以便它可以建立与王老板的 SMTP 服务器的连接。但是,为了建立此会话,我需要找到王老板的 SMTP 服务器所在的位置。如何到达那里呢?你想一下?是不是要使用 DNS。具体来说,你的电子邮件服务器将向 DNS 询问王老板的域名的邮件交换记录。假设这个金主爸爸是京东的。那你就要去询问 JD.COM 的记录。然后,DNS 服务器将使用该 MX 记录答复我们的邮件服务器,该记录将提供王老板的 SMTP 服务器的 IP 地址。该 IP 地址是王老板的 SMTP 服务器所在的 Internet 上的虚拟地址。
SMTP 具体的工作流程¶
我们来分解一下 SMTP 对话的实际工作流程。首先,电子邮件服务器需要通过查询 DNS 来查找金主爸爸的 SMTP 服务器的 MX 记录。一旦获得,邮件服务器将通过端口 25 尝试建立与 jd.com 的连接。一旦建立了到 jd 服务器的连接,jd 的服务器就会通过确认(ACK)响应你的邮件服务器。通常,此确认采用 SMTP 服务器的完全限定域名的形式(220 mail.jd.com)。然后,你的邮件服务器将发送一个 ehlo 命令。 金主爸爸的 SMTP 服务器将对此进行确认(ACK)并打个招呼。然后,从命令发送邮件,该命令提供了你的电子邮件地址(MAIL FROM shuaige@xxx.com)。接着,jd 的服务器将对此进行确认,并指示可以继续进行对话。已经在监听了。然后,你的 SMTP 客户端将发送一个收件人命令(RCPT wanglaoban@jd.com)。此时,金主爸爸的服务器以 250 OK(250 Recipient OK)的响应 ACK。现在,你的 SMTP 服务器希望了解邮件的内容,因此服务器发送了 DATA 命令。一旦发送了 DATA 命令,构成正文消息的每一行文本都会被发送到王老板那。为了向王老板的服务器发出已完成该消息的信号,我已经说了我需要说的所有内容,我按回车键换了一个新行,然后输入一个句号,然后再换回另一行。因此,新行,句号,新行。这个就是暗号了。然后,金主爸爸的 SMTP 服务器回复我的 SMTP 服务器(250 Message accepted for delivery),让你知道他已经知道了一切。他会传达你的信息。至此,完成了邮件的传递。你的 SMTP 服务器发送了 Quit 命令,从而结束了对话。或者,你可以将其视为挂断电话。我画一下图就是这样
Microsoft Exchange¶
我们现在来看一个具体的例子呀。outook 大家应该都不陌生。那我们就以 Microsoft Exchange 为例。Microsoft Exchange,简单地说,它是一种服务器端允许客户传递消息的产品。你可以使用 Microsoft Exchange 发送和接收电子邮件。实际上你可能已经是 Exchange 的忠实客户,每天都在使用 Exchange,甚至可能没有意识到。
假如正坐在办公桌旁工作,并且收到 Microsoft Outlook 中一位同事的电子邮件,要求你提供有关你正在一起工作的项目的信息。使用 Outlook,你可以回复邮件,在午餐期间,你可以继续使用手机与同事回复邮件(不要问我为什么你们不能当面谈,也许你同事是一个漂亮的小姐姐)。但是,整天你都无法获得所需的答案,于是你终于鼓足勇气,安排一次面对面的会议。你创建了一个会议请求,并将你的同事添加到该请求中,你找到了适合双方的时间,然后发送会议邀请。在几分钟之内,你会收到一封电子邮件通知,告知小姐姐已接受你的会议请求。这一切听起来熟悉吗(我们在美国的工作流程是这样的哦)?如果是这样,则你可能正在使用 Microsoft Exchange 的多个功能。
Microsoft Exchange Server 是世界上最受欢迎和功能最强大的邮件服务器之一。普遍用于已经使用 Active Directory(如果你做过 windows 运维的话,你会知道,如果不知道也没关系)架构的企业。你是否用过称为 Outlook 的 Microsoft Office 应用程序?Exchange 就是支撑 Microsoft Outlook 这个强大功能软件的背后的那个男人。你可以将电子邮件,日历和联系人通过 Microsoft Outlook 发送到电脑上,智能手机上,也可以从 Web 浏览器访问这些项目(如果你做过相关的开发,你就会发现这是一个很复杂的东西)。所以,使用 Microsoft Exchange 的公司的员工可以从世界任何地方访问他们的电子邮件。无论他们在办公室还是在旅途中,他们都可以进行交流(比如说我可以回中国工作的时候,仍然访问我的邮件)你可以在受支持的 Windows 服务器版本上安装 Exchange,该版本通常位于 Active Directory 服务器所在的公司数据中心中。
Active Directory¶
Active Directory 是 Exchange 基础结构中的重要组成部分,你可以使用两个关键工具来管理 Exchange 环境,这两个工具是基于 Web 的 Exchange Admin Center 和使用 PowerShell 的 Exchange Management。 Exchange 采用简化的方法来实现高可用性,这意味着降低了实现高可用所需的复杂性。 Exchange 与 Active Directory 紧密结合。没有 Active Directory,Exchange 甚至无法运行。Exchange 使用 Active Directory 将帐户与邮箱相关联,就像你用来登录工作 PC 的帐户一样。它使用 Active Directory 站点来确定将邮件路由到其他 Exchange 服务器的最佳方法。 Exchange 软件使用许多不同的协议来实现传递电子邮件的功能。诸如 HTTP 和 HTTPS 之类的协议用于 Web 服务。 LDAP 用于身份验证。然后是几种不同的客户端连接协议,例如 POP 和 IMAP 和 SMTP。作为 Exchange 的核心,数据库技术提供了中央存储,可以为用户发送和接收电子邮件进行存储。该数据库还可以在数据库中跟踪会议和其他与日历相关的任务。微软早在 1996 年就一直公开发行 Exchange 的第一个品牌版本。这说明 Exchange 是一款非常成熟且可靠的软件。如果你使用 Exchange 为用户提供邮件服务,那么只要你设置正确且配置正确,应该不会出现任何的环境问题。
基本上你不做运维的话。你不太会用到 powershell,Active Directory 等等。我也不知道我是幸运还是不幸运曾经使用过一段 Powershell 和 Active Directory。这也算是一段经历吧。



