计算机网络课件第6章应用层.ppt

上传人:新** 文档编号:568605227 上传时间:2024-07-25 格式:PPT 页数:204 大小:1.81MB
返回 下载 相关 举报
计算机网络课件第6章应用层.ppt_第1页
第1页 / 共204页
计算机网络课件第6章应用层.ppt_第2页
第2页 / 共204页
计算机网络课件第6章应用层.ppt_第3页
第3页 / 共204页
计算机网络课件第6章应用层.ppt_第4页
第4页 / 共204页
计算机网络课件第6章应用层.ppt_第5页
第5页 / 共204页
点击查看更多>>
资源描述

《计算机网络课件第6章应用层.ppt》由会员分享,可在线阅读,更多相关《计算机网络课件第6章应用层.ppt(204页珍藏版)》请在金锄头文库上搜索。

1、计算机网络计算机网络第 6 章 应用层6.1 域名系统 DNS 6.1.1 域名系统概述 6.1.2 因特网的域名结构 6.1.3 域名服务器6.2 文件传送协议 6.2.1 FTP 概述 6.2.2 FTP 的基本工作原理 6.2.3 简单文件传送协议 TFTP 章节安排:章节安排:计算机网络主讲:南京信息工程大学刘生6.3 远程终端协议 TELNET 6.4 万维网 WWW 6.4.1 概述 6.4.2 统一资源定位符 URL 6.4.3 超文本传送协议 HTTP 6.4.4 万维网的文档 6.4.5 万维网的信息检索系统章节安排:章节安排:计算机网络主讲:南京信息工程大学刘生 6.5 电

2、子邮件6.5.1 电子邮件概述6.5.2 简单邮件传送协议 SMTP6.5.3 电子邮件的信息格式6.5.4 邮件读取协议 POP3 和 IMAP6.5.5 基于万维网的电子邮件 6.5.6 通用因特网邮件扩充 MIME章节安排:章节安排:计算机网络主讲:南京信息工程大学刘生6.6 动态主机配置协议 DHCP 6.7 简单网络管理协议 SNMP6.7.1 网络管理的基本概念6.7.2 管理信息结构 SMI 6.7.3 管理信息库 MIB 6.7.4 SNMP 的协议数据单元和报文6.8 应用进程跨越网络的通信6.8.1 系统调用和应用编程接口6.8.2 几种常用的系统调用章节安排:章节安排:计

3、算机网络主讲:南京信息工程大学刘生本章重点:本章重点:1.DNS原理及域名结构2.FTP协议3.WWW与HTTP4.电子邮件系统原理5.DHCP6.SNMP*(选讲)计算机网络主讲:南京信息工程大学刘生应用层协议的特点应用层协议的特点 l应用层的具体内容就是规定应用进程在通信时所遵循的协议。l应用层的许多协议都是基于客户服务器方式。计算机网络主讲:南京信息工程大学刘生6.1 域名系统域名系统 DNS6.1.1 域名系统概述域名系统概述l许多应用层软件经常直接使用域名系统 DNS (Domain Name System),但计算机的用户只是间接而不是直接使用域名系统。 l因特网采用层次结构的命名

4、树作为主机的域名,并使用分布式的域名系统 DNS。l域名到 IP 地址的解析是由若干个域名服务器程序完成的。域名服务器程序在专设的结点上运行,运行该程序的机器称为域名服务器。 计算机网络主讲:南京信息工程大学刘生6.1.2 因特网的域名结构因特网的域名结构l因特网采用了层次树状结构的命名方法。l任何一个连接在因特网上的主机或路由器,都有一个唯一的层次结构的名字,即域名。l域名的结构由标号序列组成,各标号之间用点隔开: . 三级域名 . 二级域名 . 顶级域名l各标号分别代表不同级别的域名。 计算机网络主讲:南京信息工程大学刘生域名只是个逻辑概念域名只是个逻辑概念l域名只是个逻辑概念,并不代表计

