计算机网络-应用层

目录

一、应用层概述

二、客户-服务器方式(C/S方式)和对等方式(P2P方式)

(一)客户/服务器 (Client/Server,C/S) 方式

(二)对等(Peer-to-Peer,P2P) 方式

(三)总结

三、动态主机配置协议DHCP

(一)DHCP的工作流程

(二)DHCP中继代理

四、域名系统DNS

五、文件传送协议FTP

六、电子邮件

(一)简单邮件传送协议SMTP (Simple Mail Transfer Protocol)的基本工作原理 

(二)MIME的出现

(三)常用的邮件读取协议

(四)基于万维网的电子邮件


计算机网络系列

计算机网络系列博客
计算机网络-物理层_zoeil的博客-CSDN博客
计算机网络-数据链路层上篇_zoeil的博客-CSDN博客
计算机网络-数据链路层下篇_zoeil的博客-CSDN博客
计算机网络-网络层上篇_zoeil的博客-CSDN博客
计算机网络-网络层下篇_zoeil的博客-CSDN博客
计算机网络-运输层_zoeil的博客-CSDN博客
本篇

一、应用层概述

经过前面几篇文章的学习,我们终于来到了网络最高层——应用层,应用层的作用使解决通过应用进程的交互来实现特定网络应用的问题。

应用层是计算机网络体系结构的最顶层,是设计和建立计算机网络的最终目的,也是计算机网络中发展最快的部分。

  • 早期基于文本的应用(电子邮件、远程登录、文件传输、新闻组)
  • 20世纪90年代将因特网带入干家万户的万维网WWW
  • 当今流行的即时通信、P2P文件共享及各种音视频应用
  • 计算设备的小型化和“无处不在”,宽带住宅接入和无线接入的日益普及和迅速发展,为未来更多的新型应用提供了广阔的舞台。

在本章中,我们以一些经典的网络应用为例来学习有关网络应用的原理、协议和实现方面的知识。

  • 万维网WWW
  • 电子邮件
  • 域名系统DNS
  • 文件传送协议FTP
  • 动态主机配置协议DHCP
  • P2P文件共享
  • 多媒体网络应用 

二、客户-服务器方式(C/S方式)和对等方式(P2P方式)

网络应用程序运行在处于网络边缘的不同的端系统上,通过彼此间的通信来共同完成某项任务。

开发一种新的网络应用首先要考虑的问题就是网络应用程序在各种端系统上的组织方式它们之间的关系

目前流行的主要有以下两种:

  • 客户/服务器 (Client/Server,C/S) 方式
  • 对等(Peer-to-Peer,P2P) 方式

(一)客户/服务器 (Client/Server,C/S) 方式

  • 客户和服务器是指通信中所涉及的两个应用进程。
  • 客户/服务器方式所描述的是进程之间服务和被服务的关系
  • 客户是服务请求方,服务器是服务提供方
  • 服务器总是处于运行状态,并等待客户的服务请求。服务器具有固定端口号 (例如HTTP服务器的默认端口号为80),而运行服务器的主机也具有固定的IP地址。

C/S方式是因特网上传统的、同时也是最成熟的方式,很多我们熟悉的网络应用采用的都是C/S方式。包括万维网WWW、电子邮件、文件传输FTP等。
基于C/S方式的应用服务通常是服务集中型的,即应用服务集中在网络中比客户计算机少得多的服务器计算机上。

  • 由于一台服务器计算机要为多个客户机提供服务,在C/S应用中,常会出现服务器计算机跟不上众多客户机请求的情况
  • 为此,在C/S应用中,常用计算机群集(或服务器场)构建一个强大的虚拟服务器 

(二)对等(Peer-to-Peer,P2P) 方式

在P2P方式中,没有固定的服务请求者和服务提供者,分布在网络边缘各端系统中的应用进程是对等的,被称为对等方。对等方相互之间直接通信每个对等方既是服务的请求者,又是服务的提供者。
目前,在因特网上流行的P2P应用主要包括P2P文件共享、即时通信、P2P流媒体、分布式存储等
基于P2P的应用是服务分散型的,因为服务不是集中在少数几个服务器计算机中,而是分散在大量对等计算机中,这些计算机并不为服务提供商所有,而是为个人控制的桌面计算机和笔记本电脑,它们通常位于住宅、校园和办公室中。

