计算机网络:数据交换方式

简介: 计算机网络:数据交换方式

本博客介绍计算机之间数据交换的三种方式,分别是电路交换、分组交换以及报文交换。

电路交换

我们首先来看电路交换,在电话问世后不久,人们就发现要让所有的电话机都两两相连接是不现实的。例如两部电话只需要用一对电线就能够互相连接起来,但若有 5 部电话要两两相连,则需要 10 对电线。

当电话机的数量很大时,这种连接方法需要的电线数量就太大了。例如,如果有 n 部电话机需要两两相连,那么一共需要多少对电线呢?答案是(n - 1) * n / 2。


于是人们认识到要使得每一部电话能够很方便地和另一部电话进行通信,就应当使用一个中间设备将这些电话连接起来。这个中间设备就是电话交换机,每一部电话都连接到电话交换机上:

可以把电话交换机简单的看成是一个有多个开关的开关器,可以将需要通信的任意两部电话的电话线路按需接通,从而大大减少了连接的电话线数量。

当电话机的数量增多时,就需要使用很多彼此连接起来的电话交换机来完成全网的交换任务。用这样的方法就构成了覆盖全世界的电信网,电话交换机接通电话线的方式称为电路交换

从通信资源的分配角度来看,交换就是按照某种方式动态的分配传输线路的资源。我们来看下面这个电路交换的示意图:

应当注意的是用户线归电话用户专用,而电话交换机之间拥有的大量中继线则是许多用户共享的。

电路交换有以下三个步骤:

  • 建立连接,也就是分配通信资源。例如在使用电路交换打电话之前,必须先拨号请求建立连接。当被叫用户听到电话交换机送来的拨号音并接通,从主叫端到被叫端就建立了一条连接,也就是一条专用的物理通路,这条连接保证了双方通话时所需的通信资源,而这些资源在双方通信时不会被其他用户占用。
  • 通话,也就是主叫和被叫双方互相通电话。在整个通话期间,之前建立连接所分配的通信资源始终被占用。
  • 释放连接,也就是通话完毕挂机后,电话交换机释放刚才使用的这条专用的物理通路。换句话说是把刚才占用的所有通信资源归还给电信网,

这种必须通过建立连接(占用通信资源),通话(一直占用通信资源),释放连接(归还通信资源)三个步骤的交换方式,称为电路交换

那么如果使用电路交换来传送计算机数据是否可行?

应该说,尽管采用电路交换可以实现计算机之间的数据传送,但是线路的传输效率往往很低,这是因为计算机数据是突发式的出现在传输线路上的。

突发性:

计算机在传输数据时,不会一直在信道中传输数据,而是间歇性的传输数据

计算机数据具有突发性,这导致使用电路交换传送数据时通信线路的利用率很低,真正用来传送数据的时间往往不到10%,甚至不到 1%。已被用户占用的通信线路资源在绝大部分时间里都是空闲的。

试想一下,这种情况,当用户正在输入和编辑一份带传输的文件时,用户所占用的通信资源暂时未被利用,该通信资源也不能被其他用户利用,宝贵的通信线路资源白白被浪费了。因此,计算机网络通常采用分组交换而不是电路交换。

分组交换

假设这是因特网的一部分,在因特网中最重要的分组交换机就是路由器,他负责将各种网络互联起来,并对接收到的分组进行转发,也就是进行分组交换。

我们来看这样一个例子,假设主机 H6 的用户要给主机 H2 的用户发送一条消息,通常我们把表示该消息的整块数据称为一个报文

在发送报文之前,先把较长的报文划分成为一个更小的等长数据段,在每一个数据段前面加上一些由必要的控制信息组成的手部后,就构成了一个分组,也可简称为包,相应的手部也可称为包头。


那么添加手部的作用是什么?这不是额外加大了带传输的数据量吗?


实际上手部起着非常关键的作用,相信大家至少能想到手部中肯定包含了分组的目的地址,否则分组传输路径中的各分组交换机,也就是各路由器就不知道如何转发分组了。分组交换机收到一个分组后,先将分组暂时存储下来,再检查其手部,按照手部中的目的地址进行查表转发,找到合适的转发接口,通过该接口将分组转发给下一个分组。

主机 H6 将所构造出的各分组依次发送出去,各分组经过途中各分组交换机的存储、转发,最终到达主机H2。

