计算机系统(五):计算机网络和因特网

目录

引言

5.1 什么是因特网

5.1.1 具体构成描述

5.1.2 什么是协议

5.1.2.1 人类活动的类比

5.1.2.2 网络协议

5.2 网络边缘

5.2.1 接入网

5.3  协议层次及其服务模型

5.3.1 分层的体系结构

5.3.1.1 协议分层

5.3.1.2 OSI模型

5.3.2 封装


引言

“计算机网络和因特网”系列学习的目标是从整体上粗线条地勾画出计算机网络的概貌。这几篇博客将包括大量的背景知识,讨论大量的计算机网络构件,而且将它们放在整个网络的大环境中进行讨论。

5.1 什么是因特网

我们使用一种特定的计算机网络,即公共因特网,作为讨论计算机网络及其协议的主要载体。但什么是因特网?回答这个问题有两种方式:

其一,我们能够描述因特网的具体构成,即构成因特网的基本硬件和软件组件;

其二,我们能够根据为分布式应用提供服务的联网基础设施来描述因特网。

5.1.1 具体构成描述

因特网是一个世界范围的计算机网络,即它是一个互联了遍及全世界的数以亿计的计算设备的网络。除了传统的桌面PC、Linux工作站以及所谓的服务器。然而,越来越多的非传统的因特网端系统(如便携机、智能手机、平板电脑、电视、游戏机、Web相机、汽车、环境传感设备、数字相框、家用电器)和安全系统,正在与因特网相连。的确,在许多非传统设备连接到因特网的情况下,计算机网络这个术语开始听起来有些过时了。用因特网术语来说,所有这些设备都称为主机(host)或端系统(end system)

计算机系统(五):计算机网络和因特网_第1张图片

端系统通过通信链路(communicationlink)分组交换机(packetswitch)连接到一起。

通信链路

不同类型的通信链路,它们由不同类型的物理媒体组成。这些物理媒体包括同轴电缆、铜线、光纤和无线电频谱。不同的链路能够以不同的速率传输数据,链路的传输速率以比特/秒度量(bit/s,或bps)。

分组

当一台端系统要向另一台端系统发送数据时,发送端系统将数据分段,并为每段加上首部字节。由此形成的信息包用计算机网络的术语来说称为分组(packet)。这些分组通过网络发送到目的端系统,在那里被装配成初始数据。

分组交换机

分组交换机从它的一条入通信链路接收到达的分组,并从它的一条出通信链路转发该分组。市面上流行着各种类型、各具特色的分组交换机,但在当今的因特网中,两种最著名的类型是路由器(router)链路层交换机(link-layer switch)。 这两种类型的交换机朝着最终目的地转发分组。

链路层交换机通常用于接入网中,而路由器通常用于网络核心中。从发送端系统到接收端系统,一个分组所经历的一系列通信链路和分组交换机称为通过该网络的路径(route or path)。因特网所承载的精确通信量是难以估算的。

举一个现实生活中的例子来描述这个过程:

用于传送分组的分组交换网络在许多方面类似于承载运输车辆的运输网络,该网络包括了高速公路、公路和立交桥。一个工厂需要将大量货物搬运到数千公里以外的某个目的地仓库。在工厂中,货物要分开并装上卡车车队。然后,每辆卡车独立地通过高速公路、公路和立交桥组成的网络向该仓库运送货物。在目的地仓库,卸下这些货物,并且与一起装载的同一批货物的其余部分堆放在一起。因此,在许多方面,分组类似于卡车,通信链路类似于高速公路和公路,分组交换机类似于立交桥,而端系统类似于建筑物。就像卡车选取运输网络的一条路径前行一样, 分组则选取计算机网络的一条路径前行。

端系统通过因特网服务提供商(InternetServiceProvider,ISP)接入因特网,包括如本地电缆或电话公司那样的住宅区ISP、公司ISP、大学ISP,以及那些在机场、旅馆、咖啡店和其他公共场所提供WiFi接入的ISP。