5、算机所在的物理地点。l变长的域名和使用有助记忆的字符串,是为了便于人来使用。而 IP 地址是定长的 32 位二进制数字则非常便于机器进行处理。l域名中的“点”和点分十进制 IP 地址中的“点”并无一一对应的关系。点分十进制 IP 地址中一定是包含三个“点”,但每一个域名中“点”的数目则不一定正好是三个。 计算机网络主讲:南京信息工程大学刘生顶级域名顶级域名 TLD(Top Level Domain)(1) 国家顶级域名 nTLD:如: .cn 表示中国,.us 表示美国,.uk 表示英国,等等。(2) 通用顶级域名 gTLD:最早的顶级域名是: .com (公司和企业) .net (网络服务机

6、构) .org (非赢利性组织) .edu (美国专用的教育机构() .gov (美国专用的政府部门) .mil (美国专用的军事部门) .int (国际组织)计算机网络主讲:南京信息工程大学刘生顶级域名顶级域名 TLD (续)(续)(3) 基础结构域名(infrastructure domain):这种顶级域名只有一个,即 arpa,用于反向域名解析,因此又称为反向域名。 计算机网络主讲:南京信息工程大学刘生新增加了下列的通用顶级域名新增加了下列的通用顶级域名 l.aero (航空运输企业)l.biz (公司和企业)l.cat (加泰隆人的语言和文化团体)l.coop (合作团体)l.inf

7、o (各种情况)l.jobs (人力资源管理者)l.mobi (移动产品与服务的用户和提供者)l.museum (博物馆)l.name (个人)l.pro (有证书的专业人员)l.travel (旅游业) 计算机网络主讲:南京信息工程大学刘生因特网的域名空间因特网的域名空间 根四级域名mailwwwbjeducomcctvibmhp二级域名pkutsinghua三级域名mailwwwcomnetorgedugovaerocnuk顶级域名计算机网络主讲:南京信息工程大学刘生6.1.3 域名服务器域名服务器 l一个服务器所负责管辖的(或有权限的)范围叫做区(zone)。l每一个区设置相应的权限(授

8、权)域名服务器,用来保存该区中的所有主机的域名到IP地址的映射。lDNS 服务器的管辖范围不是以“域”为单位,而是以“区”为单位。 计算机网络主讲:南京信息工程大学刘生区的不同划分方法举例区的不同划分方法举例 域 区abcxuvwty(a) 区 = 域(b) 区 域域 区区abcxuvwtycomeduorg根comeduorg根计算机网络主讲:南京信息工程大学刘生树状结构的树状结构的 DNS 域名服务器域名服务器 根域名服务器org 域名服务器com 域名服务器edu 域名服务器域名服务器abc 公司有两个权限域名服务器权限域名服务器根域名服务器顶级域名服务器域名服务器计算机网络主讲:南

9、京信息工程大学刘生域名服务器有以下四种类型域名服务器有以下四种类型 l根域名服务器 l顶级域名服务器 l权限域名服务器 l本地域名服务器 计算机网络主讲:南京信息工程大学刘生根域名服务器根域名服务器 最高层次的域名服务器最高层次的域名服务器l根域名服务器是最重要的域名服务器。所有的根域名服务器都知道所有的顶级域名服务器的域名和 IP 地址。l不管是哪一个本地域名服务器,若要对因特网上任何一个域名进行解析,只要自己无法解析,就首先求助于根域名服务器。l在因特网上共有13 个不同 IP 地址的根域名服务器,它们的名字是用一个英文字母命名,从a 一直到 m(前13 个字母)。计算机网络主讲:南京信息

10、工程大学刘生根域名服务器共有根域名服务器共有 13 套装置套装置(不是(不是 13 个机器)个机器)l这些根域名服务器相应的域名分别是 l到 2006 年底全世界已经安装了一百多个根域名服务器机器,分布在世界各地。l这样做的目的是为了方便用户,使世界上大部分 DNS 域名服务器都能就近找到一个根域名服务器。 计算机网络主讲:南京信息工程大学刘生举例:根域名服务器举例:根域名服务器 f 的地点分布图的地点分布图 根域名服务器并不直接把域名直接转换成 IP 地址。 在使用迭代查询时,根域名服务器把下一步应当找 的顶级域名服务器的 IP 地址告诉本地域名服务器。共 40 个机器计算机网络主讲:南

11、京信息工程大学刘生顶级域名服务器顶级域名服务器(即(即 TLD 服务器)服务器) l这些域名服务器负责管理在该顶级域名服务器注册的所有二级域名。l当收到 DNS 查询请求时,就给出相应的回答(可能是最后的结果,也可能是下一步应当找的域名服务器的 IP 地址)。 计算机网络主讲:南京信息工程大学刘生权限域名服务器权限域名服务器 l这就是前面已经讲过的负责一个区的域名服务器。l当一个权限域名服务器还不能给出最后的查询回答时,就会告诉发出查询请求的 DNS 客户,下一步应当找哪一个权限域名服务器。 计算机网络主讲:南京信息工程大学刘生本地域名服务器本地域名服务器 l本地域名服务器对域名系统非常重要。

12、l当一个主机发出 DNS 查询请求时,这个查询请求报文就发送给本地域名服务器。l每一个因特网服务提供者 ISP,或一个大学,甚至一个大学里的系,都可以拥有一个本地域名服务器,l这种域名服务器有时也称为默认域名服务器。 计算机网络主讲:南京信息工程大学刘生提高域名服务器的可靠性提高域名服务器的可靠性lDNS 域名服务器都把数据复制到几个域名服务器来保存,其中的一个是主域名服务器,其他的是辅助域名服务器。l当主域名服务器出故障时,辅助域名服务器可以保证 DNS 的查询工作不会中断。l主域名服务器定期把数据复制到辅助域名服务器中,而更改数据只能在主域名服务器中进行。这样就保证了数据的一致性。 计算机

13、网络主讲:南京信息工程大学刘生域名的解析过程域名的解析过程 l主机向本地域名服务器的查询一般都是采用递归查询。如果本地域名服务器不知道主机所询问的域名的 IP 地址,那么本地域名服务器就以 DNS 客户的身份,向其他根域名服务器继续发出查询请求报文。l本地域名服务器向根域名服务器的查询通常是采用迭代查询。当根域名服务器收到本地域名服务器的迭代查询请求报文时,要么给出所要查询的 IP 地址,要么告诉本地域名服务器:“你下一步应当向哪一个域名服务器进行查询”。然后让本地域名服务器进行后续的查询。计算机网络主讲:南京信息工程大学刘生本地域名服务器采用迭代查询本地域名服务器采用迭代查询 顶级域名服务器

14、权限域名服务本地域名服务器根域名服务器迭代查询 的 IP 地址 递归查询需要查找 的 IP 地址计算机网络主讲:南京信息工程大学刘生本地域名服务器采用递归查询本地域名服务器采用递归查询(比较少用)(比较少用) 顶级域名服务器权限域名服务本地域名服务器 根域名服务器递归查询递归查询 的 IP 地址 需要查找 的 IP 地址计算机网络主讲:南京信息工程大学刘生名字的高速缓存名字的高速缓存 l每个域名服务器都维护一个高速缓存,存放最近用过的名字以及从何处获得名字映射信息的记录。l可大大减轻根域名服务器的负荷,使因特网上的 DNS 查询请求和回答报文的数量大为减少。 l为保持高速缓存中的内容

15、正确,域名服务器应为每项内容设置计时器,并处理超过合理时间的项(例如,每个项目只存放两天)。l当权限域名服务器回答一个查询请求时,在响应中都指明绑定有效存在的时间值。增加此时间值可减少网络开销,而减少此时间值可提高域名转换的准确性。 计算机网络主讲:南京信息工程大学刘生6.2 文件传送协议文件传送协议 6.2.1 FTP概述概述l文件传送协议 FTP (File Transfer Protocol) 是因特网上使用得最广泛的文件传送协议。lFTP 提供交互式的访问,允许客户指明文件的类型与格式,并允许文件具有存取权限。lFTP 屏蔽了各计算机系统的细节,因而适合于在异构网络中任意计算机之间传送

16、文件。lRFC 959 很早就成为了因特网的正式标准。 计算机网络主讲:南京信息工程大学刘生文件传送并非很简单的问题文件传送并非很简单的问题l网络环境中的一项基本应用就是将文件从一台计算机中复制到另一台可能相距很远的计算机中。l初看起来,在两个主机之间传送文件是很简单的事情。l其实这往往非常困难。原因是众多的计算机厂商研制出的文件系统多达数百种,且差别很大。 计算机网络主讲:南京信息工程大学刘生6.2.2 FTP 的基本工作原理的基本工作原理 网络环境下复制文件的复杂性:(1) 计算机存储数据的格式不同。(2) 文件的目录结构和文件命名的规定不同。(3) 对于相同的文件存取功能,操作系统使用的

17、命令不同。(4) 访问控制方法不同。 计算机网络主讲:南京信息工程大学刘生FTP 特点特点l文件传送协议 FTP 只提供文件传送的一些基本的服务,它使用 TCP 可靠的运输服务。lFTP 的主要功能是减少或消除在不同操作系统下处理文件的不兼容性。lFTP 使用客户服务器方式。一个 FTP 服务器进程可同时为多个客户进程提供服务。FTP 的服务器进程由两大部分组成:一个主进程,负责接受新的请求;另外有若干个从属进程,负责处理单个请求。计算机网络主讲:南京信息工程大学刘生主进程的工作步骤如下主进程的工作步骤如下l打开熟知端口(端口号为 21),使客户进程能够连接上。l等待客户进程发出连接请求。l启

18、动从属进程来处理客户进程发来的请求。从属进程对客户进程的请求处理完毕后即终止,但从属进程在运行期间根据需要还可能创建其他一些子进程。l回到等待状态,继续接受其他客户进程发来的请求。主进程与从属进程的处理是并发地进行。 计算机网络主讲:南京信息工程大学刘生两个连接两个连接l控制连接在整个会话期间一直保持打开,FTP 客户发出的传送请求通过控制连接发送给服务器端的控制进程,但控制连接不用来传送文件。l实际用于传输文件的是“数据连接”。服务器端的控制进程在接收到 FTP 客户发送来的文件传输请求后就创建“数据传送进程”和“数据连接”,用来连接客户端和服务器端的数据传送进程。l数据传送进程实际完成文件

19、的传送,在传送完毕后关闭“数据传送连接”并结束运行。 计算机网络主讲:南京信息工程大学刘生FTP 使用的两个使用的两个 TCP 连接连接 控制进程FTP 客户端FTP 服务器端因特网TCP 控制连接TCP 数据连接用户界面控制进程数据传送进程数据传送进程计算机网络主讲:南京信息工程大学刘生l 当客户进程向服务器进程发出建立连接请求时,要寻找连接服务器进程的熟知端口(21),同时还要告诉服务器进程自己的另一个端口号码,用于建立数据传送连接。l接着,服务器进程用自己传送数据的熟知端口(20)与客户进程所提供的端口号码建立数据传送连接。l由于 FTP 使用了两个不同的端口号,所以数据连接与控制连接不

20、会发生混乱。 两个不同的端口号两个不同的端口号 计算机网络主讲:南京信息工程大学刘生l使协议更加简单和更容易实现。l在传输文件时还可以利用控制连接(例如,客户发送请求终止传输)。 使用两个不同端口号的好处使用两个不同端口号的好处 计算机网络主讲:南京信息工程大学刘生6.2.3 简单文件传送协议简单文件传送协议 TFTP(Trivial File Transfer Protocol) lTFTP 是一个很小且易于实现的文件传送协议。lTFTP 使用客户服务器方式和使用 UDP 数据报,因此 TFTP 需要有自己的差错改正措施。lTFTP 只支持文件传输而不支持交互。lTFTP 没有一个庞大的命令

21、集,没有列目录的功能,也不能对用户进行身份鉴别。 计算机网络主讲:南京信息工程大学刘生TFTP 的主要特点是的主要特点是 (1) 每次传送的数据 PDU 中有 512 字节的数据,但最后一次可不足 512 字节。 (2) 数据 PDU 也称为文件块(block),每个块按序编号,从 1 开始。 (3) 支持 ASCII 码或二进制传送。 (4) 可对文件进行读或写。 (5) 使用很简单的首部。 计算机网络主讲:南京信息工程大学刘生TFTP 的工作很像停止等待协议的工作很像停止等待协议l发送完一个文件块后就等待对方的确认,确认时应指明所确认的块编号。l发完数据后在规定时间内收不到确认就要重发数据

22、 PDU。l发送确认 PDU 的一方若在规定时间内收不到下一个文件块,也要重发确认 PDU。这样就可保证文件的传送不致因某一个数据报的丢失而告失败。 计算机网络主讲:南京信息工程大学刘生TFTP 的工作很像停止等待协议的工作很像停止等待协议l在一开始工作时。TFTP 客户进程发送一个读请求 PDU 或写请求 PDU 给 TFTP 服务器进程,其熟知端口号码为 69。lTFTP 服务器进程要选择一个新的端口和 TFTP 客户进程进行通信。l若文件长度恰好为 512 字节的整数倍,则在文件传送完毕后,还必须在最后发送一个只含首部而无数据的数据 PDU。l若文件长度不是 512 字节的整数倍,则最后

23、传送数据 PDU 的数据字段一定不满512字节,这正好可作为文件结束的标志。计算机网络主讲:南京信息工程大学刘生6.3 按远程终端协议按远程终端协议 TELNETlTELNET 是一个简单的远程终端协议,也是因特网的正式标准。l用户用 TELNET 就可在其所在地通过 TCP 连接注册(即登录)到远地的另一个主机上(使用主机名或 IP 地址)。lTELNET 能将用户的击键传到远地主机,同时也能将远地主机的输出通过 TCP 连接返回到用户屏幕。这种服务是透明的,因为用户感觉到好像键盘和显示器是直接连在远地主机上。 计算机网络主讲:南京信息工程大学刘生客户服务器方式客户服务器方式l现在由于 PC

24、 机的功能越来越强,用户已较少使用 TELNET 了。lTELNET 也使用客户服务器方式。在本地系统运行 TELNET 客户进程,而在远地主机则运行 TELNET 服务器进程。l和 FTP 的情况相似,服务器中的主进程等待新的请求,并产生从属进程来处理每一个连接。 计算机网络主讲:南京信息工程大学刘生TELNET 使用使用网络虚拟终端网络虚拟终端 NVT 格式格式 因特网TCP 连接 客户端 服务器端 使用客户端的格式 使用服务器端的格式 使用 NVT 格式客户服务器计算机网络主讲:南京信息工程大学刘生网络虚拟终端网络虚拟终端 NVT 格式格式 l客户软件把用户的击键和命令转换成 NVT 格

25、式,并送交服务器。l服务器软件把收到的数据和命令,从 NVT 格式转换成远地系统所需的格式。l向用户返回数据时,服务器把远地系统的格式转换为 NVT 格式,本地客户再从 NVT 格式转换到本地系统所需的格式。 计算机网络主讲:南京信息工程大学刘生6.4 万维网万维网 WWW6.4.1 万维网概述万维网概述l万维网 WWW (World Wide Web)并非某种特殊的计算机网络。l万维网是一个大规模的、联机式的信息储藏所。l万维网用链接的方法能非常方便地从因特网上的一个站点访问另一个站点,从而主动地按需获取丰富的信息。l这种访问方式称为“链接”。计算机网络主讲:南京信息工程大学刘生万维网提供分

26、布式服务万维网提供分布式服务 万维网站点 A万维网站点 C万维网站点 E万维网站点 D万维网站点 B链接到链接到链接到链接到链接到链接到计算机网络主讲:南京信息工程大学刘生超媒体与超文本超媒体与超文本l万维网是分布式超媒体(hypermedia)系统,它是超文本(hypertext)系统的扩充。l一个超文本由多个信息源链接成。利用一个链接可使用户找到另一个文档。这些文档可以位于世界上任何一个接在因特网上的超文本系统中。超文本是万维网的基础。l超媒体与超文本的区别是文档内容不同。超文本文档仅包含文本信息,而超媒体文档还包含其他表示方式的信息,如图形、图像、声音、动画,甚至活动视频图像。计算机网络

27、主讲:南京信息工程大学刘生 万维网的工作方式万维网的工作方式 l万维网以客户服务器方式工作。l浏览器就是在用户计算机上的万维网客户程序。万维网文档所驻留的计算机则运行服务器程序,因此这个计算机也称为万维网服务器。l客户程序向服务器程序发出请求,服务器程序向客户程序送回客户所要的万维网文档。l在一个客户程序主窗口上显示出的万维网文档称为页面(page)。计算机网络主讲:南京信息工程大学刘生万维网必须解决的问题万维网必须解决的问题 (1) 怎样标志分布在整个因特网上的万维网文档? l使用统一资源定位符 URL (Uniform Resource Locator)来标志万维网上的各种文档。l使每一个

28、文档在整个因特网的范围内具有唯一的标识符 URL。 计算机网络主讲:南京信息工程大学刘生万维网必须解决的问题万维网必须解决的问题 (2) 用何协议实现万维网上各种超链的链接? l在万维网客户程序与万维网服务器程序之间进行交互所使用的协议,是超文本传送协议 HTTP (HyperText Transfer Protocol)。lHTTP 是一个应用层协议,它使用 TCP 连接进行可靠的传送。 计算机网络主讲:南京信息工程大学刘生万维网必须解决的问题万维网必须解决的问题 (3) 怎样使各种万维网文档都能在因特网上的各种计算机上显示出来,同时使用户清楚地知道在什么地方存在着超链? l超文本标记语言

29、HTML (HyperText Markup Language)使得万维网页面的设计者可以很方便地用一个超链从本页面的某处链接到因特网上的任何一个万维网页面,并且能够在自己的计算机屏幕上将这些页面显示出来。 计算机网络主讲:南京信息工程大学刘生万维网必须解决的问题万维网必须解决的问题 (4) 怎样使用户能够很方便地找到所需的信息? l为了在万维网上方便地查找信息,用户可使用各种的搜索工具(即搜索引擎)。 计算机网络主讲:南京信息工程大学刘生6.4.2 统一资源定位符统一资源定位符 URL1. URL的格式的格式l统一资源定位符 URL 是对可以从因特网上得到的资源的位置和访问方法的一种简洁的表

30、示。lURL 给资源的位置提供一种抽象的识别方法,并用这种方法给资源定位。l只要能够对资源定位,系统就可以对资源进行各种操作,如存取、更新、替换和查找其属性。lURL 相当于一个文件名在网络范围的扩展。因此 URL 是与因特网相连的机器上的任何可访问对象的一个指针。 计算机网络主讲:南京信息工程大学刘生URL 的一般形式的一般形式 l由以冒号隔开的两大部分组成,并且在 URL 中的字符对大写或小写没有要求。lURL 的一般形式是::/:/ ftp 文件传送协议 FTPhttp 超文本传送协议 HTTPNews USENET 新闻计算机网络主讲:南京信息工程大学刘生URL 的一般形式(续)的一般

31、形式(续) l由以冒号隔开的两大部分组成,并且在 URL 中的字符对大写或小写没有要求。lURL 的一般形式是::/:/ 是存放资源的主机在因特网中的域名计算机网络主讲:南京信息工程大学刘生URL 的一般形式(续)的一般形式(续) l由以冒号隔开的两大部分组成,并且在 URL 中的字符对大写或小写没有要求。lURL 的一般形式是::/:/有时可省略计算机网络主讲:南京信息工程大学刘生使用使用 HTTP 的的 URLl使用 HTTP 的 URL 的一般形式 http:/:/ 这表示使用 HTTP 协议计算机网络主讲:南京信息工程大学刘生使用使用 HTTP 的的 URLl使用 HTTP 的 URL

32、 的一般形式 http:/:/ 冒号和两个斜线是规定的格式计算机网络主讲:南京信息工程大学刘生使用使用 HTTP 的的 URLl使用 HTTP 的 URL 的一般形式 http:/:/ 这里写主机的域名计算机网络主讲:南京信息工程大学刘生使用使用 HTTP 的的 URLl使用 HTTP 的 URL 的一般形式 http:/:/ HTTP 的默认端口号是 80,通常可省略计算机网络主讲:南京信息工程大学刘生使用使用 HTTP 的的 URLl使用 HTTP 的 URL 的一般形式 http:/:/ 若再省略文件的项,则 URL 就指到因特网上的某个主页(home page)。 计算机网络主讲:南京

33、信息工程大学刘生6.4.3 超文本传送协议超文本传送协议 HTTP1. HTTP 的操作过程的操作过程 l为了使超文本的链接能够高效率地完成,需要用 HTTP 协议来传送一切必须的信息。l从层次的角度看,HTTP 是面向事务的(transaction-oriented)应用层协议,它是万维网上能够可靠地交换文件(包括文本、声音、图像等各种多媒体文件)的重要基础。 计算机网络主讲:南京信息工程大学刘生万维网的工作过程万维网的工作过程 因特网服务器链接到URL的超链HTTP 使用此 TCP 连接浏览器 程序服务器 程序HTTP客户清华大学院系设置建立 TCP 连接释放 TCP 连接HTTP 响应报

34、文 响应文档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 中的所有文本。计算机网络主讲:南京信息

35、工程大学刘生HTTP 的主要特点的主要特点 lHTTP 是面向事务的客户服务器协议。lHTTP 1.0 协议是无状态的(stateless)。lHTTP 协议本身也是无连接的,虽然它使用了面向连接的 TCP 向上提供的服务。计算机网络主讲:南京信息工程大学刘生RTTRTT请求一个万维网文档所需的时间请求一个万维网文档所需的时间 万维网服务器万维网客户发起 TCP 连接HTTP 请求报文传输文档的时间整个文档收到时间时间HTTP 响应报文计算机网络主讲:南京信息工程大学刘生持续连接持续连接(persistent connection)lHTTP/1.1 协议使用持续连接。l万维网服务器在发送响应

36、后仍然在一段时间内保持这条连接,使同一个客户(浏览器)和该服务器可以继续在这条连接上传送后续的 HTTP 请求报文和响应报文。l这并不局限于传送同一个页面上链接的文档,而是只要这些文档都在同一个服务器上就行。l目前一些流行的浏览器(例如,IE 6.0)的默认设置就是使用 HTTP/1.1。计算机网络主讲:南京信息工程大学刘生持续连接的两种工作方式持续连接的两种工作方式l非流水线方式:客户在收到前一个响应后才能发出下一个请求。这比非持续连接的两倍 RTT 的开销节省了建立 TCP 连接所需的一个 RTT 时间。但服务器在发送完一个对象后,其 TCP 连接就处于空闲状态,浪费了服务器资源。l流水线

37、方式:客户在收到 HTTP 的响应报文之前就能够接着发送新的请求报文。一个接一个的请求报文到达服务器后,服务器就可连续发回响应报文。使用流水线方式时,客户访问所有的对象只需花费一个 RTT时间,使 TCP 连接中的空闲时间减少,提高了下载文档效率。 计算机网络主讲:南京信息工程大学刘生代理服务器代理服务器(proxy server) l代理服务器(proxy server)又称为万维网高速缓存(Web cache),它代表浏览器发出 HTTP 请求。l万维网高速缓存把最近的一些请求和响应暂存在本地磁盘中。l当与暂时存放的请求相同的新请求到达时,万维网高速缓存就把暂存的响应发送出去,而不需要按

38、URL 的地址再去因特网访问该资源。 计算机网络主讲:南京信息工程大学刘生使用高速缓存可减少使用高速缓存可减少访问因特网服务器的时延访问因特网服务器的时延 校园网源点服务器2 Mb/s因特网浏览器R1R2这条链路上的时延很大没有使用高速缓存的情况所有万维网通信量都经过这条链路计算机网络主讲:南京信息工程大学刘生使用高速缓存的情况使用高速缓存的情况校园网校园网的高速缓存(代理服务器)源点服务器2 Mb/s因特网浏览器R1R2(1) 浏览器访问因特网的服务器时,要先与校园网的高速缓存建立 TCP 连接,并向高速缓存发出 HTTP 请求报文 计算机网络主讲:南京信息工程大学刘生使用高速缓存的情况使用

39、高速缓存的情况校园网校园网的高速缓存(代理服务器)源点服务器2 Mb/s因特网浏览器R1R2(2) 若高速缓存已经存放了所请求的对象,则将此对象放入 HTTP 响应报文中返回给浏览器。计算机网络主讲:南京信息工程大学刘生使用高速缓存的情况使用高速缓存的情况校园网校园网的高速缓存(代理服务器)源点服务器2 Mb/s因特网浏览器R1R2(3) 否则,高速缓存就代表发出请求的用户浏览器,与因特网上的源点服务器建立 TCP 连接,并发送 HTTP 请求报文。计算机网络主讲:南京信息工程大学刘生使用高速缓存的情况使用高速缓存的情况校园网校园网的高速缓存(代理服务器)源点服务器2 Mb/s因特网浏览器R1

40、R2(4) 源点服务器将所请求的对象放在 HTTP 响应报文中返回给校园网的高速缓存。计算机网络主讲:南京信息工程大学刘生使用高速缓存的情况使用高速缓存的情况校园网校园网的高速缓存(代理服务器)源点服务器2 Mb/s因特网浏览器R1R2(5) 高速缓存收到此对象后,先复制在其本地存储器中(为今后使用),然后再将该对象放在 HTTP 响应报文中,通过已建立的 TCP 连接,返回给请求该对象的浏览器。计算机网络主讲:南京信息工程大学刘生3. HTTP 的报文结构的报文结构 HTTP 有两类报文:l请求报文从客户向服务器发送请求报文。l响应报文从服务器到客户的回答。l由于 HTTP 是面向正文的(t

41、ext-oriented),因此在报文中的每一个字段都是一些 ASCII 码串,因而每个字段的长度都是不确定的。计算机网络主讲:南京信息工程大学刘生HTTP 的报文结构(请求报文)的报文结构(请求报文) 方 法URL版 本首部字段名首部行:值首部字段名值:实体主体(通常不用)请求行空格回车换行:CRLFCRLFCRLFCRLF报文由三个部分组成,即开始行、首部行和实体主体。在请求报文中,开始行就是请求行。开始行计算机网络主讲:南京信息工程大学刘生HTTP 的报文结构(请求报文)的报文结构(请求报文) 方 法URL版 本首部字段名首部行:值首部字段名值:实体主体(通常不用)请求行空格回车换行:C

42、RLFCRLFCRLFCRLF“方法”是面向对象技术中使用的专门名词。所谓“方法”就是对所请求的对象进行的操作,因此这些方法实际上也就是一些命令。因此,请求报文的类型是由它所采用的方法决定的。 计算机网络主讲:南京信息工程大学刘生HTTP 请求报文的一些方法请求报文的一些方法 方法(操作) 意义OPTION 请求一些选项的信息GET 请求读取由 URL所标志的信息HEAD 请求读取由 URL所标志的信息的首部POST 给服务器添加信息(例如,注释)PUT 在指明的 URL下存储一个文档DELETE 删除指明的 URL所标志的资源TRACE 用来进行环回测试的请求报文CONNECT 用于代理服务

43、器计算机网络主讲:南京信息工程大学刘生HTTP 的报文结构(请求报文)的报文结构(请求报文) 方 法URL版 本首部字段名首部行:值首部字段名值:实体主体(通常不用)请求行空格回车换行:CRLFCRLFCRLFCRLF“URL”是所请求的资源的 URL。计算机网络主讲:南京信息工程大学刘生HTTP 的报文结构(请求报文)的报文结构(请求报文) 方 法URL版 本首部字段名首部行:值首部字段名值:实体主体(通常不用)请求行空格回车换行:CRLFCRLFCRLFCRLF“版本”是 HTTP 的版本。计算机网络主讲:南京信息工程大学刘生HTTP 的报文结构(响应报文)的报文结构(响应报文) 版 本状

44、态码短 语首部字段名首部行:值首部字段名值:实体主体(有些响应报文不用)状态行空格回车换行:CRLFCRLFCRLFCRLF响应报文的开始行是状态行。状态行包括三项内容,即 HTTP 的版本,状态码,以及解释状态码的简单短语。 开始行计算机网络主讲:南京信息工程大学刘生状态码都是三位数字状态码都是三位数字 l1xx 表示通知信息的,如请求收到了或正在进行处理。l2xx 表示成功,如接受或知道了。l3xx 表示重定向,表示要完成请求还必须采取进一步的行动。l4xx 表示客户的差错,如请求中有错误的语法或不能完成。l5xx 表示服务器的差错,如服务器失效无法完成请求。计算机网络主讲:南京信息工程大

45、学刘生4. 在服务器上存放用户的信息在服务器上存放用户的信息l万维网站点使用 Cookie 来跟踪用户。lCookie 表示在 HTTP 服务器和客户之间传递的状态信息。l使用 Cookie 的网站服务器为用户产生一个唯一的识别码。利用此识别码,网站就能够跟踪该用户在该网站的活动。 计算机网络主讲:南京信息工程大学刘生6.4.4 万维网的文档万维网的文档1. 超文本标记语言超文本标记语言 HTMLl超文本标记语言 HTML 中的 Markup 的意思就是“设置标记”。lHTML 定义了许多用于排版的命令(即标签)。lHTML 把各种标签嵌入到万维网的页面中。这样就构成了所谓的 HTML 文档。

46、HTML 文档是一种可以用任何文本编辑器创建的 ASCII 码文件。 计算机网络主讲:南京信息工程大学刘生HTML 文档文档 l仅当 HTML 文档是以.html 或 .htm 为后缀时,浏览器才对此 文档的各种标签进行解释。l如 HTML 文档改换以 .txt 为其后缀,则 HTML 解释程序就不对标签进行解释,而浏览器只能看见原来的文本文件。l当浏览器从服务器读取 HTML 文档后,就按照 HTML 文档中的各种标签,根据浏览器所使用的显示器的尺寸和分辨率大小,重新进行排版并恢复出所读取的页面。计算机网络主讲:南京信息工程大学刘生HTML 文档中标签的用法文档中标签的用法 一个 HTML

47、的例子 HTML 很容易掌握 这是第一个段落。虽然很 短,但它仍是一个段落。 这是第二个段落。HTML 文档开始计算机网络主讲:南京信息工程大学刘生HTML 文档中标签的用法文档中标签的用法 一个 HTML 的例子 HTML 很容易掌握 这是第一个段落。虽然很 短,但它仍是一个段落。 这是第二个段落。首部开始计算机网络主讲:南京信息工程大学刘生HTML 文档中标签的用法文档中标签的用法 一个 HTML 的例子 HTML 很容易掌握 这是第一个段落。虽然很 短,但它仍是一个段落。 这是第二个段落。标题计算机网络主讲:南京信息工程大学刘生HTML 文档中标签的用法文档中标签的用法 一个 HTML

48、的例子 HTML 很容易掌握 这是第一个段落。虽然很 短,但它仍是一个段落。 这是第二个段落。首部结束计算机网络主讲:南京信息工程大学刘生HTML 文档中标签的用法文档中标签的用法 一个 HTML 的例子 HTML 很容易掌握 这是第一个段落。虽然很 短,但它仍是一个段落。 这是第二个段落。主体开始计算机网络主讲:南京信息工程大学刘生HTML 文档中标签的用法文档中标签的用法 一个 HTML 的例子 HTML 很容易掌握 这是第一个段落。虽然很 短,但它仍是一个段落。 这是第二个段落。1 级标题计算机网络主讲:南京信息工程大学刘生 一个 HTML 的例子 HTML 很容易掌握 这是第一个段落。

49、虽然很 短,但它仍是一个段落。 这是第二个段落。HTML 文档中标签的用法文档中标签的用法 第一个段落计算机网络主讲:南京信息工程大学刘生 一个 HTML 的例子 HTML 很容易掌握 这是第一个段落。虽然很 短,但它仍是一个段落。 这是第二个段落。HTML 文档中标签的用法文档中标签的用法 第二个段落计算机网络主讲:南京信息工程大学刘生HTML 文档中标签的用法文档中标签的用法 一个 HTML 的例子 HTML 很容易掌握 这是第一个段落。虽然很 短,但它仍是一个段落。 这是第二个段落。主体结束计算机网络主讲:南京信息工程大学刘生HTML 文档中标签的用法文档中标签的用法 一个 HTML 的

50、例子 HTML 很容易掌握 这是第一个段落。虽然很 短,但它仍是一个段落。 这是第二个段落。HTML 文档结束计算机网络主讲:南京信息工程大学刘生两种不同的链接两种不同的链接l远程链接:超链的终点是其他网点上的页面。l本地链接:超链指向本计算机中的某个文件。计算机网络主讲:南京信息工程大学刘生2. 动态万维网文档动态万维网文档 l静态文档是指该文档创作完毕后就存放在万维网服务器中,在被用户浏览的过程中,内容不会改变。 l动态文档是指文档的内容是在浏览器访问万维网服务器时才由应用程序动态创建。l动态文档和静态文档之间的主要差别体现在服务器一端。这主要是文档内容的生成方法不同。而从浏览器的角度看,

51、这两种文档并没有区别。 计算机网络主讲:南京信息工程大学刘生万维网服务器功能的扩充万维网服务器功能的扩充 (1) 应增加另一个应用程序,用来处理浏览器发来的数据,并创建动态文档。(2) 应增加一个机制,用来使万维网服务器把浏览器发来的数据传送给这个应用程序,然后万维网服务器能够解释这个应用程序的输出,并向浏览器返回 HTML 文档。计算机网络主讲:南京信息工程大学刘生CGI 响应动态文档HTTP 响应报文扩充了功能的万维网服务器扩充了功能的万维网服务器 万维网服务器浏览器 程序万维网客户服务器 程序HTTP数据库HTTP 请求报文 请求文档 CGI 程序创建动态文档计算机网络主讲:南京信息工程

52、大学刘生通用网关接口通用网关接口 CGI(Common Gateway Interface) lCGI 是一种标准,它定义了动态文档应如何创建,输入数据应如何提供给应用程序,以及输出结果应如何使用。l万维网服务器与 CGI 的通信遵循 CGI 标准。l“通用”:CGI 标准所定义的规则对其他任何语言都是通用的。l“网关”:CGI 程序的作用像网关。l“接口”:有一些已定义好的变量和调用等可供其他 CGI 程序使用。 计算机网络主讲:南京信息工程大学刘生CGI 程序程序lCGI 程序的正式名字是 CGI 脚本(script)。l“脚本”指的是一个程序,它被另一个程序(解释程序)而不是计算机的处理

53、机来解释或执行。l脚本运行起来要比一般的编译程序要慢,因为它的每一条指令先要被另一个程序来处理(这就要一些附加的指令),而不是直接被指令处理器来处理。 计算机网络主讲:南京信息工程大学刘生3. 活动万维网文档活动万维网文档l活动文档(active document)技术把所有的工作都转移给浏览器端。l每当浏览器请求一个活动文档时,服务器就返回一段程序副本在浏览器端运行。l活动文档程序可与用户直接交互,并可连续地改变屏幕的显示。l由于活动文档技术不需要服务器的连续更新传送,对网络带宽的要求也不会太高。 计算机网络主讲:南京信息工程大学刘生 响应程序HTTP 响应报文程序活动文档在客户端创建活动文

54、档在客户端创建 万维网服务器浏览器 程序万维网客户服务器 程序HTTPHTTP 请求报文 请求文档程序事先被编译成二进制代码,存放为文件程序 此程序在客户端创建出活动文档文档计算机网络主讲:南京信息工程大学刘生用用 Java 技术创建活动文档技术创建活动文档 l由美国 Sun 公司开发的 Java 语言是一项用于创建和运行活动文档的技术。l在 Java 技术中使用 “小应用程序”(applet)来描述活动文档程序。l用户从万维网服务器下载嵌入了 Java 小应用程序的 HTML 文档后,可在浏览器的屏幕上点击某个图像,就可看到动画效果,或在下拉式菜单中点击某个项目,就可看到计算结果。lJava

55、 技术是活动文档技术的一部分。 计算机网络主讲:南京信息工程大学刘生Java 技术装三个主要组成部分技术装三个主要组成部分 (1) 程序设计语言。Java 包含一个新的程序设计语言,用来编写传统的计算机程序和 Java 小应用程序。(2) 运行(runtime)环境。这是运行 Java 程序所必须的运行环境,其中包括 Java 虚拟机(简称为 JVM),该软件定义了 Java 二进制代码的执行模型。(3) 类库(class library)。为了更容易编写 Java 小应用程序,Java 提供了强大的类库支持。 计算机网络主讲:南京信息工程大学刘生JavalJava 是一种面向对象的高级语言,

56、从 C+ 派生出来的,它省略了 C+ 很多复杂的、很少用的语言特点。lJava 的每一个数据项都有一个确定的类型。对数据的操作严格按照该数据的类型来进行。lJava 的编译程序将源程序转换成 Java 字节码(bytecode),这是一种与机器无关的二进制代码。计算机程序调用解释程序读取字节码,并解释执行。 计算机网络主讲:南京信息工程大学刘生计算机硬件无关计算机硬件无关lJava 语言、字节码以及 Java 运行系统都被设计成与计算机硬件无关。一旦形成了字节码,就可在任何计算机上运行并产生相同的输出。lJava 小应用程序与机器无关可使在任何计算机上运行的浏览器程序能够下载并运行活动文档。l

57、可保证活动文档在所有的浏览器上产生同样的正确输出。l可大大地降低活动文档的创建和测试费用,因为不必为每一种计算机都制作一个副本。计算机网络主讲:南京信息工程大学刘生Java 解释程序解释程序 l运行 Java 的浏览器需要有 HTML 解释程序和 Java 小应用程序解释程序。l解释程序的核心是一个模仿计算机的简单循环。l解释程序维持一个指令指针,在初始化时指在小应用程序的开始处。l在每一次循环操作时,解释程序在指令指针指向的地址读取字节码。然后解释程序对字节码进行解码,并完成指明的操作。 计算机网络主讲:南京信息工程大学刘生4. 浏览器的结构浏览器的结构与远地服务器通信输出至显示器从鼠标和键

58、盘输入网 络 接 口可选客户程序HTML解释程序可选解释程序控 制 程 序驱动程序HTTP 客户程序缓 存计算机网络主讲:南京信息工程大学刘生浏览器的主要组成部分浏览器的主要组成部分 l浏览器有一组客户、一组解释程序,以及管理这些客户和解释程序的控制程序。l控制程序是其中的核心部件,它解释鼠标的点击和键盘的输入,并调用有关的组件来执行用户指定的操作。l例如,当用户用鼠标点击一个超链的起点时,控制程序就调用一个客户从所需文档所在的远地服务器上取回该文档,并调用解释程序向用户显示该文档。 计算机网络主讲:南京信息工程大学刘生解释程序解释程序 lHTML 解释程序是必不可少的,而其他的解释程序则是可

59、选的。 l解释程序把 HTML 规格转换为适合用户显示硬件的命令来处理版面的细节。 l许多浏览器还包含 FTP 客户程序,用来获取文件传送服务。l一些浏览器也包含电子邮件客户程序,使浏览器能够发送和接收电子邮件。计算机网络主讲:南京信息工程大学刘生浏览器中的缓存浏览器中的缓存 l浏览器将它取回的每一个页面副本都放入本地磁盘的缓存中。l当用户用鼠标点击某个选项时,浏览器首先检查磁盘的缓存。若缓存中保存了该项,浏览器就直接从缓存中得到该项副本而不必从网络获取,这样就明显地改善浏览器的运行特性。 。l但缓存要占用磁盘大量的空间,而浏览器性能的改善只有在用户再次查看缓存中的页面时才有帮助。l许多浏览器

60、允许用户调整缓存策略。 计算机网络主讲:南京信息工程大学刘生6.4.5 万维网的信息检索系统万维网的信息检索系统1. 全文检索搜索和分类目录搜索全文检索搜索和分类目录搜索l在万维网中用来进行搜索的程序叫做搜索引擎。l全文检索搜索引擎是一种纯技术型的检索工具。它的工作原理是通过搜索软件到因特网上的各网站收集信息,找到一个网站后可以从这个网站再链接到另一个网站。然后按照一定的规则建立一个很大的在线数据库供用户查询。l用户在查询时只要输入关键词,就从已经建立的索引数据库上进行查询(并不是实时地在因特网上检索到的信息)。 计算机网络主讲:南京信息工程大学刘生分类目录搜索分类目录搜索 l分类目录搜索引擎

61、并不采集网站的任何信息,而是利用各网站向搜索引擎提交的网站信息时填写的关键词和网站描述等信息,经过人工审核编辑后,如果认为符合网站登录的条件,则输入到分类目录的数据库中,供网上用户查询。l分类目录搜索也叫做分类网站搜索。 计算机网络主讲:南京信息工程大学刘生一些著名的搜索引擎一些著名的搜索引擎 l最著名的全文检索搜索引擎:uGoogle(谷歌)(谷歌)() u百度百度 () l最著名的分类目录搜索引擎:u雅虎雅虎 ()u雅虎中国雅虎中国 ()u新浪新浪 ()u搜狐搜狐 ()u网易网易 () 计算机网络主讲:南京信息工程大学刘生垂直搜索引擎垂直搜索引擎(Vertical Search Engin

62、e) l针对某一特定领域、特定人群或某一特定需求提供搜索服务。垂直搜索也是提供关键字来进行搜索的,但被放到了一个行业知识的上下文中,返回的结果更倾向于信息、消息、条目等。 计算机网络主讲:南京信息工程大学刘生6.5 电子邮件电子邮件6.5.1 概述概述l电子邮件(e-mail)是因特网上使用得最多的和最受用户欢迎的一种应用。l电子邮件把邮件发送到收件人使用的邮件服务器,并放在其中的收件人邮箱中,收件人可随时上网到自己使用的邮件服务器进行读取。l电子邮件不仅使用方便,而且还具有传递迅速和费用低廉的优点。l现在电子邮件不仅可传送文字信息,而且还可附上声音和图像。计算机网络主讲:南京信息工程大学刘生

63、电子邮件的一些标准电子邮件的一些标准l发送邮件的协议:SMTPl读取邮件的协议:POP3 和 IMAPlMIME 在其邮件首部中说明了邮件的数据类型(如文本、声音、图像、视像等),使用 MIME 可在邮件中同时传送多种类型的数据。 计算机网络主讲:南京信息工程大学刘生电子邮件的最主要的组成构件电子邮件的最主要的组成构件 发送方邮件缓存 接收端邮件服务器用户代理SMTPSMTPPOP3 发送端邮件服务器用户代理用户邮箱接收方(发送邮件)(发送邮件)(读取邮件)因特网SMTPPOP3发送邮件发送邮件 SMTP读取邮件TCP连接TCP连接发送方邮件服务器SMTP客户POP3客户发件人用户代理接收方邮

64、件服务器SMTP服务器POP3服务器SMTP服务器SMTP客户收件人用户代理TCP 连接计算机网络主讲:南京信息工程大学刘生用户代理用户代理 UA (User Agent)l用户代理 UA 就是用户与电子邮件系统的接口,是电子邮件客户端软件。l用户代理的功能:撰写、显示、处理和通信。l邮件服务器的功能是发送和接收邮件,同时还要向发信人报告邮件传送的情况(已交付、被拒绝、丢失等)。l邮件服务器按照客户服务器方式工作。邮件服务器需要使用发送和读取两个不同的协议。计算机网络主讲:南京信息工程大学刘生应当注意应当注意l一个邮件服务器既可以作为客户,也可以作为服务器。l例如,当邮件服务器 A 向另一个邮

65、件服务器 B 发送邮件时,邮件服务器 A 就作为 SMTP 客户,而 B 是 SMTP 服务器。l当邮件服务器 A 从另一个邮件服务器 B 接收邮件时,邮件服务器 A 就作为 SMTP 服务器,而 B 是 SMTP 客户。计算机网络主讲:南京信息工程大学刘生发送和接收电子邮件的发送和接收电子邮件的几个重要步骤几个重要步骤 发件人调用 PC 机中的用户代理撰写和编辑要发送的邮件。 发件人的用户代理把邮件用 SMTP 协议发给发送方邮件服务器, SMTP 服务器把邮件临时存放在邮件缓存队列中,等待发送。 发送方邮件服务器的 SMTP 客户与接收方邮件服务器的 SMTP 服务器建立 TCP 连接,然

66、后就把邮件缓存队列中的邮件依次发送出去。 计算机网络主讲:南京信息工程大学刘生发送和接收电子邮件的发送和接收电子邮件的几个重要步骤(续)几个重要步骤(续) 运行在接收方邮件服务器中的SMTP服务器进 程收到邮件后,把邮件放入收件人的用户邮箱中,等待收件人进行读取。 收件人在打算收信时,就运行 PC 机中的用户代理,使用 POP3(或 IMAP)协议读取发送给自己的邮件。l请注意,POP3 服务器和 POP3 客户之间的通信是由 POP3 客户发起的。 计算机网络主讲:南京信息工程大学刘生电子邮件的组成电子邮件的组成l电子邮件由信封(envelope)和内容(content)两部分组成。l电子邮

67、件的传输程序根据邮件信封上的信息来传送邮件。用户在从自己的邮箱中读取邮件时才能见到邮件的内容。l在邮件的信封上,最重要的就是收件人的地址。 计算机网络主讲:南京信息工程大学刘生电子邮件地址的格式电子邮件地址的格式lTCP/IP 体系的电子邮件系统规定电子邮件地址的格式如下: 收件人邮箱名邮箱所在主机的域名 (6-1)l符号“”读作“at”,表示“在”的意思。 l 例如,电子邮件地址 邮箱所在的主机的域名在全世界必须是唯一的 这个用户名在该域名的范围内是唯一的。 计算机网络主讲:南京信息工程大学刘生6.5.2 简单邮件传送协议简单邮件传送协议 SMTP lSMTP 所规定的就是在两个相互通信的

68、SMTP 进程之间应如何交换信息。l由于 SMTP 使用客户服务器方式,因此负责发送邮件的 SMTP 进程就是 SMTP 客户,而负责接收邮件的 SMTP 进程就是 SMTP 服务器。lSMTP 规定了 14 条命令和 21 种应答信息。每条命令用 4 个字母组成,而每一种应答信息一般只有一行信息,由一个 3 位数字的代码开始,后面附上(也可不附上)很简单的文字说明。 计算机网络主讲:南京信息工程大学刘生SMTP 通信的三个阶段通信的三个阶段 1. 连接建立:连接是在发送主机的 SMTP 客户和接收主机的 SMTP 服务器之间建立的。SMTP不使用中间的邮件服务器。 2. 邮件传送3. 连接释

69、放:邮件发送完毕后,SMTP 应释放 TCP 连接。 计算机网络主讲:南京信息工程大学刘生6.5.3 电子邮件的信息格式电子邮件的信息格式 l一个电子邮件分为信封和内容两大部分。lRFC 822 只规定了邮件内容中的首部(header)格式,而对邮件的主体(body)部分则让用户自由撰写。l用户写好首部后,邮件系统将自动地将信封所需的信息提取出来并写在信封上。所以用户不需要填写电子邮件信封上的信息。l邮件内容首部包括一些关键字,后面加上冒号。最重要的关键字是:To 和 Subject。 计算机网络主讲:南京信息工程大学刘生邮件内容的首部邮件内容的首部 l“To:”后面填入一个或多个收件人的电子

70、邮件地址。用户只需打开地址簿,点击收件人名字,收件人的电子邮件地址就会自动地填入到合适的位置上。l “Subject:”是邮件的主题。它反映了邮件的主要内容,便于用户查找邮件。l抄送 “Cc:” 表示应给某某人发送一个邮件副本。l“From” 和 “Date” 表示发信人的电子邮件地址和发信日期。“Reply-To” 是对方回信所用的地址。 计算机网络主讲:南京信息工程大学刘生6.5.4 邮件读取协议邮件读取协议POP3 和和 IMAPl邮局协议 POP 是一个非常简单、但功能有限的邮件读取协议,现在使用的是它的第三个版本 POP3。lPOP 也使用客户服务器的工作方式。l在接收邮件的用户 P

71、C 机中必须运行 POP 客户程序,而在用户所连接的 ISP 的邮件服务器中则运行 POP 服务器程序。 计算机网络主讲:南京信息工程大学刘生IMAP 协议协议(Internet Message Access Protocol) lIMAP 也是按客户服务器方式工作,现在较新的是版本 4,即 IMAP4。l用户在自己的 PC 机上就可以操纵 ISP 的邮件服务器的邮箱,就像在本地操纵一样。l因此 IMAP 是一个联机协议。当用户 PC 机上的 IMAP 客户程序打开 IMAP 服务器的邮箱时,用户就可看到邮件的首部。若用户需要打开某个邮件,则该邮件才传到用户的计算机上。 计算机网络主讲:南京信

72、息工程大学刘生IMAP 的特点的特点lIMAP最大的好处就是用户可以在不同的地方使用不同的计算机随时上网阅读和处理自己的邮件。lIMAP 还允许收件人只读取邮件中的某一个部分。例如,收到了一个带有视像附件(此文件可能很大)的邮件。为了节省时间,可以先下载邮件的正文部分,待以后有时间再读取或下载这个很长的附件。lIMAP 的缺点是如果用户没有将邮件复制到自己的 PC 机上,则邮件一直是存放在 IMAP 服务器上。因此用户需要经常与 IMAP 服务器建立连接。 计算机网络主讲:南京信息工程大学刘生必须注意必须注意l不要将邮件读取协议 POP 或 IMAP 与邮件传送协议 SMTP 弄混。l发信人的

73、用户代理向源邮件服务器发送邮件,以及源邮件服务器向目的邮件服务器发送邮件,都是使用 SMTP 协议。l而 POP 协议或 IMAP 协议则是用户从目的邮件服务器上读取邮件所使用的协议。 计算机网络主讲:南京信息工程大学刘生HTTPHTTP6.5.5 基于万维网的电子邮件基于万维网的电子邮件l电子邮件从 A 发送到网易邮件服务器是使用 HTTP 协议。l两个邮件服务器之间的传送使用 SMTP。l邮件从新浪邮件服务器传送到 B 是使用 HTTP 协议。ABSMTP网易邮件服务器新浪邮件服务器计算机网络主讲:南京信息工程大学刘生6.5.6 通用因特网邮件扩充通用因特网邮件扩充 MIME1. MIME

74、 概述概述 SMTP 有以下缺点:lSMTP 不能传送可执行文件或其他的二进制对象。lSMTP 限于传送 7 位的 ASCII 码。许多其他非英语国家的文字(如中文、俄文,甚至带重音符号的法文或德文)就无法传送。lSMTP 服务器会拒绝超过一定长度的邮件。l某些 SMTP 的实现并没有完全按照RFC 821的 SMTP 标准。 计算机网络主讲:南京信息工程大学刘生MIME 的特点的特点lMIME 并没有改动 SMTP 或取代它。lMIME 的意图是继续使用目前的RFC 822格式,但增加了邮件主体的结构,并定义了传送非 ASCII 码的编码规则。 计算机网络主讲:南京信息工程大学刘生MIME

75、和和 SMTP 的关系的关系 非 ASCII 码7 位 ASCII 码MIMESMTPMIMESMTP7 位 ASCII 码7 位 ASCII 码非 ASCII 码用户用户计算机网络主讲:南京信息工程大学刘生MIME 主要包括三个部分主要包括三个部分 l5 个新的邮件首部字段,它们可包含在RFC 822首部中。这些字段提供了有关邮件主体的信息。l定义了许多邮件内容的格式,对多媒体电子邮件的表示方法进行了标准化。l定义了传送编码,可对任何内容格式进行转换,而不会被邮件系统改变。计算机网络主讲:南京信息工程大学刘生MIME 增加增加 5 个个新的邮件首部新的邮件首部 lMIME-Version:

76、标志 MIME 的版本。现在的版本号是 1.0。若无此行,则为英文文本。lContent-Description: 这是可读字符串,说明此邮件是什么。和邮件的主题差不多。lContent-Id: 邮件的唯一标识符。 lContent-Transfer-Encoding: 在传送时邮件的主体是如何编码的。lContent-Type: 说明邮件的性质。 计算机网络主讲:南京信息工程大学刘生2. 内容传送编码内容传送编码(Content-Transfer-Encoding) l最简单的编码就是 7 位 ASCII 码,而每行不能超过 1000 个字符。MIME 对这种由 ASCII 码构成的邮件主体

77、不进行任何转换。 l另一种编码称为 quoted-printable,这种编码方法适用于当所传送的数据中只有少量的非 ASCII 码。l对于任意的二进制文件,可用 base64 编码。 计算机网络主讲:南京信息工程大学刘生3. 内容类型内容类型 lMIME着标准规定 Content-Type 说明必须含有两个标识符,即内容类型(type)和子类型(subtype),中间用“/”分开。 lMIME 标准定义了 7 个基本内容类型和 15 种子类型。 计算机网络主讲:南京信息工程大学刘生6.6 动态主机配置协议动态主机配置协议 DHCPl为了将软件协议做成通用的和便于移植,协议软件的编写者把协议软

78、件参数化。这就使得在很多台计算机上使用同一个经过编译的二进制代码成为可能。l一台计算机和另一台计算机的区别,都可通过一些不同的参数来体现。l在软件协议运行之前,必须给每一个参数赋值。 计算机网络主讲:南京信息工程大学刘生协议配置协议配置l在协议软件中给这些参数赋值的动作叫做协议配置。l一个软件协议在使用之前必须是已正确配置的。l具体的配置信息有哪些则取决于协议栈。 计算机网络主讲:南京信息工程大学刘生协议配置(续)协议配置(续)l需要配置的项目 (1) IP 地址 (2) 子网掩码 (3) 默认路由器的 IP 地址 (4) 域名服务器的 IP 地址l这些信息通常存储在一个配置文件中,计算机在引

79、导过程中可以对这个文件进行存取。 计算机网络主讲:南京信息工程大学刘生动态主机配置协议动态主机配置协议 DHCP(Dynamic Host Configuration Protocol) l动态主机配置协议 DHCP 提供了即插即用连网(plug-and-play networking)的机制。l这种机制允许一台计算机加入新的网络和获取IP地址而不用手工参与。计算机网络主讲:南京信息工程大学刘生DHCP 使用客户服务器方式。使用客户服务器方式。l需要 IP 地址的主机在启动时就向 DHCP 服务器广播发送发现报文(DHCPDISCOVER),这时该主机就成为 DHCP 客户。l本地网络上所有主

80、机都能收到此广播报文,但只有 DHCP 服务器才回答此广播报文。lDHCP 服务器先在其数据库中查找该计算机的配置信息。若找到,则返回找到的信息。若找不到,则从服务器的 IP 地址池(address pool)中取一个地址分配给该计算机。DHCP 服务器的回答报文叫做提供报文(DHCPOFFER)。 计算机网络主讲:南京信息工程大学刘生DHCP 中继代理中继代理(relay agent) l并不是每个网络上都有 DHCP 服务器,这样会使 DHCP 服务器的数量太多。现在是每一个网络至少有一个 DHCP 中继代理,它配置了 DHCP 服务器的 IP 地址信息。l当 DHCP 中继代理收到主机发

81、送的发现报文后,就以单播方式向 DHCP 服务器转发此报文,并等待其回答。收到 DHCP 服务器回答的提供报文后,DHCP 中继代理再将此提供报文发回给主机。计算机网络主讲:南京信息工程大学刘生DHCP 中继代理中继代理以单播方式转发发现报文以单播方式转发发现报文 主机DHCP服务器其他网络DHCP中继代理DHCPDISCOVER广播DHCPDISCOVER单播注意:DHCP 报文只是 UDP 用户数据报中的数据。 计算机网络主讲:南京信息工程大学刘生租用期租用期(lease period) lDHCP 服务器分配给 DHCP 客户的 IP 地址的临时的,因此 DHCP 客户只能在一段有限的时

82、间内使用这个分配到的 IP 地址。DHCP 协议称这段时间为租用期。 l租用期的数值应由 DHCP 服务器自己决定。lDHCP 客户也可在自己发送的报文中(例如,发现报文)提出对租用期的要求。 计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPNACK服务器6768UDPUDP客户DHCPACK服务器6768U

83、DPUDP客户DHCPRELEASE服务器6768UDPUDP服务器67UDP被动打开:DHCP 服务器被动打开 UDP 端口 67, 等待客户端发来的报文。计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPNACK服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPRELEASE

84、服务器6768UDPUDP服务器67UDP被动打开:DHCP 客户从 UDP 端口 68 发送 DHCP 发现报文。计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPNACK服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPRELEASE服务器6768UDPUDP服务器67UDP

85、被动打开:凡收到 DHCP 发现报文的 DHCP 服务器 都发出 DHCP 提供报文,因此 DHCP 客户 可能收到多个 DHCP 提供报文。计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPNACK服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPRELEASE服务器6768U

86、DPUDP服务器67UDP被动打开:DHCP 客户从几个 DHCP 服务器中选择 其中的一个,并向所选择的 DHCP 服务 器发送 DHCP 请求报文。计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPNACK服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPRELEASE服务器

87、6768UDPUDP服务器67UDP被动打开:被选择的 DHCP 服务器发送确认报文 DHCPACK,进入已绑定状态,并可 开始使用得到的临时 IP 地址了。计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPNACK服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPRELEASE

88、服务器6768UDPUDP服务器67UDP被动打开DHCP 客户现在要根据服务器提供的租用期 T 设置两个计时器 T1 和 T2,它们的超时时间分别是 0.5T 和 0.875T。当超时时间到就要请求更新租用期。计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPNACK服务器6768UDPUDP客户DHCPAC

89、K服务器6768UDPUDP客户DHCPRELEASE服务器6768UDPUDP服务器67UDP被动打开:租用期过了一半(T1 时间到),DHCP 发送 请求报文 DHCPREQUEST 要求更新租用期。 计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPNACK服务器6768UDPUDP客户DHCPACK服务

90、器6768UDPUDP客户DHCPRELEASE服务器6768UDPUDP服务器67UDP被动打开:DHCP 服务器若同意,则发回确认报文 DHCPACK。DHCP 客户得到了新的租 用期,重新设置计时器。计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPNACK服务器6768UDPUDP客户DHCPACK服务

91、器6768UDPUDP客户DHCPRELEASE服务器6768UDPUDP服务器67UDP被动打开:DHCP 服务器若不同意,则发回否认报文 DHCPNACK。这时 DHCP 客户必须立即 停止使用原来的 IP 地址,而必须重新申 请 IP 地址(回到步骤)。计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPN

92、ACK服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPRELEASE服务器6768UDPUDP服务器67UDP被动打开若 DHCP服 务 器 不 响 应 步 骤 的 请 求 报 文DHCPREQUEST,则在租用期过了 87.5% 时,DHCP 客 户 必 须 重 新 发 送 请 求 报 文 DHCPREQUEST(重复步骤),然后又继续后面的步骤。 计算机网络主讲:南京信息工程大学刘生DHCP 协议的工作过程协议的工作过程 客户DHCPDISCOVER服务器6768UDPUDP客户DHCPOFFER服务器6768UDPUDP客户DHCPREQUEST服务器6

93、768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPREQUEST服务器6768UDPUDP客户DHCPNACK服务器6768UDPUDP客户DHCPACK服务器6768UDPUDP客户DHCPRELEASE服务器6768UDPUDP服务器67UDP被动打开:DHCP 客户可随时提前终止服务器所提供的 租用期,这时只需向 DHCP 服务器发送释 放报文 DHCPRELEASE 即可。计算机网络主讲:南京信息工程大学刘生6.7 简单网络管理协议简单网络管理协议 SNMP6.7.1 网络管理的基本概念网络管理的基本概念l网络管理包括对硬件、软件和人力的使用、综合与协调,以便对

94、网络资源进行监视、测试、配置、分析、评价和控制,这样就能以合理的价格满足网络的一些需求,如实时运行性能,服务质量等。网络管理常简称为网管。l网络管理并不是指对网络进行行政上的管理。计算机网络主讲:南京信息工程大学刘生网络管理的一般模型网络管理的一般模型 管理站因特网网络管理员 被管设备 管理程序(运行 SNMP 客户程序) 代理程序(运行 SNMP 服务器程序)AAAAM 被管设备 被管设备 被管设备MAA 被管设备网管协议计算机网络主讲:南京信息工程大学刘生网络管理模型中的主要构件网络管理模型中的主要构件 l管理站也常称为网络运行中心 NOC (Network Operations Cent

95、er),是网络管理系统的核心。l管理程序在运行时就成为管理进程。l管理站(硬件)或管理程序(软件)都可称为管理者(manager)。lManager 不是指人而是指机器或软件。l网络管理员(administrator) 指的是人。大型网络往往实行多级管理,因而有多个管理者,而一个管理者一般只管理本地网络的设备。计算机网络主讲:南京信息工程大学刘生被管对象被管对象(Managed Object)。l网络的每一个被管设备中可能有多个被管对象。l被管设备有时可称为网络元素或网元。l在被管设备中也会有一些不能被管的对象。 计算机网络主讲:南京信息工程大学刘生代理代理(agent)l在每一个被管设备中都

96、要运行一个程序以便和管理站中的管理程序进行通信。这些运行着的程序叫做网络管理代理程序,或简称为代理。l代理程序在管理程序的命令和控制下在被管设备上采取本地的行动。计算机网络主讲:南京信息工程大学刘生网络管理协议网络管理协议 l网络管理协议,简称为网管协议。l需要注意的是,并不是网管协议本身来管理网络。网管协议就是管理程序和代理程序之间进行通信的规则。l网络管理员利用网管协议通过管理站对网络中的被管设备进行管理。 计算机网络主讲:南京信息工程大学刘生客户服务器方式客户服务器方式l管理程序和代理程序按客户服务器方式工作。l管理程序运行 SNMP 客户程序,向某个代理程序发出请求(或命令),代理程序

97、运行 SNMP 服务器程序,返回响应(或执行某个动作)。l在网管系统中往往是一个(或少数几个)客户程序与很多的服务器程序进行交互。计算机网络主讲:南京信息工程大学刘生网络管理的基本原理网络管理的基本原理l若要管理某个对象,就必然会给该对象添加一些软件或硬件,但这种“添加”必须对原有对象的影响尽量小些。计算机网络主讲:南京信息工程大学刘生SNMP 的指导思想的指导思想lSNMP 最重要的指导思想就是要尽可能简单。lSNMP 的基本功能包括监视网络性能、检测分析网络差错和配置网络设备等。l在网络正常工作时,SNMP 可实现统计、配置、和测试等功能。当网络出故障时,可实现各种差错检测和恢复功能。l虽

98、然 SNMP 是在 TCP/IP 基础上的网络管理协议,但也可扩展到其他类型的网络设备上。 计算机网络主讲:南京信息工程大学刘生SNMP 的管理站和委托代理的管理站和委托代理l整个系统必须有一个管理站。l管理进程和代理进程利用 SNMP 报文进行通信,而 SNMP 报文又使用 UDP 来传送。l若网络元素使用的不是 SNMP 而是另一种网络管理协议,SNMP 协议就无法控制该网络元素。这时可使用委托代理(proxy agent)。委托代理能提供如协议转换和过滤操作等功能对被管对象进行管理。计算机网络主讲:南京信息工程大学刘生SNMP 的网络管理的网络管理由三个部分组成由三个部分组成 lSNMP

99、 本身l管理信息结构 SMI (Structure of Management Information)l管理信息库 MIB (Management Information Base)。 计算机网络主讲:南京信息工程大学刘生SNMPlSNMP 定义了管理站和代理之间所交换的分组格式。所交换的分组包含各代理中的对象(变量)名及其状态(值)。lSNMP 负责读取和改变这些数值。 计算机网络主讲:南京信息工程大学刘生SMIlSMI 定义了命名对象和定义对象类型(包括范围和长度)的通用规则,以及把对象和对象的值进行编码的规则。l这样做是为了确保网络管理数据的语法和语义的无二义性。但从 SMI 的名称并

100、不能看出它的功能。lSMI 并不定义一个实体应管理的对象数目,也不定义被管对象名以及对象名及其值之间的关联。 计算机网络主讲:南京信息工程大学刘生MIBlMIB 在被管理的实体中创建了命名对象,并规定了其类型。计算机网络主讲:南京信息工程大学刘生6.7.2 管理信息结构管理信息结构 SMI lSMI 的功能: (1) 被管对象应怎样命名; (2) 用来存储被管对象的数据类型有哪些种; (3) 在网络上传送的管理数据应如何编码。 计算机网络主讲:南京信息工程大学刘生SMI 规定所有被管对象必须在命名树上规定所有被管对象必须在命名树上 根iso (1)itu-t (0)iso/itu-t (2)d

101、od (6)internet (1) 1.3.6.1 (iso.org.dod.internet)mgmt (2)mib-2 (1) 1.3.6.1.2.1 (iso.org.dod.internet.mgmt.mib-2)org (3)system(1)interface(2)at(3)ip(4)icmp(5)tcp(6)udp(7)egp(8)ipInReceives(3) 1.3.6.1.2.1.4.3(iso.org.dod.internet.mgmt.mib-2.ip.ipinreceives)计算机网络主讲:南京信息工程大学刘生SMI 使用使用 ASN.1 lSMI 标准指明了所有

102、的 MIB 变量必须使用抽象语法记法 1(ASN.1)来定义。lSMI 既是 ASN.1 的子集,又是 ASN.1 的超集。 lASN.1 的记法很严格,它使得数据的含义不存在任何可能的二义性。lSMI 把数据类型分为两大类:简单类型和结构化类型。 计算机网络主讲:南京信息工程大学刘生基本编码规则基本编码规则 BER(Basic Encoding Rule) lISO 在制订 ASN.1 语言的同时也为它定义了一种标准的编码方案,即基本编码规则 BER。lBER 指明了每种数据类型中每个数据的值的表示。l发送端用 BER 编码,可将用 ASN.1 所表述的报文转换成唯一的比特序列。接收端用 B

103、ER 进行解码,得到该比特序列所表示的 ASN.1 报文。 计算机网络主讲:南京信息工程大学刘生用用 TLV 方法进行编码方法进行编码l把各种数据元素表示为以下三个字段组成的八位位组序列:(1) T 字段,即标识符八位位组(identifier octet),用于标识标记。(2) L 字段,即长度用八位位组(length octet),用于标识后面 V 字段的长度。(3) V 字段,即内容八位位组(content octet),用于标识数据元素的值。 计算机网络主讲:南京信息工程大学刘生TLV 中的中的 T 字段字段定义数据的类型定义数据的类型 字节 1 可变 可变标记 T 长度 L 值 V类

104、 别 格 式 编 号位 2 1 5数据元素计算机网络主讲:南京信息工程大学刘生TLV 中的中的 L 字段字段定义定义 V 字段的长度字段的长度 指出 V 字段长度 = 2 字节0 0 0 0 0 0 1 01 0 0 0 0 0 1 00 0 0 0 0 0 0 10 0 0 0 0 1 1 0单字节的 L 字段指出 V 字段长度 = 262 字节多字节的 L 字段指出后续字节数 = 2后续字节数 = 2计算机网络主讲:南京信息工程大学刘生TLV 中的中的 V 字段字段定义数据的值定义数据的值 l例如,INTEGER 15,其 T 字段是02, INTEGER 类型要用 4 字节编码。最后得出

105、 TLV 编码为 02 04 00 00 00 0F。l又如 IPAddress 192.1.2.3,其 T 字段是 40,V 字段需要 4 字节表示,因此得出 IPAddress 192.1.2.3 的 TLV 编码是 40 04 C0 01 02 03。 计算机网络主讲:南京信息工程大学刘生6.7.3 管理信息库管理信息库 MIB(Management Information Base)l被管对象必须维持可供管理程序读写的若干控制和状态信息。这些信息总称为管理信息库 MIB 。l管理程序使用 MIB 中这些信息的值对网络进行管理(如读取或重新设置这些值)。计算机网络主讲:南京信息工程大学刘

106、生6.7.4 SNMP 的的协议数据单元和报文协议数据单元和报文 lSNMP的操作只有两种基本的管理功能,即: “读”操作,用 get 报文来检测各被管对象的状况; “写”操作,用 set 报文来改变各被管对象的状况。计算机网络主讲:南京信息工程大学刘生SNMP 的探询操作的探询操作l探询操作SNMP 管理进程定时向被管理设备周期性地发送探询信息。l探询的好处是:u可使系统相对简单。可使系统相对简单。u能限制通过网络所产生的管理信息的通信量。能限制通过网络所产生的管理信息的通信量。l但探询管理协议不够灵活,而且所能管理的设备数目不能太多。探询系统的开销也较大。如探询频繁而并未得到有用的报告,则

107、通信线路和计算机的 CPU 周期就被浪费了。 计算机网络主讲:南京信息工程大学刘生陷阱陷阱(trap)lSNMP 不是完全的探询协议,它允许不经过询问就能发送某些信息。这种信息称为陷阱,表示它能够捕捉“事件”。l这种陷阱信息的参数是受限制的。l当被管对象的代理检测到有事件发生时,就检查其门限值。代理只向管理进程报告达到某些门限值的事件(即过滤)。过滤的好处是:u仅在严重事件发生时才发送陷阱;仅在严重事件发生时才发送陷阱;u陷阱信息很简单且所需字节数很少。陷阱信息很简单且所需字节数很少。 计算机网络主讲:南京信息工程大学刘生SNMP 是有效的网络管理协议是有效的网络管理协议l使用探询(至少是周期

108、性地)以维持对网络资源的实时监视,同时也采用陷阱机制报告特殊事件,使得 SNMP 成为一种有效的网络管理协议。 计算机网络主讲:南京信息工程大学刘生SNMP 使用无连接的使用无连接的 UDPlSNMP 使用无连接的 UDP,因此在网络上传送 SNMP 报文的开销较小。但 UDP 不保证可靠交付。l在运行代理程序的服务器端用熟知端口 161 来接收 get 或 set 报文和发送响应报文(与熟知端口通信的客户端使用临时端口)。l运行管理程序的客户端则使用熟知端口 162 来接收来自各代理的 trap 报文。 计算机网络主讲:南京信息工程大学刘生SNMPv1 定义的定义的协议数据单元类型(无编号协

109、议数据单元类型(无编号 4) PDU PDU名称 用途编号 0 GetRequest 用来查询一个或一组变量的值 1 GetNextRequest 允许在 MIB 树上读取下一个变量, 此操作可反复进行 2 Reponse 代理向管理者或管理者向管理者发送 响应 3 SetRequest 对一个或多个变量值进行设置 5 GetBulkRequest管理者从代理读取大数据块的值 6 InformRequest 管理者从另一管理者读取代理的变量 7 SNMPv2Trap 代理向管理者报告异常事件 8 Report 管理者之间报告某些差错 计算机网络主讲:南京信息工程大学刘生变量绑定首部上下文引擎

110、ID 上下文名 PDU 类型 请求 ID 差错状态 差错索引 名 值 名 值 SNMP 的报文格式的报文格式 UDP 数据报IP 数据报SNMP 报文 IP 首部UDP 首部SNMP 报文的数据部分 版本首部20 字节 8 字节SNMP PDU安全参数有关加密信息的字段计算机网络主讲:南京信息工程大学刘生name valueGet-request 报文报文 ASN.1 编码编码 V01 03 06 01 02 01 01 01 00 L09 TOBJECT IDENTIFIER TNULL L00 L01 TSEQUENCE L0C L0E L04 TINTEGER L01request-id

111、error-statuserror-indexvariable-bindings TINTEGER V05 AE 56 02 V00 TSEQUENCE OF TINTEGER V00VarBind TA0 L1FGetRequest-PDUrequest-ID1. 3. 6. 1. 2. 1. 7. 1. 0GetRequest-PDU计算机网络主讲:南京信息工程大学刘生6.8 应用进程跨越网络的通信应用进程跨越网络的通信6.8.1 系统调用和应用编程接口系统调用和应用编程接口l大多数操作系统使用系统调用(system call)的机制在应用程序和操作系统之间传递控制权。l对程序员来说,每一

112、个系统调用和一般程序设计中的函数调用非常相似,只是系统调用是将控制权传递给了操作系统。 计算机网络主讲:南京信息工程大学刘生多个应用进程多个应用进程使用系统调用的机制使用系统调用的机制 应用程序 1应用程序 2应用程序 n由应用程序调用的系统函数用户地址空间中的应用程序系统调用接口系统地址空间中的协议软件包括 TCP/IP 协议软件的操作系统内核计算机网络主讲:南京信息工程大学刘生应用编程接口应用编程接口 API(Application Programming Interface) l当某个应用进程启动系统调用时,控制权就从应用进程传递给了系统调用接口。l此接口再将控制权传递给计算机的操作系统

113、。操作系统将此调用转给某个内部过程,并执行所请求的操作。l内部过程一旦执行完毕,控制权就又通过系统调用接口返回给应用进程。l系统调用接口实际上就是应用进程的控制权和操作系统的控制权进行转换的一个接口,即应用编程接口 API。 计算机网络主讲:南京信息工程大学刘生几种应用编程接口几种应用编程接口 API lBerkeley UNIX 操作系统定义了一种 API,它又称为套接字接口(socket interface)。l微软公司在其操作系统中采用了套接字接口 API,形成了一个稍有不同的 API,并称之为 Windows Socket。lAT&T 为其 UNIX 系统 V 定义了一种 API,简写

114、为 TLI (Transport Layer Interface)。 计算机网络主讲:南京信息工程大学刘生应用进程通过套接字接入到网络应用进程通过套接字接入到网络 应用进程TCP由应用程序控制因特网由操作系统控制客户服务器套接字TCP应用进程套接字计算机网络主讲:南京信息工程大学刘生套接字的作用套接字的作用 l当应用进程需要使用网络进行通信时就发出系统调用,请求操作系统为其创建“套接字”,以便把网络通信所需要的系统资源分配给该应用进程。l操作系统为这些资源的总和用一个叫做套接字描述符的号码来表示,并把此号码返回给应用进程。应用进程所进行的网络操作都必须使用这个号码。l通信完毕后,应用进程通过一

115、个关闭套接字的系统调用通知操作系统回收与该“号码”相关的所有资源。计算机网络主讲:南京信息工程大学刘生套接字描述符表(每一个进程一个描述符)0:1:2:3:4:操作系统套接字的数据结构协议族:PF_INET服务:SOCK_STREAM本地 IP 地址:远地 IP 地址:本地端口:远地端口:调用调用 socket 创建套接字创建套接字 计算机网络主讲:南京信息工程大学刘生6.8.2 几种常用的系统调用几种常用的系统调用 1. 连接建立阶段连接建立阶段l当套接字被创建后,它的端口号和 IP 地址都是空的,因此应用进程要调用 bind(绑定)来指明套接字的本地地址。在服务器端调用 bind 时就是把

116、熟知端口号和本地IP地址填写到已创建的套接字中。这就叫做把本地地址绑定到套接字。l服务器在调用 bind 后,还必须调用 listen(收听)把套接字设置为被动方式,以便随时接受客户的服务请求。UDP服务器由于只提供无连接服务,不使用 listen 系统调用。l服务器紧接着就调用 accept(接受),以便把远地客户进程发来的连接请求提取出来。系统调用 accept 的一个变量就是要指明从哪一个套接字发起的连接。 计算机网络主讲:南京信息工程大学刘生6.8.2 几种常用的系统调用几种常用的系统调用 并发方式工作的服务器并发方式工作的服务器 接受连接请求的套接字MS1连接套接字连接套接字连接套接字S2S3操作系统服务器应用进程从属服务器进程主服务器进程(原来的套接字)(新创建的套接字)计算机网络主讲:南京信息工程大学刘生系统调用使用顺序的例子系统调用使用顺序的例子 服务器端socketbindlistenacceptrecvsendclose客户端socketrecvsendcloseconnect连接建立请求计算机网络主讲:南京信息工程大学刘生

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 研究生课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号