主机 H2 收到这些分组后,去掉他们的手部,将各数据段组合还原出原始报文:

需要说明的是,为了初学者容易理解,在本例中我们只演示出了分组传输过程中的两种情况。一种是各分组从源站到达目的站可以走不同的路径,也就是不同的路由。另一种是分组乱序,也就是分组到达目的站的顺序不一定与分组在源站的发送顺序相同。对于可能出现的分组丢失、误码重复等问题并没有演示,这些内容将在以后详细介绍。


在上述的分组交换过程中,发送方所要完成的任务是构造分组和发送分组。

路由器,也就是分组交换机,所要完成的任务是缓存分组和转发分组,简称为存储转发。

接收方所要完成的任务是接收分组和还原报文。


报文交换

与分组交换类似,报文交换中的交换节点也采用存储转发方式,但报文交换对报文的大小没有限制,这就要求交换节点需要有较大的缓存空间。需要注意的是,报文交换主要用于早期的电报通信网,现在较少使用,通常被较先进的分组交换方式所取代。因此我们不再详细介绍报文交换了。


传输对比

接下来我们对电路交换、报文交换、分组交换这三种交换方式进行一下对比。

假设a、b、c、 d 是分组传输路径上所要经过的四个节点,纵坐标为时间。

电路交换:

对于电路交换通信之前首先要建立连接。连接建立好之后就可以使用已建立好的连接进行数据传送。数据传送结束后需要释放连接以归还之前建立连接所占用的通信线路资源。

报文交换:

对于报文交换,可以随时发送报文,而不需要事先建立连接,整个报文先传送到相邻节点,交换机全部存储下来后进行查表转发到下一个节点交换机。

分组交换:

对于分组交换,可以随时发送分组,而不需要事先建立连接。构成原始报文的一个分组,依次在各节点交换机上存储、转发。各节点交换机在发送分组的同时还缓存接收到的分组。

  • 电路交换:一旦建立连接,中间的各节点交换机就是直通形式的比特流,可以直达终点。
  • 报文交换:整个报文需要在各节点交换机上进行存储转发,由于不限制报文的大小,因此需要各节点交换机都具有较大的缓存空间。
  • 分组交换:构成原始报文的一个个分组,在各节点交换机上进行存储转发。相比报文交换减少了转发时延,还可以避免过长的报文,长时间占用链路,同时也有利于进行差错控制。

最后我们总结一下这三种交换方式各自的优缺点:

电路交换:

优点 缺点
通信时延小 建立连接时间长
有序传输 独占线路,使用率低
没有冲突 灵活性差
适用范围广 难以规格化
实时性强
控制简单

电路交换的优点:

  • 通信时延小:这是因为通信线路为通信双方用户专用数据直达,因此通信时延非常小。当连续传输大量数据时,这一优点非常明显。
  • 有序传输:这是因为通信双方之间只有一条专用的通信线路,数据只在这一条线路上传输,因此不存在失序问题。
  • 没有冲突:不同的通信双方拥有不同的信道,不会出现征用物理信道的问题。
  • 适用范围广:电路交换既适用于传输模拟信号,也适用于传输数字信号。
  • 实时性强:这主要得益于其通信时延小的优点。
  • 控制简单:电路交换的节点。交换机及其控制都比较简单。

电路交换的缺点:

  • 建立连接时间长:电路交换的平均连接建立时间对计算机通信来说太长了,
  • 线路独占使用效率低:电路交换一旦建立连接物理通路就被通信双方独占,即使通信线路空闲,也不能供其他用户使用,因而信道利用率很低。
  • 灵活性差:只要连接所建立的物理通路中的任何一点出现了故障,就必须重新拨号,建立新的连接,这对十分紧急和重要的通信是很不利的。
  • 难以规格化:电路交换时,数据直达不同类型、不同规格、不同速率的终端,很难相互进行通信,也难以在通信过程中进行差错控制。

报文交换:

优点 缺点
无需建立连接 引起了转发时延
动态分配链路 需要较大存储缓存空间
提高线路可靠性 需要传输额外信息量
提高线路利用率
提供多目标服务

报文交换的优点:

  • 无需建立连接:报文交换不需要为通信双方预先建立一条专用的通信线路,不存在建立连接的时延,用户可以随时发送报文。
  • 动态分配线路:当发送方把报文传送给节点交换机时,节点交换机先存储整个报文,然后选择一条合适的空闲线路将报文发送出去。
  • 提高线路可靠性:如果某条传输路径发生故障,会重新选择另一条路径传输数据,因此提高了传输的可靠性。
  • 提高线路利用率:通信双方不是固定占用一条通信线路,而是在不同的时间分段部分占用物理线路,因而大大提高了通信线路的利用率。
  • 提供多目标服务:一个报文可以同时发送给多个目的地址,这在电路交换中是很难实现的。

报文交换的缺点:

  • 引起了转发时延:这是因为报文在节点交换机上要经历存储、转发的过程。
  • 需要较大的存储缓存空间:这是因为报文交换对报文的大小没有限制。
  • 需要传输额外的信息量:这是因为报文需要携带目标地址、原地址等信息。

分组交换:

优点 缺点
无需建立连接 引起了转发时延
提高线路利用率 需要较大存储缓存空间
简化了存储管理 对于数据报服务,存在失序,丢失或重复分组的问题
加速传输 对于虚电路服务,存在呼叫建立,数据传输和虚电路释放三个过程
减少出错概率和重发数据量

分组交换的优点如下,

  • 无需建立连接:分组交换不需要为通信双方预先建立一条专用的通信线路,不存在建立连接的时延,用户可以随时发送分组
  • 线路利用率高:通信双方不是固定占用一条通信线路,而是在不同的时间分段部分占用物理线路,因而大大提高了通信线路的利用率。
  • 简化了存储管理:这是相对于报文交换而言的,因为分组的长度固定,相应的缓冲区的大小也固定,管理起来相对容易。
  • 加速传输:由于分组是逐个传输的,这就使得后一个分组的存储操作与前一个分组的转发操作可以同时进行。
  • 减少出错概率和重发数据量:因为分组比报文小,因此出错概率必然减小。即便分组出错,也只需重传出错的部分,这比重传整个报文的数据量小很多,这样不仅提高了可靠性,也减少了传输时延。

分组交换的缺点如下,

  • 引起了转发时延:这是因为分组在节点交换机上要经历存储、转发的过程。
  • 需要传输额外的信息量:将原始报文分割成等长的数据块,每个数据块都要加上原地址、目的地址等控制信息,从而构成分组,因此使得传送的信息量增大了。
  • 采用数据报服务进行分组交换:可能会出现失序、丢失或重复分组**:分组到达目的节点时,需要重新还原成原始报文比较麻烦。
  • 采用虚电路服务进行分组交换:虽然没有分组失序问题,但由呼叫建立、数据传输和虚电路释放三个过程。


相关文章
|
3天前
|
存储 安全 网络安全
云计算与网络安全:守护数据,构筑未来
在当今的信息化时代,云计算已成为推动技术革新的重要力量。然而,随之而来的网络安全问题也日益凸显。本文从云服务、网络安全和信息安全等技术领域展开,探讨了云计算在为生活带来便捷的同时,如何通过技术创新和策略实施来确保网络环境的安全性和数据的保密性。
|
25天前
|
机器学习/深度学习 人工智能 自然语言处理
深度学习的魔法:如何用神经网络解锁数据的奥秘
在人工智能的璀璨星空中,深度学习犹如一颗最亮的星,它以其强大的数据处理能力,改变了我们对世界的认知方式。本文将深入浅出地介绍深度学习的核心概念、工作原理及其在不同领域的应用实例,让读者能够理解并欣赏到深度学习技术背后的奇妙和强大之处。
31 3
|
14天前
|
数据采集 存储 监控
网络爬虫的最佳实践:结合 set_time_limit() 与 setTrafficLimit() 抓取云盘数据
本文探讨了如何利用 PHP 的 `set_time_limit()` 与爬虫工具的 `setTrafficLimit()` 方法,结合多线程和代理 IP 技术,高效稳定地抓取百度云盘的公开资源。通过设置脚本执行时间和流量限制,使用多线程提高抓取效率,并通过代理 IP 防止 IP 封禁,确保长时间稳定运行。文章还提供了示例代码,展示了如何具体实现这一过程,并加入了数据分类统计功能以监控抓取效果。
52 16
网络爬虫的最佳实践:结合 set_time_limit() 与 setTrafficLimit() 抓取云盘数据
|
8天前
|
数据采集 存储 JavaScript
构建您的第一个Python网络爬虫:抓取、解析与存储数据
【9月更文挑战第24天】在数字时代,数据是新的金矿。本文将引导您使用Python编写一个简单的网络爬虫,从互联网上自动抓取信息。我们将介绍如何使用requests库获取网页内容,BeautifulSoup进行HTML解析,以及如何将数据存储到文件或数据库中。无论您是数据分析师、研究人员还是对编程感兴趣的新手,这篇文章都将为您提供一个实用的入门指南。拿起键盘,让我们开始挖掘互联网的宝藏吧!
|
7天前
|
机器学习/深度学习 人工智能 自然语言处理
深度学习与神经网络:探索复杂数据的表示
【9月更文挑战第26天】深度学习作为人工智能领域的明珠,通过神经网络自动从大数据中提取高级特征,实现分类、回归等任务。本文介绍深度学习的基础、张量表示、非线性变换、反向传播及梯度下降算法,并探讨其在计算机视觉、自然语言处理等领域的应用与挑战。未来,深度学习将更加智能化,揭示数据背后的奥秘。
|
12天前
|
机器学习/深度学习 安全 网络安全
云端盾牌:云计算时代的网络安全守护在这个数字脉搏加速跳动的时代,云计算以其高效、灵活的特性,成为推动企业数字化转型的强劲引擎。然而,正如每枚硬币都有两面,云计算的广泛应用也同步放大了网络安全的风险敞口。本文旨在探讨云计算服务中网络安全的关键作用,以及如何构建一道坚不可摧的信息防线,确保数据的安全与隐私。
云计算作为信息技术领域的革新力量,正深刻改变着企业的运营模式和人们的生活。但在享受其带来的便利与效率的同时,云服务的安全问题不容忽视。从数据泄露到服务中断,每一个安全事件都可能给企业和个人带来难以估量的损失。因此,本文聚焦于云计算环境下的网络安全挑战,分析其根源,并提出有效的防护策略,旨在为云服务的安全使用提供指导和参考。
|
9天前
|
存储 安全 网络安全
云计算与网络安全:保护数据的关键策略
【9月更文挑战第23天】在数字化时代,云计算已成为企业和个人存储和处理数据的热门选择。然而,随着云服务的普及,网络安全问题也日益凸显。本文将探讨云计算环境下的网络安全挑战,并提出一系列保护数据的策略。我们将从云服务的基本概念出发,深入分析网络安全的重要性,并介绍如何通过技术和管理措施来增强云安全。文章的目的是为读者提供实用的指导,帮助他们在享受云计算便利的同时,确保数据的安全。
|
6天前
|
小程序 开发者
微信小程序之网络数据请求 wx:request的简单使用
这篇文章介绍了微信小程序中如何使用wx.request进行网络数据请求,包括请求的配置、请求的格式以及如何在开发阶段关闭请求的合法检验。
微信小程序之网络数据请求 wx:request的简单使用
|
6天前
|
缓存 网络协议 网络架构
网络抓包分析【IP,ICMP,ARP】以及 IP数据报,MAC帧,ICMP报和ARP报的数据报格式
本文详细介绍了如何使用网络抓包工具Wireshark进行网络抓包分析,包括以太网v2 MAC帧、IP数据报、ICMP报文和ARP报文的格式,以及不同网络通信的过程。文章通过抓包分析展示了IP数据报、ICMP数据报和ARP数据报的具体信息,包括MAC地址、IP地址、ICMP类型和代码、以及ARP的硬件类型、协议类型、操作类型等。通过这些分析,可以更好地理解网络协议的工作机制和数据传输过程。
网络抓包分析【IP,ICMP,ARP】以及 IP数据报,MAC帧,ICMP报和ARP报的数据报格式
|
7天前
|
存储 安全 网络安全
云计算与网络安全:保护数据的新挑战
【9月更文挑战第25天】在数字化时代,云计算已成为企业和个人存储和处理数据的关键技术。然而,随着云服务的普及,网络安全问题也日益突出。本文将探讨云计算中的网络安全问题,包括数据泄露、恶意软件攻击等,并提出相应的防护措施。我们将通过实例分析,展示如何在实际场景中应用这些防护措施,以保护数据安全。
下一篇
无影云桌面