每个ISP是一个由多个分组交换机和多段通信链路组成的网络。各ISP为端系统提供了各种不同类型的网络接入。ISP也为内容提供者提供因特网接入服务,将Web站点直接接入因特网。因特网就是将端系统彼此互联,因此为端系统提供接入的ISP也必须互联。低层的ISP通过国家的、国际的高层ISP(如Level 3 Communications、AT&T、Sprint和NTT)互联起来。高层ISP是由通过高速光纤链路互联的高速路由器组成的。无论是高层还是低层ISP网络,它们每个都是独立管理的,运行着IP协议,遵从一定的命名和地址习惯。

端系统、分组交换机和其他因特网部件都要运行一系列协议(protocol),这些协议控制因特网中信息的接收和发送。TCP(Transmission Control Protocol,传输控制协议)IP(Internet Protocol,网际协议)是因特网中两个最为重要的协议。IP 协议定义了在路由器和端系统之间发送和接收的分组格式。因特网的主要协议统称为TCP/IP

5.1.2 什么是协议

5.1.2.1 人类活动的类比

理解计算机网络协议概念,可以先与某些人类活动进行类比,因为我们人类无时无刻不在执行协议。考虑当你想要向某人询问时间时将要怎样做。下图显示了一种典型的交互过程:

计算机系统(五):计算机网络和因特网_第2张图片

人类协议要求一方首先进行问候(图中的第一个“你好”),以开始与另一个人的通信。对“你好”的典型响应是返回一个“你好”报文。此人用一个热情的“你好”进行响应,隐含着一种指示,表明能够继续向那人询问时间了。对最初的“你好”的不同响应(例如“不要烦我!”,或“我不会说英语”,或某些不合时宜的回答)也许表明了一个勉强的或不能进行的通信。在此情况下,按照人类协议,发话者也许将不能够询问时间了。有时,我们甚至根本得不到任何回答,在此情况下,发话者通常会放弃向这个人询问时间。注意在我们人类协议中,有我们发送的特定报文,也有我们根据接收到的应答报文或其他事件采取的动作(例如在某个给定的时间内没有回答)。显然,发送和接收的报文,以及这些报文发送和接收或其他事件出现时所采取的动作,这些在一个人类协议中起到了核心作用。

如果人们使用不同的协议(例如,如果一个人讲礼貌,而另一人不讲礼貌,或一个人明白时间这个概念,而另一人却不知道),该协议就不能互动,因而不能完成有用的工作。在网络中这个道理同样成立。即为了完成一项工作,要求两个(或多个)通信实体运行相同的协议。

5.1.2.2 网络协议

网络协议类似于人类协议,除了交换报文和采取动作的实体是某些设备的硬件或软件组件。在因特网中,凡是涉及两个或多个远程通信实体的所有活动都受协议的制约。

以大家可能熟悉的一个计算机网络协议为例,考虑当你向一个Web服务器发出请求(即你在Web浏览器中键入一个Web网页的URL)时所发生的情况下图分显示了这种情形。首先,你的计算机将向该Web服务器发送一条连接请求报文, 并等待回答。

计算机系统(五):计算机网络和因特网_第3张图片

该Web服务器将最终能接收到连接请求报文,并返回一条连接响应报文。得知请求该Web文档正常以后,计算机则在一条GET报文中发送要从这台Web服务器上取回的网页名字。最后,Web服务器向计算机返回该Web网页(文件)。

从上述例子可见,报文的交换以及发送和接收报文时采取的动作是定义一个协议的关键元素:

一个协议定义了在两个或多个通信实体之间交换的报文格式和次序,以及报文发送和/或接收一条报文或其他事件所采取的动作

因特网(更一般地说是计算机网络)广泛地使用了协议。不同的协议用于完成不同的通信任务。某些协议简单而直截了当,而另一些协议则复杂且晦涩难懂。掌握计算机网络领域知识的过程就是理解网络协议的构成、原理和工作方式的过程。

