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

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

    • 电路交换
    • 分组交换
    • 报文交换
    • 传输对比


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

电路交换

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

在这里插入图片描述

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

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

在这里插入图片描述

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

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

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

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

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

  • 建立连接,也就是分配通信资源。例如在使用电路交换打电话之前,必须先拨号请求建立连接。当被叫用户听到电话交换机送来的拨号音并接通,从主叫端到被叫端就建立了一条连接,也就是一条专用的物理通路,这条连接保证了双方通话时所需的通信资源,而这些资源在双方通信时不会被其他用户占用

  • 通话,也就是主叫和被叫双方互相通电话。在整个通话期间,之前建立连接所分配的通信资源始终被占用。

  • 释放连接,也就是通话完毕挂机后,电话交换机释放刚才使用的这条专用的物理通路。换句话说是把刚才占用的所有通信资源归还给电信网,

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

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

在这里插入图片描述

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

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

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

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


分组交换

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

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

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

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

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

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

在上述的分组交换过程中,发送方所要完成的任务是构造分组发送分组
在这里插入图片描述

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

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

在这里插入图片描述


报文交换

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


传输对比

接下来我们对电路交换、报文交换、分组交换这三种交换方式进行一下对比。
在这里插入图片描述

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

电路交换:
在这里插入图片描述

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

报文交换:
在这里插入图片描述

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

分组交换:
在这里插入图片描述

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

在这里插入图片描述

  • 电路交换:一旦建立连接,中间的各节点交换机就是直通形式的比特流,可以直达终点。

  • 报文交换:整个报文需要在各节点交换机上进行存储转发,由于不限制报文的大小,因此需要各节点交换机都具有较大的缓存空间。

  • 分组交换:构成原始报文的一个个分组,在各节点交换机上进行存储转发。相比报文交换减少了转发时延,还可以避免过长的报文,长时间占用链路,同时也有利于进行差错控制。


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

电路交换:

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

电路交换的优点:

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

电路交换的缺点:

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

报文交换:

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

报文交换的优点:

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

报文交换的缺点:

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

分组交换:

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

分组交换的优点如下,

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

分组交换的缺点如下,

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/756602.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c++类和对象(中)类的6个默认成员函数及const成员函数

🪐🪐🪐欢迎来到程序员餐厅💫💫💫 今日主菜:类和对象 主厨:邪王真眼 所属专栏:c专栏 主厨的主页:Chef‘s blog 前言: 咱们之前也是…

【开发环境搭建篇】IDEA安装和配置

作者介绍:本人笔名姑苏老陈,从事JAVA开发工作十多年了,带过大学刚毕业的实习生,也带过技术团队。最近有个朋友的表弟,马上要大学毕业了,想从事JAVA开发工作,但不知道从何处入手。于是&#xff0…

C语言——结构体自定义类型

目录 结构体类型 声明结构体 结构体的特殊声明 创建结构体变量和初始化结构体变量 结构体的自引用 结构体内存对齐 对齐规则 内存对齐存在意义 默认对齐数的修改 结构体传参 结构体实现位段 了解位段是什么 位段的内存分配 位段有跨平台的问题及使用注意事项 C语言…

Spark-Scala语言实战(3)

在之前的文章中,我们学习了如何在来如何在IDEA离线和在线安装Scala,想了解的朋友可以查看这篇文章。同时,希望我的文章能帮助到你,如果觉得我的文章写的不错,请留下你宝贵的点赞,谢谢。 Spark-Scala语言实…

[Halcon学习笔记]标定常用的Halcon标定板规格及说明

1、介绍 大多数标定的要求都是以实心圆或方格来作为标志点,所以一般的标定板为棋盘格或矩阵圆点图,高精度的相机标定过程中,大多是以比较明确的特征点来作为参考,所以通过识别标定板的圆形,拟合出精确的中心位置&…

3.19总结

A计划 题解&#xff1a;这题其实就是一个很简单的三维搜索&#xff0c;有了一个传送门&#xff0c;并且要确定是否传过去的对应位置是墙&#xff0c;防止被装死&#xff0c;同事呢又要在对应的t时间内完成&#xff08;不一定要卡着t时间恰好完成&#xff09; #include<ios…

linux单机部署hadoop

1.下载安装包 https://archive.apache.org/dist/hadoop/common/ 2.上传压缩 3.修改配置文件 1)设置JDK的路径 cd /usr/local/software/hadoop-3.1.3/etc/hadoop vi hadoop-env.sh export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.402.b06-1.el7_9.x86_64/ 查看…

1Panel应用推荐:Nginx Proxy Manager

1Panel&#xff08;github.com/1Panel-dev/1Panel&#xff09;是一款现代化、开源的Linux服务器运维管理面板&#xff0c;它致力于通过开源的方式&#xff0c;帮助用户简化建站与运维管理流程。为了方便广大用户快捷安装部署相关软件应用&#xff0c;1Panel特别开通应用商店&am…