P2P方式的最突出特性之一就是它的可扩展性。因为系统每增加一个对等方,不仅增加的是服务的请求者,同时也增加了服务的提供者,系统性能不会因规模的增大而降低

P2P方式具有成本上的优势,因为它通常不需要庞大的服务器设施和服务器带宽。为了降低成本,服务提供商对于将P2P方式用于应用的兴趣越来越大。

(三)总结

三、动态主机配置协议DHCP

对于下图两台主机,可以通过手工配置ip地址,子网掩码,默认网关,DNS服务器使其能与web服务器通信,但当主机数量大时,手工配置的工作量大,且容易出错!

可以通过配置DHCP服务器让主机自动获取网络配置信息

(一)DHCP的工作流程

DHCP是基于传输层中的UDP协议,即传输的是UDP用户数据报

主机上运行着DHCP客户进程,监听的端口号为68,简称DHCP客户。DHCP服务器上运行着服务端进程,监听的端口号为67,这两个都是熟知端口号。

(1)DHCP客户向所在网络发送DHCP发现报文DHCP DISCOVERY),源IP为0.0.0.0,因为此时还没有配置ip,目的ip地址为广播地址255.255.255.255。报文携带了事务ID,DHCP客户端的MAC地址

(2)网络中的DHCP服务器接收到该DHCP发现报文后,根据其中封装的DHCP客户端的MAC地址来查找自己的数据库,看是否有针对该MAC地址的配置信息,如果有,则使用这些配置信息来构建并发送DHCP提供报文;如果没有则采用默认配置信息并发送DHCP提供报文,封装该报文的IP数据报的源IP地址为DHCP服务器的IP地址,目的地址仍为广播地址,因为此时主机仍未配置ip地址。DHCP提供报文内部封装了事务ID,还有配置信息,如:IP地址,子网掩码,地址租期,默认网关,DNS服务器等。DHCP服务器从自己的IP地址池中挑选待租用给主机的IP地址时,会使用ARP来确保所选IP地址未被网络中其他主机占用

网络中的所有设备都会收到该IP数据报,并对其层层解封,解封出封装有DHCP提供报文的UDP用户数据报。对于DHCP服务器,其应用层没有监听该UDP用户数据报目的端口68的进程,也就是DHCP客户进程,因此,无法交付DHCP提供报文,只能丢弃。而对于DHCP客户,其应用层运行着DHCP客户进程,因此会接收该提供报文并作出相应处理。DHCP客户会根据DHCP提供报文中的事务ID来判断是否是自己所请求的报文。如果ID与自己之前发送DHCP发现报文中封装的事务ID相同,就表明这是自己所请求的报文

(3)DHCP客户此时会收到两个DHCP提供报文,一般会选择先到的那个,然后向所选择的DHCP服务器发送DHCP请求报文,封装该报文的IP数据报的源IP地址仍为0.0.0.0,因为此时才从多个DHCP服务器中挑选一个作为自己的DHCP服务器,首先需要征得该服务器的同意,之后才能正式使用向该DHCP服务器租用的IP地址,目的IP地址仍为广播地址255.255.255.255。DHCP请求报文中封装有事务ID,DHCP客户端的MAC地址,接收的租约中的IP地址,提供此租约的DHCP服务器端的IP地址等信息

(4)在本例中,假设选择DHCP服务器1作为主机的DHCP服务器,于是DHCP服务器1给DHCP客户发送DHCP确认报文,封装该报文的IP数据报的源IP地址为DHCP服务器1的IP地址,目的IP地址仍为广播地址,DHCP收到该确认报文后,就可以使用所租用的IP地址了,需要注意的是,在使用租用的IP地址之前,主机还会使用ARP检测该IP地址是否已被网络中其他主机占用。若被占用: 给DHCP服务器发送“DHCPDECLINE”报文撤销IP地址租约,并重新发送“DHCP DISCOVER”报文:
未被占用: 可以使用租约中的IP地址与网络中其他主机通信了 

(5)当租用期过了一半时,DHCP客户会向DHCP服务器发送DHCP请求报文,来请求更新租用期,源IP地址为租用的地址,目的地址为DHCP服务器1的IP地址。DHCP服务器有三种情况:

情况一:同意,发送回确认报文,DHCP客户得到新的租用期;

情况二: 不同意,DHCP服务器发回DHCP否认报文。DHCP客户必须立即停止使用之前租用的IP地址。并重新发送DHCP发现报文来重新申请IP地址;

情况三:DHCP服务器未响应,则在IP地址租期过了87.5%时,DHCP客户必须重新发送DHCP请求报文,然后继续等待DHCP服务器可能做出的反应,若DHCP服务器仍未做出响应,则当租用期到期后,DHCP客户必须立即停止使用之前租用的IP地址。并重新发送DHCP发现报文来重新申请IP地址

(6)DHCP客户可以随时提前终止DHCP服务器所提供的租用期,只需向DHCP服务器发送DHCP释放报文段即可。

(7)总结

(二)DHCP中继代理

下图中的两台主机不能通过DHCP获取到IP地址,因为路由器对于广播不会进行转发

给该路由器配置DHCP服务器的IP地址并使之成为DHCP中继代理!

四、域名系统DNS

DNS报文使用运输层的UDP协议进行封装,运输层端口号为53

DNS服务器的作用,主机访问某个域名时,通过查询DNS中域名与ip对应的表,可以得到域名的ip,然后进行访问

因特网是否可以只使用一台DNS服务器?

这种做法并不可取。因为因特网的规模很大,这样的域名服务器肯定会因为超负荷而无法正常工作,而且一旦域名服务器出现故障,整个因特网就会瘫痪。
早在1983年,因特网就开始采用层次结构的命名树作为主机的名字 (即域名)并使用分布式的域名系统DNS
DNS使大多数域名都在本地解析,仅少量解析需要在因特网上通信,因此系统效率很高。
由于DNS是分布式系统,即使单个计算机出了故障,也不会妨碍整个系统的正常运行。 

因特网采用层次树状结构的域名结构
域名的结构由若干个分量组成,各分量之间用“点”隔开,分别代表不同级别的域名

  • 每一级的域名都由英文字母和数字组成,不超过63个字符,不区分大小写字母
  • 级别最低的域名写在最左边,而级别最高的顶级域名写在最右边。
  • 完整的域名不超过255个字符.

域名系统既不规定一个域名需要包含多少个下级域名,也不规定每一级的域名代表什么意思。

各级域名由其上一级的域名管理机构管理,而最高的顶级域名则由因特网名称与数字地址分配机构ICANN进行管理

【举例】因特网的域名空间

域名和IP地址的映射关系必须保存在域名服务器中,供所有其他应用查询。显然不能将所有信息都储存在一台域名服务器中DNS使用分布在各地的域名服务器来实现域名到IP地址的转换。
域名服务器可以划分为以下四种不同的类型:

① 根域名服务器
根域名服务器是最高层次的域名服务器,每个根域名服务器都知道所有的顶级域名服务器的域名及其IP地址,因特网上共有13个不同IP地的根域名服务器。尽管我们将这13个根域名服务器中的每一个都视为单个的服务器,但“每台服务器”实际上是由许多分布在世界各地的计算机构成的服务器群集。当本地域名服务器向根域名服务器发出查询请求时,路由器就把查询请求报文转发到离这个DNS客户最近的一个根域名服务器。这就加快了DNS的查询过程,同时也更合理地利用了因特网的资源。根域名服务器通常并不直接对域名进行解析,而是返回该域名所屈顶级域名的顶级域名服务器的IP地址
② 顶级域名服务器

这些域名服务器负责管理在该顶级域名服务器注册的所有二级域名。当收到DNS查询请求时就给出相应的回答 (可能是最后的结果,也可能是下一级权限域名服务器的IP地址)
③ 权限域名服务器
这些域名服务器负责管理某个区的域名。每一个主机的域名都必须在某个权限域名服务器处注册登记。因此权限域名服务器知道其管辖的域名与IP地址的映射关系。另外,权限域名服务器还知道其下级域名服务器的地址.
④ 本地域名服务器
本地域名服务器不属于上述的域名服务器的等级结构,当一个主机发出DNS请求报文时,这个报文就首先被送往该主机的本地域名服务器。本地域名服务器起着代理的作用,会将该报文转发到上述的域名服务器的等级结构中。每一个因特网服务提供者ISP,一个大学,甚至一个大学里的学院,都可以拥有一个本地域名服务器,它有时也称为默认域名服务器。本地域名服务器离用户较近,一般不超过几个路由器的距离,也有可能就在同一个局域网中。本地域名服务器的IP地址需要直接配置在需要域名解析的主机中。

