目录
6.1 网络应用模型
6.1.1 应用层概述
6.1.2 网络应用模型
1 客户/服务器模型(Client/Server)
2 P2P模型(Peer-to-peer)
6.2 DNS系统(53端口、UDP连接)
6.2.1 层次域名空间
1 命名方法
2 域名空间的树状结构
6.2.2 域名服务器
6.2.3 域名解析过程(解析为IP地址)
6.3 文件传输协议FTP(端口号21、TCP连接)
6.3.1 FTP的工作原理
1 文件传送协议
2 FTP服务器和用户端
3 FTP工作原理
6.3.2 控制连接与数据连接
6.4 电子邮件
6.4.1 电子邮件系统概述
1 电子邮件的信息格式
2 组成结构
6.4.2 SMTP协议(TCP连接、端口号25、C/S)
1 简单邮件传输协议SMPT
2 通用因特网邮件扩充MIME
6.4.3 POP3协议(TCP连接、端口号110、C/S)
1 邮局协议POP3
2 网际报文存取协议IMAP
6.4.4 基于万维网的电子邮件(使用HTTP协议)
6.5 万维网WWW和HTTP协议(端口号80)
6.5.1 WWW的概念与组成结构(CS)
6.5.2 超文本传输协议HTTP
1 HTTP操作过程
2 HTTP协议的特点
3 报文结构
6.6 远程终端协议Telnet(端口号23)
6.7 简单网络管理协议SNMP(代理端口号161、UDP)
6.7.1 网络管理的基本概念
1 为什么要有网络管理
2 网络管理中的主要构件
3 简单网络管理协议(SNMP Simple Network Management Protocol)
4 网络管理的基本原理
6.7.2 SNMP的协议数据单元和报文
应用层对应用程序的通信提供服务。
应用层协议定义:
应用层的功能:
应用层的重要协议:
客户/服务器模型(Client/Server)
P2P模型(Peer-to-peer)
服务器:提供计算服务的设备。
客户机:请求计算服务的主机。
应用: Web,文件传输FTP, 远程登录,电子邮件
P2P模型特点:
域名系统(Domain Name System, DNS):是因特网使用的命名系统,用来把便于人们记忆的具有特定含义的主机名(如www.cskaoyan.com)转换为便于机器处理的IP地址。相对于IP地址,人们更喜欢使用具有特定含义的字符串来标识因特网上的计算机。值得注意的是,DNS系统采用客户/服务器模型,其协议运行在UDP之上,使用53号端口。
域名组成:字符、数字和符号
从概念上可将DNS分为3部分:层次域名空间、域名服务器和解析器。
DNS系统实现域名到ip地址的转换
因特网采用层次树状结构的命名方法。采用这种命名方法,任何一个连接到因特网的主机或路由器,都有一个唯一的层次结构名称,即域名(Domain Name)。 域(Domain) 是名字空间中一个可被管理的划分。域还可以划分为子域,而子域还可以继续划分为子域的子域,这样就形成了顶级域、二级域、三级域等。每个域名都由标号序列组成,而各标号之间用点(“.”) 隔开。
关于域名中的标号有以下几点需要注意:
1)标号中的英文不区分大小写。
2)标号中除连字符(-) 外不能使用其他的标点符号。
3)每个标号不超过63个字符,多标号组成的完整域名最长不超过255个字符。
4)级别最低的域名写在最左边,级别最高的顶级域名写在最右边。
在域名系统中,每个域分别由不同的组织进行管理。每个组织都可以将它的域再分成一定数目的子域,并将这些子域委托给其他组织去管理。例如,管理CN域的中国将EDU.CN子域授权给中国教育和科研计算机网(CERNET)来管理。
DNS的层次结构:
根域名服务器:根域名服务器是最高层次的域名服务器,所有的根域名服务器都知道所有的顶级域名服务器的IP地址。根域名服务器也是最重要的域名服务器,不管是哪个本地域名服务器,若要对因特网上任何一个域名进行解析,只要自己无法解析,就首先要求助于根域名服务器。因特网上有13个根域名服务器,尽管我们将这13个根域名服务器中的每个都视为单个服务器,但每个“服务器”实际上是冗余服务器的集群,以提供安全性和可靠性。需要注意的是,根域名服务器用来管辖顶级域(如.com),通常它并不直接把待查询的域名直接转换成IP地址,而是告诉本地域名服务器下一步应当找哪个顶级域名服务器进行查询。
顶级域名服务器:这些域名服务器负责管理在该顶级域名服务器注册的所有二级域名。收到DNS查询请求时,就给出相应的回答(可能是最后的结果,也可能是下一步应当查找的域名服务器的IP地址)。
权限域名服务器:每台主机都必须在授权域名服务器处登记。为了更加可靠地工作,一台主机最好至少有两个授权域名服务器。实际上,许多域名服务器都同时充当本地域名服务器和授权域名服务器。授权域名服务器总能将其管辖的主机名转换为该主机的IP地址。
本地域名服务器:本地域名服务器对域名系统非常重要。每个因特网服务提供者(ISP), 或一所大学,甚至一所大学中的各个系,都可以拥有一个本地域名服务器。当一台主机发出DNS查询请求时,这个查询请求报文就发送给该主机的本地域名服务器。事实上,我们在Windows系统中配置“本地连接”时,就需要填写DNS地址,这个地址就是本地DNS (域名服务器)的地址。
域名解析有两种方式:递归查询和递归与迭代相结合的查询
(1)主机向本地域名服务器的查询采用的是递归查询
也就是说,如果本地主机所询问的本地域名服务器不知道被查询域名的IP地址,那么本地域名服务器就以DNS客户的身份(主机靠本地域名服务器),向根域名服务器继续发出查询请求报文(即替该主机继续查询),而不是让该主机自己进行下一步的查询。在这种情况下,本地域名服务器只需向根域名服务器查询一次,后面的几次查询都是递归地在其他几个域名服务器之间进行的[见下图a中的步骤③~⑥]。在步骤⑦中,本地域名服务器从根域名服务器得到了所需的IP地址,最后在步骤⑧中,本地域名服务器把查询结果告诉主机m.xyz.com。
(2)本地域名服务器向根域名服务器的查询采用迭代查询
当根域名服务器收到本地域名服务器发出的迭代查询请求报文时,要么给出所要查询的IP地址,要么告诉本地域名服务器:“你下一步应当向哪个顶级域名服务器进行查询”。然后让本地域名服务器自己(本地域名服务器靠自己)向这个顶级域名服务器进行后续的查询,如图(b)所示。 同样,顶级域名服务器收到查询报文后,要么给出所要查询的IP地址,要么告诉本地域名服务器下一步应向哪个权限域名服务器查询。最后,知道所要解析的域名的IP地址后,把这个结果返回给发起查询的主机。
高速缓存:为了提高DNS的查询效率,并减少因特网上的DNS查询报文数量,在域名服务器中广泛地使用了高速缓存。当一个DNS服务器接收到DNS查询结果时,它能将该DNS信息缓存在高速
缓存中。这样,当另一个相同的域名查询到达该DNS服务器时,该服务器就能够直接提供所要求的IP地址,而不需要再去向其他DNS服务器询问。因为主机名和IP地址之间的映射不是永久的,所以DNS服务器将在一段时间后丢弃高速缓存中的信息。
文件传送协议FTP ( File Transfer Protocol)功能:
简单文件传送协议TFTP (Trivial File Transfer Protocol):
FTP是基于客户/服务器(C/S)的协议。
用户通过一个客户机程序连接至在远程计算机上运行的服务器程序。
依照FTP协议提供服务,进行文件传送的计算机就是FTP服务器。
连接FTP服务器,遵循FTP协议与服务器传送文件的电脑就是FTP客户端。
登陆:ftp地址 用户名&密码
匿名登陆:
FTP使用TCP实现可靠传输
服务器进程:
服务器进程工作步骤:
FTP服务器必须在整个会话期间保留用户的状态信息。特别是服务器必须把指定的用户账户与控制连接联系起来,服务器必须追踪用户在远程目录树上的当前位置。
两个圆柱表示系统正在运行的进程。FTP在工作时使用两个并行的TCP连接:一个是控制连接(端口号21),一个是数据连接(端口号20)。使用两个不同的端口号可使协议更加简单和更容易实现。这两个连接就是从属进程。
控制连接:
数据连接:
FTP传输模式:
因为FTP使用了一个分离的控制连接,所以也称FTP的控制信息是带外(Out-of-band) 传送的。使用FTP时,若要修改服务器上的文件,则需要先将此文件传送到本地主机,然后再将修改后的文件副本传送到原服务器。网络文件系统(NFS)允许进程打开一个远程文件,并在该文件的某个特定位置开始读写数据。这样,NFS可使用户复制一个大文件中的一个很小的片段,而不需要复制整个大文件。
客户A要给客户B发邮件,在客户端软件写好邮件后发送,先到发送方邮件服务器上,然后发送到接收方邮件服务器上,最后发送给客户B的客户端上。
SMTP(Simple Mail Transfer Protocol)规定了在两个相互通信的SMTP进程之间应如何交换信息。
SMTP的缺点:
MIME可以理解为在SMTP协议上的一种扩充手段
MIME原理图:
MIME功能:使电子邮件系统可以支持声音、图像、视频、多种国家语言等等。使得传输内容丰富多彩 。
MIME最早应用于邮件扩充,但是现在逐步应用于浏览器。
Post office protocol:POP
POP3特点:TCP连接、端口号110、C/S网络应用模型
POP3工作方式:(接收方把邮件从接收端邮件服务器读取出来后,对邮件的处理有两种方式。)
可以看出邮局协议POP3是非常简单、功能有限的一种邮件读取协议,对于邮件要么下载保留要么下载删除,不能根据用户需要决定是否上传到用户计算机上。因此有一种新的网际报文存取协议IMAP。
IMAP协议比POP协议复杂。当用户PC上的IMAP客户程序打开IMAP服务器的邮箱时,用户可以看到邮箱的首部,若用户需要打开某个邮件,该邮件才上传到用户的计算机上。
IMAP可以让用户在不同的地方使用不同的计算机随时上网阅读处理邮件,还允许只读取邮件中的某一个部分(先看正文,有WiFi的时 候再下载附件)。
现在日常生活中普遍使用的一种发邮件方式。通过使用浏览器,登陆电子邮箱,就可以发送邮件了。不需要下载邮件客户端。
特点:用户代理发送邮件和读取邮件都使用HTTP协议。邮件服务器直接的发送环节还是使用SMTP协议(简单邮件传输协议)。
万维网www是什么:万维网www (World Wide Web)是一个大规模的、联机式的信息储藏所/资料空间,是无数个网络站点和网页的集合。
如何访问/获取这些资源:统一资源定位符URL唯一标识——>资源(文件、视频、音频...)
URL一般形式:
如何操作才能定位到资源:用户通过点击超链接( http://www.baidu.com)获取资源,这些资源通过超文本传输协议(HTTP)传送给使用者。
万维网以客户/服务器(C/S)方式工作:用户使用的浏览器就是万维网客户程序,万维网文档所驻留的主机运行服务器程序。
万维网文档如何显示:万维网使用超文本标记语HTML)使得万维网页面设计者可以很方便地从一个界面的链接转到另一个界面,并能够在自己的屏幕上显示出来。
HTTP协议功能:HTTP(Hyper Text Transfer Protocol)协议定义了浏览器(万维网客户进程)怎样向万维网服务器请求万维网文档,以及服务器怎样把文档传送给浏览器。
从协议执行过程来说,浏览器要访问WWW服务器时,首先要完成对WWW服务器的域名解析。一旦获得了服务器的IP地址,浏览器就通过TCP向服务器发送连接建立请求。
万维网工作过程:
用户浏览页面方法:
假如客户点击超链接,接下来发生的事件顺序如下:
非持久连接:对于非持久连接,每个网页元素对象(如JPEG图形、Flash等)的传输都需要单独建立一个TCP连接,如图所示(第三次握手的报文段中捎带了客户对万维网文档的请求)。也就是说,请求一个万维网文档所需的时间是该文档的传输时间(与文档大小成正比)加上两倍往返时间RTT
(一个RTT用于TCP连接,另一个RTT用于请求和接收文档)。
持久连接:所谓持久连接,是指万维网服务器在发送响应后仍然保持这条连接,使同一个客户和服务器可以继续在这条连接上传送后续的HTTP请求与响应报文。
HTTP报文
请求报文
响应报文
报文格式:HTTP报文是面向文本的,因此在报文中的每一个字段都是一些ASCII码串。
举例:
Telnet协议是TCP/IP协议族中的一员,是Internet远程登录服务的标准协议和主要方式。它为用户提供了在本地计算机上完成远程主机工作的能力。在终端使用者的电脑上使用telnet程序,用它连接到服务器。终端使用者可以在telnet程序中输入命令,这些命令会在服务器上运行,就像直接在服务器的控制台上输入一样。可以在本地就能控制服务器。要开始一个telnet会话,必须输入用户名和密码来登录服务器。Telnet是常用的远程控制Web服务器的方法。
网络上运行着多种协议的结点(主要是路由器),这些结点在交换信息,所以网络的状态在不断变化。我们必须使用一种机制来读取结点上的状态信息。→网络管理!
管理站中的构件:管理程序
被管设备中的程序:网络管理代理程序,检查代理(agent)
还有一个重要构件:网络管理协议,简称网管协议。
按客户服务器的方式工作:管理程序运行SNMP客户程序,代理程序运行SNMP服务器程序。
SNMP的网络管理:SNMP本身(完成网管的动作)、管理信息结构SMI(建立规则)、管理信息库MIB(对变量进行说明)
若要管理某个对象,就必然会给该对象添加一些软件或硬件,但这种“添加”对原有对象的影响必须尽量小些。
SNMP使用无连接的UDP,因此在网络上传送SNMP报文的开销较小。
SNMP使用UDP的方法有些特殊: