研发网络应用的核心是写出能够运行在不同端系统和通过网络彼此交流的程序。
两种主流的应用体系结构:客户-服务器体系结构、对等体系结构。
客户-服务器体系:服务器是一个总是打开的主机,它为称为客户的主机提供服务。服务器具有固定的、周知的IP地址。服务器往往有数据中心构成。最典型的例子是web应用。
P2P体系:应用程序在主机对之间直接通信。P2P体系结构具有自扩展性,每个对等方在享受服务的同时也为系统提供服务能力。
网络应用程序由成对的进程组成,这些进程通过网络相互发送报文。对每对通信的进程,通常将两个进程之一称为“客户”,另一个进程称为“服务器”。在P2P体系中,下载文件的进程称为“客户”,上传文件的称为“服务器”。
进程通过称为套接字的软件接口向网络发送报文和从网络接收报文。
套接字是主机内应用层与运输层之间的接口。
IP地址是一个能唯一标识主机的32比特的量。
发送进程必须指定运行在主机上的接收进程。
应用程序的服务要求大体有4类:可靠数据传输、吞吐量、定时和安全性。
可靠数据传输:将数据正确、完整地从一端传输到另一端。邮件、文件传输等需要可靠数据传输,多媒体应用一般不需要。
吞吐量:在波动的网络中保证吞吐量。
定时:控制发送方到接收方地延迟。
安全性
因特网为应用程序提供了两个运输层协议:UDP、TCP。
TCP服务包括面向连接服务和可靠数据传输服务。
面向连接服务:在报文开始传输之前,TCP让客户和服务器交换运输层控制信息,称为“握手”。然后两个进程的套接字之间就建立了TCP联系。连接双方可以同时进行收发报文。应用程序结束报文发送后,TCP连接必须拆除。
可靠的数据传输服务:无差错、无冗余。
TCP协议还具有拥塞控制机制,当发送方和接收方之间出现网络拥塞时,TCP会抑制发送进程。
UCP服务仅提供最小服务,没有握手过程、不保证报文能送达接收进程、报文可能乱序到达、没有拥塞控制机制。
因特网运输协议不保证吞吐量和定时。
应用层协议定义了运行在不同端系统上的应用程序进程如何相互传递报文。
应用层协议定义了:
Web的应用协议是超文本传输协议(HTTP)。HTTP由一个客户程序和一个服务器程序组成,HTTP定义了报文的结构和交换报文的方式。
Web页面是由对象组成的。一个对象只是一个文件,如一个HTML文件、一个JPEG图形等,且它们可通过一个URL地址寻址。多数Web界面含有一个HTML基本文件和几个引用对象,HTML基本文件通过对象的URL地址引用页面中的其他对象。每个URL地址由两部分组成:存放对象的服务器主机名、对象的路径名(例如,http://www.someSchool.edu/someDepartment/picture.gif中,www.someSchool为主机名,/someDepartment/picture.gif为路径名)。
HTTP定义了Web客户向Web服务器请求Web页面的方式,以及服务器向客户传送Web页面的方式。
HTTP使用TCP作为它的支撑运输协议。HTTP客户首先发起一个与服务器的TCP连接,连接建立后,客户和服务器就可以通过自己的套接字发送和接受报文。
HTTP服务器不保存关于客户的任何信息,是一个无状态协议。
在许多因特网应用程序中,客户和服务器在一个相当长的时间内保持通信,客户在此期间会对服务器发出一系列请求。如果每个请求是经一个单独的TCP连接发送,则该应用程序称为使用非连续连接,如果所有请求经同一个TCP连接发送,称为持续连接。
HTTP技能使用非持续连接也能使用持续连接,默认使用持续连接。
在非持续连接中,每个TCP连接在服务器发送一个对象后关闭,每个TCP连接只传输一个请求报文和一个响应报文。
定义RRT(Round-Trip Time)为一个短分组从客户到服务器然后再返回客户所花费的时间。如上图所示,浏览器与服务器建立TCP连接涉及一次“三次握手”过程,即客户向服务器发送一个小TCP报文段,服务器用一个小TCP报文段做出确认和响应,最后客户向服务器返回确认。“三次握手”的前两次握手消耗了一个RRT时间,客户结合第三次握手向TCP连接发送一个HTTP请求报文,请求报文到达服务器后,服务器在该TCP连接上发送HTML文件。所以,总的响应时间为两个RRT时间加上服务器传输HTML文件的时间。
非持续连接有一些缺点:
在采用持续连接的情况下,服务器在发送响应后保持TCP连接打开,对对象的请求可以连续发出,不必等到响应(流水线)。一段时间未使用后,连接关闭。
上图为一个典型的HTTP请求报文。该报文由ASCII文本书写,由5行组成,每行由一个回车和换行符结束(最后一行还有一个额外的回车和换行符)。HTTP请求报文的第一行称为请求行,后面的行称为首部行。请求行有3个字段:方法字段、URL字段和HTTP版本字段。
在GET方法中,“实体体”为空,使用POST方法时需要使用实体体。
HTTP使用cookie来允许站点对用户进行跟踪。
如上图所示,cookie有4个组件:HTTP响应报文中的一个cookie首部行、HTTP请求报文中的一个cookie首部行、客户端系统保留的cookie文件(由浏览器管理)、位于Web站点的一个后端数据库。假设Susan使用PC上的IE浏览器上网,她首次访问Amazon.com,当请求报文到达Amazon Web服务器时,该Web站点产生一个唯一的识别码,并以此索引后端数据库中的一个表项。然后,Amazon Web服务器用一个包含Set cookie:
首部的HTTP响应报文对Susan的浏览器进行相应。Susan的浏览器收到响应报文时,它会根据Set cookie:
首部的内容在特定cookie文件中添加一行,该行包括服务器主机名和cookie识别码。当Susan再次浏览Amazon网页时,浏览器会查询cookie文件并抽取她对这个网站的识别码,并放到HTTP报文的cookie:
首部行中。这样,Amazon就可以跟踪Susan再Amazon站点的活动。
Web缓存器也叫代理服务器。Web服务器有自己的磁盘存储空间,保存着最近请求的对象的副本。Web缓存器既是客户也是服务器,由ISP购买并安装,可以减少客户请求的响应时间,减少机构的接入链路到因特网的通信量。
上图展示了电子邮件系统的总体情况。电子邮件系统由3部分组成:用户代理、邮件服务器、SMTP协议。
SMTP使用TCP可靠数据传输服务,由发送方的客户端和接收方的服务器端组成,每台邮件服务器上同时运行着客户端和服务器端。
SMTP用于从发送方的邮件服务器发送报文到被发送方的邮件服务器。
SMTP一般不使用中间邮件服务器发送邮件。如果上图中,Bob的邮件服务器没有开机,发送出的报文会留在Alice的邮件服务器上并等待进行新的尝试。
客户SMTP在25号端口建立一个到服务器SMTP的TCP连接。连接建立后,进行SMTP的握手阶段,SMTP客户指示发送方的邮件地址和接收方的邮件地址。当客户和服务器彼此“介绍”之后,客户发送报文。如果另有报文发送,就在相同的TCP连接上重复这种处理,否则TCP连接关闭。
相同点:持续连接。
不同点:
邮件报文由首部行和报文体构成。每个首部必须包含From:
和To:
首部行,首部行和报文体之间用空行分隔。
为什么不将报文由Alice的代理通过SMTP直接发送到Bob的邮件服务器呢?因为不通过Alice的邮件服务器进行中继,如果Bob的邮件服务器处于关闭状态,Alice的邮件将不能发送。采用Alice的邮件服务器作为中继后,Alice的服务器可以重复尝试向Bob的邮件服务器发送报文。
由于SMTP是推协议,所以Bob不能通过SMTP来获取邮件服务器上的邮件。
当用户代理打开了一个到邮件服务器110端口的TCP连接后,POP3开始工作。POP3的工作分为三个阶段:特许、事务处理、更新。特许阶段中,用户代理以明文发送用户名和口令;事务处理阶段中,用户代理取回报文,还可以对报文做删除标记、获取邮件的统计信息;更新阶段发生在客户发出quit命令后,这时,邮件服务器会删除那些有删除标记的报文。
服务器会对用户代理的命令做出回答(+OK
,-ERR
)。
list
命令要求邮件服务器列出所有存储的报文的长度。
使用“下载并删除”方式可能导致用户在一台设备上获取邮件后,不能再在其他的设备上获取邮件。
在用户代理和邮件服务器进行POP3会话期间,POP3服务器会保留一些状态信息(如哪些报文被标记删除)。但POP3服务器不会再会话过程中携带状态信息。
识别主机有两种方式:主机名、IP地址。DNS提供了主机名到IP地址转换的目录服务。DNS是一个由分层的DNS服务器实现的分布式数据库,是一个使得主机能够查询分布式数据库的应用层协议。DNS运行在UDP协议上,使用53号端口。
除了主机名到IP地址的转换外,DNS还提供了如下服务:
如果DNS服务器采用集中式设计,可能产生如下问题:
有3种类型的DNS服务器:根服务器、顶级域(TLD)服务器、权威服务器。根服务器提供TLD服务器的IP地址,TLD服务器提供权威服务器的IP地址,权威服务器将主机名映射为IP地址。
本地DNS服务器起代理作用,负责将用户的DNS请求转发到DNS服务器层次结构中。
上图为“递归+迭代”模式,在实践中较为常用
上图为纯递归模式。
当某个DNS服务器接收一个DNS回答时,它能将映射关系保存在本地。