为了提高DNS的查询效率,并减轻根域名服务器的负荷和减少因特网上的DNS查询报文数量,在域名服务器中广泛地使用了高速缓存.高速缓存用来存放最近查询过的域名以及从何处获得域名映射信息的记录 

为了提高DNS的查询效率,并减轻根域名服务器的负荷和减少因特网上的DNS查询报文数量,在域名服务器中广泛地使用了高速缓存。高速缓存用来存放最近查询过的域名以及从何处获得域名映射信息的记录
由于域名到IP地址的映射关系并不是永久不变,为保持高速缓存中的内容正确,域名服务器应为每项内容设置计时器并删除超过合理时间的项 (例如,每个项目只存放两天)
不但在本地域名服务器中需要高速缓存,在用户主机中也很需要。许多用户主机在启动时从本地域名服务器下载域名和IP地址的全部数据库,维护存放自己最近使用的域名的高速缓存,并且只在从缓存中找不到域名时才向域名服务器查询。同理,主机也需要保持高速缓存中内容的正确性。 

五、文件传送协议FTP

将某台计算机中的文件通过网络传送到可能相距很远的另一台计算机中,是一项基本的网络应用,即文件传送
文件传送协议FTP (File Transfer Protocol) 是因特网上使用得最广泛的文件传送协议。

  • FTP提供交互式的访问,允许客户指明文件的类型与格式 (如指明是否使用ASCII码),并允许文件具有存取权限 (如访问文件的用户必须经过授权,并输入有效的口令)。
  • FTP屏蔽了各计算机系统的细节,因而适合于在异构网络中任意计算机之间传送文件

在因特网发展的早期阶段,用FTP传送文件约占整个因特网的通信量的三分之一,而由电子邮件和域名系统所产生的通信量还要小于FTP所产生的通信量。只是到了1995年,万维网WWW的通信量才首次超过了FTP。

FTP的常见用途是在计算机之间传输文件,尤其是用于批量传输文件。
FTP的另一个常见用途是让网站设计者将构成网站内容的大量文件批量上传到他们的Web服务器 

FTP的工作原理 

(一)主动模式

FTP服务端主动向客户端发起连接,通过TCP 21端口进行控制连接;通过TCP 20端口进行数据连接

控制连接在整个会话期间一直保持打开,用于传送FTP相关控制

命令数据连接用于文件传输,在每次文件传输时才建立,传输结束就关闭.

(二)被动模式

FTP服务器被动等待FTP客户的连接

六、电子邮件

电子邮件(E-mail)是因特网上最早流行的一种应用,并且仍然是当今因特网上最重要、最实用的应用之一传统的电话通信属于实时通信,存在以下两个缺点:

  • 电话通信的主叫和被叫双方必须同时在场;
  • 一些不是十分紧迫的电话也常常不必要地打断人们的工作或休息

而电子邮件与邮政系统的寄信相似。

  • 发件人将邮件发送到自己使用的邮件服务器
  • 发件人的邮件服务器将收到的邮件按其目的地址转发到收件人邮件服务器中的收件人邮箱
  • 收件人在方便的时候访问收件人邮件服务器中自己的邮箱,获取收到的电子邮件。

电子邮件使用方便、传递迅速而且费用低廉。它不仅可以传送文字信息,而且还可附上声音和图像.

由于电子邮件的广泛使用,现在许多国家已经正式取消了电报业务。在我国,电信局的电报业务也因电子邮件的普及而濒临消失

电子邮件系统采用客户/服务器方式
电子邮件系统的三个主要组成构件: 用户代理,邮件服务器,以及电子邮件所需的协议

  • 用户代理是用户与电子邮件系统的接口,又称为电子邮件客户端软件
  • 邮件服务器是电子邮件系统的基础设施。因特网上所有的ISP都有邮件服务器,其功能是发送和接收邮件,同时还要负责维护用户的邮箱。 
  • 协议包括邮件发送协议 (例如SMTP)邮件读取协议 (例如POP3,IMAP) 