springBoot---过滤器,监听器,拦截器

过滤器&#xff0c;监听器&#xff0c;拦截器 一、理解它们 看里十几篇博客&#xff0c;总算有点小明白&#xff0c;总的来讲&#xff0c;两张图可以让我看明白点。 通过两幅图我们可以理解拦截器和过滤器的特点 1、过滤器 过滤器是在请求进入tomcat容器后&#xff0c;但请求…

2024流星全自动网页生成系统重构版源码

2024流星全自动网页生成系统重构版源码 源码介绍 流星全自动网页生成系统重构版源码分享&#xff0c;所有模板经过精心审核与修改&#xff0c;完美兼容小屏手机大屏手机&#xff0c;以及各种平板端、电脑端和360浏览器、谷歌浏览器、火狐浏览器等等各大浏览器显示。 为用户使…

【第十五章】改进神经网络学习方式-手写数字识别重新编码实现

让我们来实现我们在之前讨论过的想法。我们将开发一个新的程序&#xff0c;network2.py&#xff0c;这是我们之前开发的程序 network.py 的改进版本。如果你有一段时间没有看过 network.py&#xff0c;那么花几分钟快速阅读之前的讨论可能会有所帮助。它只有 74 行代码&#xf…

44.for语句

目录 一.什么是for语句 二.语法格式 三.举例 四.视频教程 一.什么是for语句 C语言中除了while和do while循环语句&#xff0c;还有for循环语句&#xff0c;所以for语句也是循环语句。 二.语法格式 for&#xff08;表达式1&#xff1b;表达式2&#xff1b;表达式3&#xf…

8.python中的元组

8.python中的元组 虽然说元组用的不是很多&#xff0c;但是还是讲一下。元组其实可以看为是一个列表&#xff0c;不可变的列表。操作和列表都差不多。 元组&#xff08;tuple&#xff09;是Python中的一种基本数据结构类型&#xff0c;它是不可变的序列&#xff0c;意味着一旦…

【爬虫】实战-爬取Boss直聘信息数据

专栏文章索引&#xff1a;爬虫 所用工具&#xff1a; 自动化工具&#xff1a;DrissionPage 目录 一、找到目标数据(2个确定)​ 1.确定目标网页 2.确定目标网址 二、编写代码​ 三、查看数据​ 五、总结 一、找到目标数据(2个确定) 1.确定目标网页 打开目标网站 网站&am…

DolphinScheduler运维-页面加载缓慢

一、问题描述 DolphinScheduler调度平台的UI界面加载缓慢,项目中的任务实例加载时间过长,需要解决这个问题,提高DolphinScheduler平台UI页面的加载速度。 二、原因分析 经过分析发现,任务实例过多是导致UI加载缓慢的主要原因。由于任务实例无法直接删除,根据文档了解到需…

狼人杀 魔镜少女 个人玩法理解

最近出来的新板子 (魔镜少女 觉醒隐狼) 确实是非常的好玩 先来说说板子身份 好人阵营: 神职牌有 魔镜少女 女巫 猎人 守卫 民牌有: 四个普通平民 狼人阵营: 觉醒隐狼 四个普通小狼人 先来说说技能 魔镜少女每晚可以翻拍查验一名玩家的具体身份&#xff0c;注意 是具体身份 就…

网络架构层_交换机连接使用

网络架构层_交换机连接使用 交换机是不是不会用呀&#xff1f;交换机&#xff0c;服务器&#xff0c;路由器&#xff0c;防火墙&#xff0c;网关&#xff0c;这些都是嘛呀&#xff1f; 网上的一些网络架构图&#xff0c;具体项目按照实际考虑。 交换机的Console口——通过Con…

c语言指针(二)

c语言指针&#xff08;二&#xff09; 1.数组名的理解 2.使用指针访问数组 3.一维数组的传参本质 1.数组名的理解 int arr[10] { 1,2,3,4,5,6,7,8,9,10 }; int* p &arr[0]这⾥我们使⽤ &arr[0] 的⽅式拿到了数组第⼀个元素的地址&#xff0c;但是其实数组名本来就是…

【链表】Leetcode 142. 环形链表 II【中等】

环形链表 II 给定一个链表的头节点 head &#xff0c;返回链表开始入环的第一个节点。 如果链表无环&#xff0c;则返回 null。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评测系…

Linux用户、用户组

用户管理命令&#xff1a; 首先要先知道两个配置文件&#xff1a;/etc/group 用户组配置文件/etc/passwd 保存了所有用户的用于读取的必要信息**/etc/shadow **是 Linux 系统中用于存储用户密码信息的文件。这个文件也被称为“影子文件”&#xff0c;因为它包含了 /etc/passwd…