5.2 网络边缘

上面,我们给出的是因特网和网络协议的总体概述。现在我们将更深入一些来探究计算机网络(特别是因特网)的部件。我们先从网络边缘开始,观察一下我们更为熟悉的部件,即计算机、智能手机和我们日常使用的其他设备。

我们通常把与因特网相连的计算机和其他设备称为端系统。如图所示:

计算机系统(五):计算机网络和因特网_第4张图片

因为它们位于因特网的边缘,故而被称为端系统。

因特网的端系统包括:

  • 桌面计算机(例如,桌面PC、Mac 和Linux盒)
  • 服务器(例如,Web和电子邮件服务器)
  • 移动计算机(例如,便携机、智能手机和平板电脑)。
  • 此外,越来越多的非传统设备正被作为端系统与因特网相连。

端系统也称为主机(主机=端系统

因为它们容纳(即运行)应用程序,如Web浏览器程序、Web服务器程序、电子邮件阅读程序或电子邮件服务器程序等。

主机有时又被进一步划分为两类:客户(client)服务器(server)

客户非正式等同于桌面PC、移动PC和智能手机等

服务器非正式等同于更强大的机器,用于存储和发布Web页面、流视频、中继电子邮件等。

今天,大部分提供搜索结果、电子邮件、Web页面和视频的服务器都属于大型数据中心(data center)。例如,谷歌公司(Google)拥有30 ~ 50个数据中心,其中许多数据中心都有10万台以上的服务器。

5.2.1 接入网

考虑了位于“网络边缘”的应用程序和端系统后,我们接下来再考虑接入网(access network)。

接入网

这是指将端系统连接到其边缘路由器(edge router)的物理链路。

边缘路由器是端系统到任何其他远程端系统的路径上的第一台路由器。下图用粗的、带阴影的线显示了几种类型的接入链路和使用接入网的几种环境(家庭、公司和广域移动无线)。

计算机系统(五):计算机网络和因特网_第5张图片

关于接入网更多的细节,我们暂时不在这里赘述,我们尽快的进入正题,讲一讲有关协议的知识。

5.3  协议层次及其服务模型

从我们到目前的讨论来看,因特网是一个极为复杂的系统。我们已经看到,因特网有许多部分:大量的应用程序和协议、各种类型的端系统、分组交换机和各种类型的链路级媒体。面对这种巨大的复杂性,存在着组织网络体系结构的希望吗?或者至少存在着我们对网络体系结构进行讨论的希望吗?幸运的是,对这两个问题的回答都是肯定的。

5.3.1 分层的体系结构

在试图组织我们关于因特网体系结构的想法之前,先看一个人类社会与之类比的例子。实际上,在日常生活中我们一直都与复杂系统打交道。想象一下有人请你描述航线系统的情况吧。你怎样用一个结构来描述这样一个复杂的系统?该系统具有票务代理、行李检查、登机口人员、飞行员、飞机、空中航行控制和世界范围的导航系统。描述这种系统的一种方式是,描述当你乘某个航班时,你(或其他人替你)要采取的一系列动作。你要购买机票,托运行李,去登机口,并最终登上这次航班。该飞机起飞,飞行到目的地。当飞机着陆后,你从登机口离机并认领行李。如果这次行程不理想,你向票务机构投诉这次航班(你的努力一无所获)。下图显示了相关情况。

计算机系统(五):计算机网络和因特网_第6张图片

我们已经能从这里看出与计算机网络的某些类似:航空公司把你从源送到目的地;而分组被从因特网中的源主机送到目的主机。但这不是我们寻求的完全的类似。我们在上图寻找某些结构。观察上图我们注意到在每一端都有票务功能;还对已经检票的乘客有行李功能,对已经检票并已经检查过行李的乘客有登机功能。对于那些已经通过登机的乘客(即已经经过检票、行李检查和通过登机的乘客),有起飞和着陆的功能,并且在飞行中,有飞机按预定路线飞行的功能。这提示我们能够以水平的方式看待这些功能,如下图所示。

计算机系统(五):计算机网络和因特网_第7张图片

上图将航线功能划分为一些层次,提供了我们能够讨论航线旅行的框架。值得注意的是每个层次与其下面的层次结合在一起,实现了某些功能、服务。在票务层及以下,完成了一个人的航线柜台到航线柜台的转移。在行李层及以下,完成了人和行李的行李托运到行李认领的转移。值得注意的是行李层仅对已经完成票务的人提供服务。在登机口层,完成了人和行李的离港登机口到到港登机口的转移。在起飞/着陆层,完成了一个人及其行李的跑道到跑道的转移。

每个层次通过以下方式提供服务:

在这层中执行了某些动作(eg. 在登机口层,某飞机的乘客登机和离机);

使用下一层的服务(eg. 在登机口层,使用起飞/着陆层的跑道到跑道的旅客转移服务)。

我们为什么要使用分层的体系结构呢?

利用分层的体系结构,我们可以讨论一个定义良好的、大而复杂系统的特定部分。这种简化本身由于提供模块化而具有很高价值,这使实现由层所提供的服务易于改变。只要该层对其上面的层提供相同的服务,并且使用来自下面层次的相同服务,当某层的实现变化时,该系统的其余部分保持不变。(值得注意的是,改变一个服务的实现与改变服务本身是极为不同的!)例如,如果登机口功能被改变了(例如让人们按身高登机和离机),航线系统的其余部分将保持不变,因为登机口仍然提供相同的功能(人们登机和离机);改变后,它仅是以不同的方式实现了该功能。对于大而复杂且需要不断更新的系统,改变服务的实现而不影响该系统其他组件是分层的另一个重要优点

5.3.1.1 协议分层

上面的讨论都是为了让我们更好的理解网络协议的分层。为了给网络协议的设计提供一个结构,网络设计者以分层(layer)的方式组织协议以及实现这些协议的网络硬件和软件。每个协议属于这些层次之一。我们再次关注某层向它的上一层提供的服务(service),即所谓一层的服务模型(service model)。

每层通过在该层中执行某些动作或使用直接下层的服务来提供服务。

例如,由第n层提供的服务可能包括报文从网络的一边到另一边的可靠传送。这可能是通过使用第n-1层的边缘到边缘的不可靠报文传送服务,加上第n层的检测和重传丢失报文的功能来实现的。

一个协议层能够用软件、硬件或两者的结合来实现。诸如HTTP和SMTP这样的应用层协议几乎总是在端系统中用软件实现的,运输层协议也是如此。因为物理层和数据链路层负责处理跨越特定链路的通信,它们通常是实现在与给定链路相联系的网络接口卡(例如以太网或WiFi接口卡)中。网络层经常是硬件和软件实现的混合体。还要注意的是,如同分层的航线体系结构中的功能分布在构成该系统的各机场和飞行控制中心中一样,一个第n层协议也分布在构成该网络的端系统、分组交换机和其他组件中。这就是说,第n层协议的不同部分常常位于这些网络组件的各部分中。

协议分层具有概念化和结构化的优点。如我们看到的那样,分层提供了一种结构化方式来讨论系统组件。模块化使更新系统组件更为容易。

但是某些研究人员和联网工程师激烈地反对分层。分层的一个潜在缺点是一层可能冗余较低层的功能。例如,许多协议栈在基于每段链路和基于端到端两种情况下,都提供了差错恢复。第二种潜在的缺点是某层的功能可能需要仅在其他某层才出现的信息(如时间戳值),这违反了层次分离的目标。

将这些综合起来,各层的所有协议被称为协议栈(protocol stack)。因特网的协议栈由5个层次组成:物理层、链路层、网络层、运输层和应用层(如下图所示)。

计算机系统(五):计算机网络和因特网_第8张图片

应用层

应用层是网络应用程序及它们的应用层协议存留的地方。

因特网的应用层包括许多协议,例如HTTP(它提供了Web文档的请求和传送),SMTP(它提供了电子邮件报文的传输)和FTP(它提供两个端系统之间的文件传送)。我们将看到,某些网络功能,如将端系统名字转换为32比特网络地址,也是借助于特定的应用层协议即域名系统(DNS)完成的。应用层协议分布在多个端系统上,一个端系统中的应用程序使用协议与另一个端系统中的应用程序交换信息的分组。

我们把这种位于应用层的信息分组称为报文(message)

运输层

因特网的运输层在应用程序端点之间传送应用层报文。

在因特网中,有两个运输协议,即TCP和UDP,利用其中的任一个都能运输应用层报文。

TCP

TCP向它的应用程序提供了面向连接的服务。这种服务包括了应用层报文向目的地的确保传递和流量控制(即发送方/接收方速率匹配)。TCP也将长报文划分为短报文,并提供拥塞控制机制,因此当网络拥塞时,源抑制其传输速率。

UDP

UDP协议向它的应用程序提供无连接服务。这是一种不提供不必要服务的服务,没有可靠性,没有流量控制,也没有拥塞控制。

我们把运输层分组称为报文段(segment)

网络层

因特网的网络层负责将称为数据报(datagram)的网络层分组从一台主机移动到另一台主机。

在一台源主机中的因特网运输层协议(TCP或UDP)向网络层递交运输层报文段和目的地址,就像你通过邮政服务寄信件时提供一个目的地址一样。

因特网的网络层包括著名的IP协议。

IP协议

IP协议定义了在数据报中的各个字段以及端系统和路由器如何作用于这些字段。仅有一个IP协议,所有具有网络层的因特网组件必须运行IP协议。

因特网的网络层也包括决定路由的路由选择协议,

路由选择协议

路由选择协议使得数据报根据该路由从源传输到目的地。因特网具有许多路由选择协议。因特网是一个网络的网络,在一个网络中,其网络管理者能够运行所希望的任何路由选择协议。

尽管网络层包括了IP 协议和一些路由选择协议,但通常把它简单地称为IP层。这反映了IP是将因特网连接在一起的粘合剂这样的事实。

链路层

因特网的网络层通过源和目的地之间的一系列路由器路由数据报。为了将分组从一个结点(主机或路由器)移动到路径上的下一个结点,网络层必须依靠该链路层的服务。

特别是在每个结点,网络层将数据报下传给链路层,链路层沿着路径将数据报传递给下一个结点。在下个结点,链路层将数据报上传给网络层。

由链路层提供的服务取决于应用于该链路的特定链路层协议。例如,某些协议基于链路提供可靠传递,从传输结点跨越一条链路到接收结点。值得注意的是,这种可靠的传递服务不同于TCP的可靠传递服务,TCP提供从一个端系统到另一个端系统的可靠交付。链路层的例子包括以太网、WiFi 和电缆接入网的DOCSIS协议。因为数据报从源到目的地传送通常需要经过几条链路,一个数据报可能被沿途不同链路上的不同链路层协议处理。例如,一个数据报可能被一段链路上的以太网和下一段链路上的PPP所处理。网络层将受到来自每个不同的链路层协议的不同服务。

我们把链路层分组称为帧(frame)。

物理层

虽然链路层的任务是将整个帧从一个网络元素移动到邻近的网络元素,而

物理层的任务是将该帧中的一个一个比特从一个结点移动到下一个结点。

在这层中的协议仍然是链路相关的,并且进一步与该链路(例如,双绞铜线、单模光纤)的实际传输媒体相关。例如,以太网具有许多物理层协议:一个是关于双绞铜线的,另一个是关于同轴电缆的,还有一个是关于光纤的,等等。在每种场合中,跨越这些链路移动一个比特是以不同的方式进行的。

5.3.1.2 OSI模型

详细地讨论过因特网协议栈后,我们应当提及它不是唯一的协议栈。特别是在20世纪70年代后期,国际标准化组织(ISO)提出计算机网络应组织为大约7层,称为开放系统互连(OSI)模型。当那些要成为因特网协议的协议尚处于襁褓中,只是许多正在研发之中的不同协议族之一时,OSI模型已经成形;事实上,初始OSI模型的发明者在创建该模型时心中并没有想到因特网。无论如何,自20世纪70年代开始,许多培训课程和大学课程围绕7层模型挑选有关ISO授权和组织的课程。因为它在网络教育的早期影响,该7层模型继续以某种方式存留在某些网络教科书和培训课程中。

显示在下图中的OSI参考模型的7层是:应用层、表示层、会话层、运输层、网络层、数据链路层和物理层。

计算机系统(五):计算机网络和因特网_第9张图片

这些层次中,5层的功能大致与它们名字类似的因特网对应层的相同。所以,我们来考虑OSI参考模型中附加的两个层,即表示层和会话层。表示层的作用是使通信的应用程序能够解释交换数据的含义。这些服务包括数据压缩和数据加密(它们是自解释的)以及数据描述(这使得应用程序不必担心在各台计算机中表示/存储的内部格式不同的问题)。会话层提供了数据交换定界和同步功能,包括了建立检查点和恢复方案的方法。

因特网缺少了在OSI参考模型中建立的两个层次,该事实引起了一些有趣的问题:这些层次提供的服务不重要吗?如果一个应用程序需要这些服务之一,将会怎样呢?因特网对这两个问题的回答是相同的:这留给应用程序开发者处理。应用程序开发者决定一个服务是否是重要的,如果该服务重要,应用程序开发者就应该在应用程序中构建该功能。

5.3.2 封装

下图显示了这样一条物理路径:数据从发送端系统的协议栈向下,向上和向下经过中间的链路层交换机和路由器的协议栈,进而向上到达接收端系统的协议栈。

计算机系统(五):计算机网络和因特网_第10张图片

路由器和链路层交换机都是分组交换机。与端系统类似,路由器和链路层交换机以多层次的方式组织它们的网络硬件和软件。而路由器和链路层交换机并不实现协议栈中的所有层次。如上图所示,链路层交换机实现了第一层和第二层;路由器实现了第一层到第三层。例如,这意味着因特网路由器能够实现IP协议(一种第三层协议),而链路层交换机则不能。我们将在后面看到,尽管链路层交换机不能识别IP地址,但它们能够识别第二层地址,如以太网地址。值得注意的是,主机实现了所有5个层次,这与因特网体系结构将它的复杂性放在网络边缘的观点是一致的

上图也说明了一个重要概念:封装(encapsulation)。在发送主机端,一个应用层报文(application-layer message)(图中的M)被传送给运输层。在最简单的情况下,运输层收取到报文并附上附加信息(所谓运输层首部信息,图中的H),该首部将被接收端的运输层使用。

应用层报文和运输层首部信息一道构成了运输层报文段(transport-layer segment)。运输层报文段因此封装了应用层报文。

附加的信息也许包括了下列信息:如允许接收端运输层向上向适当的应用程序交付报文的信息;如差错检测位信息,该信息让接收方能够判断报文中的比特是否在途中已被改变。运输层则向网络层传递该报文段,

网络层增加了如源和目的端系统地址等网络层首部信息(图中的H),产生了网络层数据报(network-layer datagram)

该数据报接下来被传递给链路层,

链路层(自然而然地)增加它自己的链路层首部信息并创建链路层帧(link-layer frame)

所以,我们看到在每一层,一个分组具有两种类型的字段:首部字段和有效载荷字段(payload field)。 有效载荷通常是来自上一层的分组。

你可能感兴趣的:(计算机网络,学习)