(一)简单邮件传送协议SMTP (Simple Mail Transfer Protocol)的基本工作原理 

 

电子邮件的信息格式并不是由SMTP定义的,而是在RFC 822中单独定义的。这个RFC文档已在2008年更新为RFC 5322。一个电子邮件有信封内容两部分。而内容又由首部主体两部分构成。

(二)MIME的出现

SMTP协议只能传送ASCII码文本数据,不能传送可执行文件或其他的二进制对象SMTP不能满足传送多媒体邮件(例如带有图片、音频或视频数据)的需要。并且许多其他非英语国家的文字(例如中文、俄文、甚至带有重音符号的法文或德文)也无法用SMTP传送
为解决SMTP传送非ASCII码文本的问题,提出了多用途因特网邮件扩展MIME (Mutipurpose ntemet Mail Extensions)

  • 增加了5个新的邮件首部字段,这些字段提供了有关邮件主体的信息
  • 定义了许多邮件内容的格式,对多媒体电子邮件的表示方法进行了标准化。
  • 定义了传送编码,可对任何内容格式进行转换,而不会被邮件系统改变

实际上,MIME不仅仅用于SMTP,也用于后来的同样面向ASCII字符的HTTP

(三)常用的邮件读取协议

常用的邮件读取协议有以下两个:
邮局协议POP (Post Office Protocol),POP3是其第三个版本,是因特网正式标准。非常简单、功能有限的邮件读取协议。用户只能以下载并删除方式下载并保留方式从邮件服务器下载邮件到用户方计算机。不允许用户在邮件服务器上管理自己的邮件。(例如创建文件夹,对邮件进行分类管理等)
因特网邮件访问协议IMAP (Internet Message Access Protocol),IMAP4是其第四个版本,目前还只是因特网建议标准。

功能比POP3强大的邮件读取协议。用户在自己的计算机上就可以操控邮件服务器中的邮箱,就像在本地操控一样,因此IMAP是一个联机协议

POP3和IMAP4都采用基于TCP连接的客户/服务器方式。POP3使用熟知端口110,IMAP4使用熟
知端口143。

(四)基于万维网的电子邮件


通过浏览器登录(提供用户名和口令)邮件服务器万维网网站就可以撰写、收发、阅读和管理电子邮件。这种工作模式与IMAP很类似,不同的是用户计算机无需安装专门的用户代理程序,只需要使用通用的万维网浏览器
邮件服务器网站通常都提供非常强大和方便的邮件管理功能,用户可以在邮件服务器网站上管理和处理自己的邮件,而不需要将邮件下载到本地进行管理。

  • 24
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 21
    评论
计算机网络应用层涵盖了广泛的知识点。其中一些重要的知识点包括网络的作用范围和使用者、计算机网络的层次结构、ICMP协议的应用、网络层的路由概述、IP网际协议以及私有网络的使用。 网络的作用范围可分为广域网(WAN)、城域网(MAN)和局域网(LAN),而根据网络使用者的分类,可以分为公用网络和专用网络计算机网络的层次结构是指将网络功能划分为不同的层次,以便更好地管理和实现网络通信。常见的网络层次结构包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层。 ICMP协议是应用于网络层的一种协议,它具有多种应用,其中包括Ping应用和Traceroute应用。Ping应用用于网络故障的排查,而Traceroute应用则可以探测IP数据报在网络中走过的路径。 网络层的路由概述指的是在网络中将数据包从源主机发送到目标主机的过程。路由器是网络层的设备,它能够决定数据包的最佳路径,并进行转发。路由器之间的通信使用路由协议来交换路由信息,以便实现数据包的正确传输。 IP网际协议是网络层最核心的协议之一,它负责将数据包从源主机传输到目标主机。通过使用IP协议,物理设备之间的差异被屏蔽,从而形成了虚拟互联网络。当主机使用IP协议连接时,无需关注网络细节,便能建立虚拟网络。 在多个主机通过一个公有IP访问互联网的私有网络中,私有网络可以减缓IP地址的消耗,但也增加了网络通信的复杂度。 综上所述,计算机网络应用层知识点汇总包括网络的作用范围和使用者、计算机网络的层次结构、ICMP协议的应用、网络层的路由概述、IP网际协议以及私有网络的使用。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 21
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zoeil

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值