计算机网络课件-谢希仁(第六章).ppt
《计算机网络课件-谢希仁(第六章).ppt》由会员分享,可在线阅读,更多相关《计算机网络课件-谢希仁(第六章).ppt(204页珍藏版)》请在冰点文库上搜索。
![计算机网络课件-谢希仁(第六章).ppt](https://file1.bingdoc.com/fileroot1/2023-5/7/0a57d873-be2b-407f-b9d4-fcfd02de4987/0a57d873-be2b-407f-b9d4-fcfd02de49871.gif)
计算机网络(第5版),第6章应用层,第6章应用层,6.1域名系统DNS6.1.1域名系统概述6.1.2因特网的域名结构6.1.3域名服务器6.2文件传送协议6.2.1FTP概述6.2.2FTP的基本工作原理6.2.3简单文件传送协议TFTP,第6章应用层(续),6.3远程终端协议TELNET6.4万维网WWW6.4.1概述6.4.2统一资源定位符URL6.4.3超文本传送协议HTTP6.4.4万维网的文档6.4.5万维网的信息检索系统,第6章应用层(续),6.5电子邮件6.5.1电子邮件概述6.5.2简单邮件传送协议SMTP6.5.3电子邮件的信息格式6.5.4邮件读取协议POP3和IMAP6.5.5基于万维网的电子邮件6.5.6通用因特网邮件扩充MIME,第6章应用层(续),6.6动态主机配置协议DHCP6.7简单网络管理协议SNMP6.7.1网络管理的基本概念6.7.2管理信息结构SMI6.7.3管理信息库MIB6.7.4SNMP的协议数据单元和报文6.8应用进程跨越网络的通信6.8.1系统调用和应用编程接口6.8.2几种常用的系统调用,应用层协议的特点,每个应用层协议都是为了解决某一类应用问题,而问题的解决又往往是通过位于不同主机中的多个应用进程之间的通信和协同工作来完成的。
应用层的具体内容就是规定应用进程在通信时所遵循的协议。
应用层的许多协议都是基于客户服务器方式。
客户(client)和服务器(server)都是指通信中所涉及的两个应用进程。
客户服务器方式所描述的是进程之间服务和被服务的关系。
客户是服务请求方,服务器是服务提供方。
6.1域名系统DNS6.1.1域名系统概述,许多应用层软件经常直接使用域名系统DNS(DomainNameSystem),但计算机的用户只是间接而不是直接使用域名系统。
因特网采用层次结构的命名树作为主机的名字,并使用分布式的域名系统DNS。
名字到IP地址的解析是由若干个域名服务器程序完成的。
域名服务器程序在专设的结点上运行,运行该程序的机器称为域名服务器。
6.1.2因特网的域名结构,因特网采用了层次树状结构的命名方法。
任何一个连接在因特网上的主机或路由器,都有一个唯一的层次结构的名字,即域名。
域名的结构由标号序列组成,各标号之间用点隔开:
.三级域名.二级域名.顶级域名各标号分别代表不同级别的域名。
域名只是个逻辑概念,域名只是个逻辑概念,并不代表计算机所在的物理地点。
变长的域名和使用有助记忆的字符串,是为了便于人来使用。
而IP地址是定长的32位二进制数字则非常便于机器进行处理。
域名中的“点”和点分十进制IP地址中的“点”并无一一对应的关系。
点分十进制IP地址中一定是包含三个“点”,但每一个域名中“点”的数目则不一定正好是三个。
顶级域名TLD(TopLevelDomain),
(1)国家顶级域名nTLD:
如:
.cn表示中国,.us表示美国,.uk表示英国,等等。
(2)通用顶级域名gTLD:
最早的顶级域名是:
.com(公司和企业).net(网络服务机构).org(非赢利性组织).edu(美国专用的教育机构().gov(美国专用的政府部门).mil(美国专用的军事部门).int(国际组织),顶级域名TLD(续),(3)基础结构域名(infrastructuredomain):
这种顶级域名只有一个,即arpa,用于反向域名解析,因此又称为反向域名。
新增加了下列的通用顶级域名,.aero(航空运输企业).biz(公司和企业).cat(加泰隆人的语言和文化团体).coop(合作团体).info(各种情况).jobs(人力资源管理者).mobi(移动产品与服务的用户和提供者).museum(博物馆).name(个人).pro(有证书的专业人员).travel(旅游业),因特网的域名空间,根,6.1.3域名服务器,一个服务器所负责管辖的(或有权限的)范围叫做区(zone)。
各单位根据具体情况来划分自己管辖范围的区。
但在一个区中的所有节点必须是能够连通的。
每一个区设置相应的权限域名服务器,用来保存该区中的所有主机的域名到IP地址的映射。
DNS服务器的管辖范围不是以“域”为单位,而是以“区”为单位。
区的不同划分方法举例,域,区,abc,x,u,v,w,t,y,(a)区=域,com,edu,org,根,树状结构的DNS域名服务器,根域名服务器,org域名服务器,com域名服务器,edu域名服务器,域名服务器,abc公司有两个权限域名服务器,权限域名服务器,根域名服务器,顶级域名服务器,域名服务器,域名服务器有以下四种类型,根域名服务器顶级域名服务器权限域名服务器本地域名服务器,根域名服务器最高层次的域名服务器,根域名服务器是最重要的域名服务器。
所有的根域名服务器都知道所有的顶级域名服务器的域名和IP地址。
不管是哪一个本地域名服务器,若要对因特网上任何一个域名进行解析,只要自己无法解析,就首先求助于根域名服务器。
在因特网上共有13个不同IP地址的根域名服务器,它们的名字是用一个英文字母命名,从a一直到m(前13个字母)。
根域名服务器共有13套装置(不是13个机器),这些根域名服务器相应的域名分别是到2006年底全世界已经安装了一百多个根域名服务器机器,分布在世界各地。
这样做的目的是为了方便用户,使世界上大部分DNS域名服务器都能就近找到一个根域名服务器。
举例:
根域名服务器f的地点分布图,根域名服务器并不直接把域名直接转换成IP地址。
在使用迭代查询时,根域名服务器把下一步应当找的顶级域名服务器的IP地址告诉本地域名服务器。
共40个机器,顶级域名服务器(即TLD服务器),这些域名服务器负责管理在该顶级域名服务器注册的所有二级域名。
当收到DNS查询请求时,就给出相应的回答(可能是最后的结果,也可能是下一步应当找的域名服务器的IP地址)。
权限域名服务器,这就是前面已经讲过的负责一个区的域名服务器。
当一个权限域名服务器还不能给出最后的查询回答时,就会告诉发出查询请求的DNS客户,下一步应当找哪一个权限域名服务器。
本地域名服务器,本地域名服务器对域名系统非常重要。
当一个主机发出DNS查询请求时,这个查询请求报文就发送给本地域名服务器。
每一个因特网服务提供者ISP,或一个大学,甚至一个大学里的系,都可以拥有一个本地域名服务器,这种域名服务器有时也称为默认域名服务器。
提高域名服务器的可靠性,DNS域名服务器都把数据复制到几个域名服务器来保存,其中的一个是主域名服务器,其他的是辅助域名服务器。
当主域名服务器出故障时,辅助域名服务器可以保证DNS的查询工作不会中断。
主域名服务器定期把数据复制到辅助域名服务器中,而更改数据只能在主域名服务器中进行。
这样就保证了数据的一致性。
域名的解析过程,主机向本地域名服务器的查询一般都是采用递归查询。
如果主机所询问的本地域名服务器不知道被查询域名的IP地址,那么本地域名服务器就以DNS客户的身份,向其他根域名服务器继续发出查询请求报文。
本地域名服务器向根域名服务器的查询通常是采用迭代查询。
当根域名服务器收到本地域名服务器的迭代查询请求报文时,要么给出所要查询的IP地址,要么告诉本地域名服务器:
“你下一步应当向哪一个域名服务器进行查询”。
然后让本地域名服务器进行后续的查询。
本地域名服务器采用迭代查询,顶级域名服务器,权限域名服务,本地域名服务器,根域名服务器,迭代查询,递归查询,需要查找的IP地址,本地域名服务器采用递归查询(比较少用),顶级域名服务器,权限域名服务,本地域名服务器,根域名服务器,递归查询,递归查询,需要查找的IP地址,名字的高速缓存,每个域名服务器都维护一个高速缓存,存放最近用过的名字以及从何处获得名字映射信息的记录。
可大大减轻根域名服务器的负荷,使因特网上的DNS查询请求和回答报文的数量大为减少。
为保持高速缓存中的内容正确,域名服务器应为每项内容设置计时器,并处理超过合理时间的项(例如,每个项目只存放两天)。
当权限域名服务器回答一个查询请求时,在响应中都指明绑定有效存在的时间值。
增加此时间值可减少网络开销,而减少此时间值可提高域名转换的准确性。
6.2文件传送协议6.2.1FTP概述,文件传送协议FTP(FileTransferProtocol)是因特网上使用得最广泛的文件传送协议。
FTP提供交互式的访问,允许客户指明文件的类型与格式,并允许文件具有存取权限。
FTP屏蔽了各计算机系统的细节,因而适合于在异构网络中任意计算机之间传送文件。
RFC959很早就成为了因特网的正式标准。
文件传送并非很简单的问题,网络环境中的一项基本应用就是将文件从一台计算机中复制到另一台可能相距很远的计算机中。
初看起来,在两个主机之间传送文件是很简单的事情。
其实这往往非常困难。
原因是众多的计算机厂商研制出的文件系统多达数百种,且差别很大。
6.2.2FTP的基本工作原理,网络环境下复制文件的复杂性:
(1)计算机存储数据的格式不同。
(2)文件的目录结构和文件命名的规定不同。
(3)对于相同的文件存取功能,操作系统使用的命令不同。
(4)访问控制方法不同。
FTP特点,文件传送协议FTP只提供文件传送的一些基本的服务,它使用TCP可靠的运输服务。
FTP的主要功能是减少或消除在不同操作系统下处理文件的不兼容性。
FTP使用客户服务器方式。
一个FTP服务器进程可同时为多个客户进程提供服务。
FTP的服务器进程由两大部分组成:
一个主进程,负责接受新的请求;另外有若干个从属进程,负责处理单个请求。
主进程的工作步骤如下,打开熟知端口(端口号为21),使客户进程能够连接上。
等待客户进程发出连接请求。
启动从属进程来处理客户进程发来的请求。
从属进程对客户进程的请求处理完毕后即终止,但从属进程在运行期间根据需要还可能创建其他一些子进程。
回到等待状态,继续接受其他客户进程发来的请求。
主进程与从属进程的处理是并发地进行。
两个连接,控制连接在整个会话期间一直保持打开,FTP客户发出的传送请求通过控制连接发送给服务器端的控制进程,但控制连接不用来传送文件。
实际用于传输文件的是“数据连接”。
服务器端的控制进程在接收到FTP客户发送来的文件传输请求后就创建“数据传送进程”和“数据连接”,用来连接客户端和服务器端的数据传送进程。
数据传送进程实际完成文件的传送,在传送完毕后关闭“数据传送连接”并结束运行。
FTP使用的两个TCP连接,控制进程,FTP客户端,FTP服务器端,因特网,TCP控制连接,TCP数据连接,用户界面,控制进程,数据传送进程,数据传送进程,当客户进程向服务器进程发出建立连接请求时,要寻找连接服务器进程的熟知端口(21),同时还要告诉服务器进程自己的另一个端口号码,用于建立数据传送连接。
接着,服务器进程用自己传送数据的熟知端口(20)与客户进程所提供的端口号码建立数据传送连接。
由于FTP使用了两个不同的端口号,所以数据连接与控制连接不会发生混乱。
两个不同的端口号,使协议更加简单和更容易实现。
在传输文件时还可以利用控制连接(例如,客户发送请求终止传输)。
使用两个不同端口号的好处,NFS采用另一种思路,NFS允许应用进程打开一个远地文件,并能在该文件的某一个特定的位置上开始读写数据。
NFS可使用户只复制一个大文件中的一个很小的片段,而不需要复制整个大文件。
对于上述例子,计算机A的NFS客户软件,把要添加的数据和在文件后面写数据的请求一起发送到远地的计算机B的NFS服务器。
NFS服务器更新文件后返回应答信息。
在网络上传送的只是少量的修改数据。
6.2.3简单文件传送协议TFTP(TrivialFileTransferProtocol),TFTP是一个很小且易于实现的文件传送协议。
TFTP使用客户服务器方式和使用UDP数据报,因此TFTP需要有自己的差错改正措施。
TFTP只支持文件传输而不支持交互。
TFTP没有一个庞大的命令集,没有列目录的功能,也不能对用户进行身份鉴别。
TFTP的主要特点是,
(1)每次传送的数据PDU中有512字节的数据,但最后一次可不足512字节。
(2)数据PDU也称为文件块(block),每个块按序编号,从1开始。
(3)支持ASCII码或二进制传送。
(4)可对文件进行读或写。
(5)使用很简单的首部。
TFTP的工作很像停止等待协议,发送完一个文件块后就等待对方的确认,确认时应指明所确认的块编号。
发完数据后在规定时间内收不到确认就要重发数据PDU。
发送确认PDU的一方若在规定时间内收不到下一个文件块,也要重发确认PDU。
这样就可保证文件的传送不致因某一个数据报的丢失而告失败。
TFTP的工作很像停止等待协议,在一开始工作时。
TFTP客户进程发送一个读请求PDU或写请求PDU给TFTP服务器进程,其熟知端口号码为69。
TFTP服务器进程要选择一个新的端口和TFTP客户进程进行通信。
若文件长度恰好为512字节的整数倍,则在文件传送完毕后,还必须在最后发送一个只含首部而无数据的数据PDU。
若文件长度不是512字节的整数倍,则最后传送数据PDU的数据字段一定不满512字节,这正好可作为文件结束的标志。
6.3按远程终端协议TELNET,TELNET是一个简单的远程终端协议,也是因特网的正式标准。
用户用TELNET就可在其所在地通过TCP连接注册(即登录)到远地的另一个主机上(使用主机名或IP地址)。
TELNET能将用户的击键传到远地主机,同时也能将远地主机的输出通过TCP连接返回到用户屏幕。
这种服务是透明的,因为用户感觉到好像键盘和显示器是直接连在远地主机上。
客户服务器方式,现在由于PC机的功能越来越强,用户已较少使用TELNET了。
TELNET也使用客户服务器方式。
在本地系统运行TELNET客户进程,而在远地主机则运行TELNET服务器进程。
和FTP的情况相似,服务器中的主进程等待新的请求,并产生从属进程来处理每一个连接。
TELNET使用网络虚拟终端NVT格式,因特网,TCP连接,客户端,服务器端,使用客户端的格式,使用服务器端的格式,使用NVT格式,客户,服务器,网络虚拟终端NVT格式,客户软件把用户的击键和命令转换成NVT格式,并送交服务器。
服务器软件把收到的数据和命令,从NVT格式转换成远地系统所需的格式。
向用户返回数据时,服务器把远地系统的格式转换为NVT格式,本地客户再从NVT格式转换到本地系统所需的格式。
6.4万维网WWW6.4.1万维网概述,万维网WWW(WorldWideWeb)并非某种特殊的计算机网络。
万维网是一个大规模的、联机式的信息储藏所。
万维网用链接的方法能非常方便地从因特网上的一个站点访问另一个站点,从而主动地按需获取丰富的信息。
这种访问方式称为“链接”。
万维网提供分布式服务,万维网站点A,万维网站点C,万维网站点E,万维网站点D,万维网站点B,超媒体与超文本,万维网是分布式超媒体(hypermedia)系统,它是超文本(hypertext)系统的扩充。
一个超文本由多个信息源链接成。
利用一个链接可使用户找到另一个文档。
这些文档可以位于世界上任何一个接在因特网上的超文本系统中。
超文本是万维网的基础。
超媒体与超文本的区别是文档内容不同。
超文本文档仅包含文本信息,而超媒体文档还包含其他表示方式的信息,如图形、图像、声音、动画,甚至活动视频图像。
万维网的工作方式,万维网以客户服务器方式工作。
浏览器就是在用户计算机上的万维网客户程序。
万维网文档所驻留的计算机则运行服务器程序,因此这个计算机也称为万维网服务器。
客户程序向服务器程序发出请求,服务器程序向客户程序送回客户所要的万维网文档。
在一个客户程序主窗口上显示出的万维网文档称为页面(page)。
万维网必须解决的问题,
(1)怎样标志分布在整个因特网上的万维网文档?
使用统一资源定位符URL(UniformResourceLocator)来标志万维网上的各种文档。
使每一个文档在整个因特网的范围内具有唯一的标识符URL。
万维网必须解决的问题,
(2)用何协议实现万维网上各种超链的链接?
在万维网客户程序与万维网服务器程序之间进行交互所使用的协议,是超文本传送协议HTTP(HyperTextTransferProtocol)。
HTTP是一个应用层协议,它使用TCP连接进行可靠的传送。
万维网必须解决的问题,(3)怎样使各种万维网文档都能在因特网上的各种计算机上显示出来,同时使用户清楚地知道在什么地方存在着超链?
超文本标记语言HTML(HyperTextMarkupLanguage)使得万维网页面的设计者可以很方便地用一个超链从本页面的某处链接到因特网上的任何一个万维网页面,并且能够在自己的计算机屏幕上将这些页面显示出来。
万维网必须解决的问题,(4)怎样使用户能够很方便地找到所需的信息?
为了在万维网上方便地查找信息,用户可使用各种的搜索工具(即搜索引擎)。
6.4.2统一资源定位符URL1.URL的格式,统一资源定位符URL是对可以从因特网上得到的资源的位置和访问方法的一种简洁的表示。
URL给资源的位置提供一种抽象的识别方法,并用这种方法给资源定位。
只要能够对资源定位,系统就可以对资源进行各种操作,如存取、更新、替换和查找其属性。
URL相当于一个文件名在网络范围的扩展。
因此URL是与因特网相连的机器上的任何可访问对象的一个指针。
URL的一般形式,由以冒号隔开的两大部分组成,并且在URL中的字符对大写或小写没有要求。
URL的一般形式是:
:
/:
/,URL的一般形式(续),由以冒号隔开的两大部分组成,并且在URL中的字符对大写或小写没有要求。
URL的一般形式是:
:
/:
/,URL的一般形式(续),由以冒号隔开的两大部分组成,并且在URL中的字符对大写或小写没有要求。
URL的一般形式是:
:
/:
/,使用HTTP的URL,使用HTTP的URL的一般形式http:
/:
/,使用HTTP的URL,使用HTTP的URL的一般形式http:
/:
/,冒号和两个斜线是规定的格式,使用HTTP的URL,使用HTTP的URL的一般形式http:
/:
/,这里写主机的域名,使用HTTP的URL,使用HTTP的URL的一般形式http:
/:
/,HTTP的默认端口号是80,通常可省略,使用HTTP的URL,使用HTTP的URL的一般形式http:
/:
/,若再省略文件的项,则URL就指到因特网上的某个主页(homepage)。
6.4.3超文本传送协议HTTP1.HTTP的操作过程,为了使超文本的链接能够高效率地完成,需要用HTTP协议来传送一切必须的信息。
从层次的角度看,HTTP是面向事务的(transaction-oriented)应用层协议,它是万维网上能够可靠地交换文件(包括文本、声音、图像等各种多媒体文件)的重要基础。
万维网的工作过程,因特网,服务器,链接到URL的超链,HTTP使用此TCP连接,浏览器程序,服务器程序,HTTP,客户,清华大学院系设置,用户点击鼠标后所发生的事件,
(1)浏览器分析超链指向页面的URL。
(2)浏览器向DNS请求解析的IP地址。
(3)域名系统DNS解析出清华大学服务器的IP地址。
(4)浏览器与服务器建立TCP连接(5)浏览器发出取文件命令:
GET/chn/yxsz/index.htm。
(6)服务器给出响应,把文件index.htm发给浏览器。
(7)TCP连接释放。
(8)浏览器显示“清华大学院系设置”文件index.htm中的所有文本。
HTTP的主要特点,HTTP是面向事务的客户服务器协议。
HTTP1.0协议是无状态的(stateless)。
HTTP协议本身也是无连接的,虽然它使用了面向连接的TCP向上提供的服务。
RTT,RTT,请求一个万维网文档所需的时间,万维网服务器,万维网客户,发起TCP连接,HTTP请求报文,传输文档的时间,整个文档收到,时间,时间,HTTP响应报文,持续连接(persistentconnection),HTTP/1.1协议使用持续连接。
万维网服务器在发送响应后仍然在一段时间内保持这条连接,使同一个客户(浏览器)和该服务器可以继续在这条连接上传送后续的HTTP请求报文和响应报文。
这并不局限于传送同一个页面上链接的文档,而是只要这些文档都在同一个服务器上就行。
目前一些流行的浏览器(例如,IE6.0)的默认设置就是使用HTTP/1.1。
持续连接的两种工作方式,非流水线方式:
客户在收到前一个响应后才能发出下一个请求。
这比非持续连接的两倍RTT的开销节省了建立TCP连接所需的一个RTT时间。
但服务器在发送完一个对象后,其TCP连接就处于空闲状态,浪费了服务器资源。
流水线方式:
客户在收到HTTP的响应报文之前就能够接着发送新的请求报文。
一个接一个的请求报文到达服务器后,服务器就可连续发回响应报文。
使用流水线方式时,客户访问所有的对象只需花费一个RTT时间,使TCP连接中的空闲时间减少,提高了下载文档效率。
代理服务器(proxyserver),代理服务器(proxyserver)又称为万维网高速缓存(Webcache),它代表浏览器发出HTTP请求。
万维网高速缓存把最近的一些请求和响应暂存在本地磁盘中。
当与暂时存放的请求相同的新请求到达时,万维网高速缓存就把暂存的响应发送出去,而不需要按URL的地址再去因特网访问该资源。
使用高速缓存可减少访问因特网服务器的时延,校园网,源点服务器,2Mb/s,因特网,浏览器,R1,R2,没有使用高速缓存的情况,使用高速缓存的情况,校园网,校园网的高速缓存(代理服务器),源点服务器,2Mb/s,因特网,浏览器,R1,R2,
(1)浏览器访问因特网的服务器时,要先与校园网的高速缓存建立TCP连接,并向高速缓存发出HTTP请求报文,使用高速缓存的情况,校园网,校园网的高速缓存(代理服务器),源点服务器,2Mb/s,因特网,浏览器,R1,R2,
(2)若高速缓存已经存放了所请求的对象,则将此对象放入HTTP响应报文中返回给浏览器。
使用高速缓存的情况,校园网,校园网的高速缓存(代理服务器),源点服务器,2Mb/s,因特网,浏览器,R1,R2,(3)否则,高速缓存就代表发出请求的用户浏览器,与因特网上的源点服务器建立TCP连接,并发送HTTP请求报文。
使用高速缓存的情况,校园网,校园网的高速缓存(代理服务器),源点服务器,2Mb/s,因特网,浏览器,R1,R2,(4)源点服务器将所请求的对象放在HTTP响应报文中返回给校园网的高速缓存。
使用高速缓存的情况,校园网,校园网的高速缓存(代理服务器),源点服务器,2Mb/s,因特网,浏览器,R1,R2,(5)高速缓存收到此对象后,先复制在其本地存储器中(为今后使用),然后再将该对象放在HTTP响应报文中,通过已建立的TCP连接,返回给请求该对象的浏览器。
3.HTTP的报文结构,HTTP有两类报文:
请求报文从客户向服务器发送请求报文。
响应报文从服务器到客户的回答。
由于HTTP是面向正文的(text-oriented),因此在报文中的每一个字段都是一些AS