【网络】网络通信的传输方式

目录

1.网络通信中的两种基本通信模式

1.1.怎么理解连接

1.2.面向有连接类型

1.3.面向无连接类型

2.实现这两种通信模式的具体交换技术

 2.1.电路交换

2.2.分组交换

3.根据接收端数量分类

单播(Unicast)

广播(Broadcast)

多播(Multicast)

任播(Anycast)


 

1.网络通信中的两种基本通信模式

1.1.怎么理解连接

我们怎么理解连接?

在不同的分层协议中,连接的具体含义可能有所不同。

  • 在数据链路层中的连接,就是指物理的、通信线路的连接。
  • 而传输层则负责创建与管理逻辑上的连接。

 在TCP/IP协议栈中,从应用层到数据链路层,每一层都承担着不同的职责,并且连接的含义也随之变化。

以下是对各层连接含义的详细解释:

1. 应用层

  • 连接含义在应用层,连接通常指的是应用程序之间的逻辑连接。这种连接不是物理的,也不是直接的网络连接,而是通过应用层协议(如HTTP、FTP、SMTP等)建立的,用于实现特定应用的数据交换。
  • 功能:应用层负责处理特定的应用程序细节,如数据格式、用户认证、会话管理等。它提供了各种网络应用所需的服务,使得用户可以通过网络进行文件传输、网页浏览、电子邮件发送等操作。
  • 我们可以这么理解:只要我的应用层和你的应用层不能通信,那么对于应用层来说,我和你的这个连接就没有建立成功

2. 传输层

  • 连接含义在传输层,连接指的是端到端的逻辑连接。这种连接是通过传输层协议(如TCP和UDP)建立的,用于在源端和目的端(所谓端可以理解为进程)之间传输数据。
    • TCP(传输控制协议):TCP是一种面向连接的协议,它提供了可靠的数据传输服务。在TCP连接中,通信双方会进行三次握手来建立连接,并在数据传输结束后进行四次挥手来释放连接。TCP通过序列号、确认机制、重传等机制来确保数据的顺序和完整性。
    • UDP(用户数据报协议):UDP则是一种无连接的协议,它不提供可靠的数据传输服务。UDP数据包在发送后不会等待接收方的确认,因此不保证数据的顺序和完整性。但是,UDP具有较低的延迟和较高的吞吐量,适用于对实时性要求较高的应用。
  • 功能:传输层负责在源端和目的端之间建立、管理和终止会话,提供可靠或不可靠的数据传输服务。
  • 我们可以这么理解:只要我的传输层和你的传输层不能通信,那么对于传输层来说,我和你的这个连接就没有建立成功

3. 网络层

  • 连接含义:在网络层,连接通常指的是逻辑上的路径选择和数据包转发过程,而不是传统意义上的“连接”。网络层通过IP协议(互联网协议)来实现数据的路由和转发。
  • 功能:网络层负责数据的路径选择和逻辑地址寻址。它使用IP地址来标识网络上的设备,并通过路由选择算法来确定数据包的最佳路径。网络层还包含了ICMP(互联网控制消息协议)等协议,用于在互联网设备之间传递控制消息,如路由信息、错误报告等。
  • 我们可以这么理解:只要我的网络层和你的网络层不能通信,那么对于网络层来说,我和你的这个连接就没有建立成功

4. 数据链路层

  • 连接含义:在数据链路层,连接通常指的是物理链路上的帧传输过程。数据链路层负责在物理网络连接上发送和接收数据帧,确保数据在物理介质上的可靠传输。
  • 功能:数据链路层通过封装成帧、差错检测、流量控制等机制来确保数据在物理链路上的正确传输。它还包括了物理地址寻址(如MAC地址)等功能,以便在局域网中正确地识别和传输数据帧。
  • 我们可以这么理解:只要我的数据链路层和你的数据链路层不能通信,那么对于数据链路层来说,我和你的这个连接就没有建立成功

综上所述,TCP/IP协议栈中各层的连接含义随着层次的深入而逐渐变化。从应用层的逻辑应用到传输层的端到端连接,再到网络层的路径选择和数据链路层的物理链路传输,每一层都承担着不同的职责,共同实现了数据在网络中的高效传输。

通过网络发送数据,大致可以分为面向有连接与面向无连接两种类型

  • 面向无连接型包括以太网、IP、UDP等协议。
  • 面向有连接型包括ATM、帧中继、TCP等协议。

1.2.面向有连接类型

        面向有连接型中,在发送数据之前,需要在收发主机之间连接一条通信线路(在不同的分层协议中,连接的具体含义可能有所不同。在数据链路层中的连接,就是指物理的、通信线路的连接。而传输层则负责创建与管理逻辑上的连接。) 。

        面向有连接型就好比人们平常用手机打电话,输入完对方电话号码点击拨出之后,只有对端拿起电话点击接听之后才能真正通话,通话结束时就点击挂断电话就能结束对话。

        因此在面向有连接的方式下,必须在通信传输前后,专门进行建立和断开连接的处理。如果与对端之间无法通信,就可以避免发送无谓的数据。 

面向有连接型协议在通信过程中,需要在发送数据之前,在收发主机之间建立一条逻辑或物理的通信线路,并在通信结束后断开这条连接。这种类型的协议通常用于确保数据传输的可靠性和顺序性。

以下是一些常见的面向有连接类型的协议:

传输层协议

  • TCP(传输控制协议):TCP是一种面向连接的、可靠的、基于字节流的传输层通信协议。在TCP连接中,通信双方会进行三次握手来建立连接,并在数据传输结束后进行四次挥手来释放连接。TCP通过序列号、确认机制、重传等机制来确保数据的顺序和完整性。

网络层协议(虽然网络层通常不直接建立逻辑连接,但某些网络层技术可以支持面向连接的服务)

  • 在网络层,面向连接的服务通常由特定的网络协议或技术提供,如ATM(异步传输模式)网络中的虚电路(VC)服务。然而,在现代互联网中,网络层主要使用IP协议,它本身是无连接的,但可以通过传输层的TCP协议来提供面向连接的服务。

数据链路层协议(物理连接)

  • 在数据链路层,面向连接的服务通常涉及到物理链路的建立和管理。然而,数据链路层协议本身并不直接提供面向连接的逻辑服务,而是为上层协议(如网络层和传输层)提供可靠的物理传输基础。例如,HDLC(高级数据链路控制协议)PPP(点对点协议)等可以在数据链路层建立和维护物理连接,但它们本身并不提供传输层那样的逻辑连接服务。

需要注意的是,虽然数据链路层协议涉及到物理链路的连接,但面向有连接型的概念在传输层中更为常见和重要。在TCP/IP协议栈中,TCP是主要的面向有连接型传输层协议。

综上所述,面向有连接型的协议主要包括传输层的TCP协议,以及在某些特定网络环境中可能使用的网络层或数据链路层技术(如ATM网络中的虚电路服务)。

在日常应用中,TCP是最常见的面向有连接型协议之一。

1.3.面向无连接类型

         面向无连接型则不要求建立和断开连接。发送端可于任何时候自由发送数据。反之,接收端也永远不知道自己会在何时从哪里收到数据。因此,在面向无连接的情况下,接收端需要时常确认是否收到了数据。

        这就如同人们去邮局寄包裹一样。负责处理邮递业务的营业员,不需要确认收件人的详细地址是否真的存在,也不需要确认收件人是否能收到包裹,只要发件人有一个寄件地址就可以办理邮寄包裹的业务。面向无连接通信与电话通信不同,它不需要拨打电话、挂掉电话之类的处理,而是全凭发送端自由地发送自己想要传递出去的数据。

        因此,在面向无连接的通信中,不需要确认对端是否存在。即使接收端不存在或无法接收数据,发送端也能将数据发送出去。

  

面向无连接类型的协议在通信过程中,不需要在发送数据之前建立一条明确的通信线路。

这种类型的协议通常将每个数据分组(报文或数据包)独立地发送到网络上,由网络负责将它们传输到目的地。

以下是一些常见的面向无连接类型的协议:

传输层协议

  • UDP(用户数据报协议):UDP是传输层的一种面向无连接的协议,它提供了简单的、不可靠的信息传送服务。UDP在发送数据之前不会建立连接,也不会对数据包的到达进行确认。因此,UDP通常用于那些对实时性要求较高,但对数据可靠性要求不高的应用场景,如实时音视频传输、在线游戏等。

网络层协议

  • IP(互联网协议):IP协议是网络层的核心协议,它负责将数据报从源主机传输到目的主机。IP协议本身是无连接的,它不对数据包的到达进行确认,也不保证数据包的顺序和完整性。然而,通过结合传输层的TCP或UDP协议,可以在上层实现可靠的数据传输服务。

数据链路层协议(特定场景)

  • 在数据链路层,虽然大多数协议(如以太网协议)主要提供面向连接的服务(通过帧的确认和重传机制),但在某些特定场景下,也存在面向无连接的服务。例如,在某些简单的数据链路层协议中,可能只负责将数据包封装成帧并发送到网络上,而不关心数据包的到达和确认。然而,这种情况相对较少见,且通常不是数据链路层的主要功能。

特点与优势

  • 简单高效:面向无连接的协议通常具有较低的协议开销和较快的传输速度,因为它们不需要建立和维护连接状态。
  • 实时性强:由于不需要等待连接的建立和确认,面向无连接的协议能够更快地响应数据传输请求,适用于对实时性要求较高的应用场景。
  • 灵活性强:面向无连接的协议允许数据分组独立地传输到网络上,这使得它们能够灵活地适应不同的网络环境和传输需求。

然而,面向无连接的协议也存在一些缺点,如数据包可能丢失、乱序到达等。因此,在使用这类协议时,需要根据具体的应用场景和需求进行权衡和选择。

2.实现这两种通信模式的具体交换技术

  • 网络通信方式大致分为两种——电路交换和分组交换。电路交换技术的历史相对久远,主要用于过去的电话网。
  • 而分组交换技术则是一种较新的通信方式,从20世纪60年代后半叶才开始逐渐被人们认可。我们所熟悉的TCP/IP,正是采用了分组交换技术。

 2.1.电路交换

  •  在电路交换中,交换机主要负责数据的中转处理。
  • 计算机首先被连接到交换机上,而交换机与交换机之间则由众多通信线路再继续连接。
  • 因此计算机之间在发送数据时,需要通过交换机与目标主机建立通信电路。
  • 我们将连接电路称为建立连接。建立好连接以后,用户就可以一直使用这条电路,直到该连接被断开为止。 

        如果某条电路只是用来连接两台计算机的通信线路,就意味着只需在这两台计算机之间实现通信,因此这两台计算机是可以独占线路进行数据传输的。

        但是,如果一条电路上连接了多台计算机,而这些计算机之间需要相互传递数据,就会出现新的问题。

  1. 鉴于一台计算机在收发信息时会独占整个电路,其他计算机只能等待这台计算机处理结束以后才有机会使用这条电路收发数据。
  2. 并且在此过程中,谁也无法预测某一台计算机的数据传输从何时开始又在何时结束。如果并发用户数超过交换机之间的通信线路数,就意味着通信根本无法实现。

为此,人们想到了一个新的方法,即让连接到通信电路的计算机将所要发送的数据分成多个数据包,按照一定的顺序排列之后分别发送。这就是分组交换。有了分组交换,数据被细分后,所有的计算机就可以一齐收发数据,这样也就提高了通信线路的利用率。由于在分组的过程中,已经在每个分组的首部写入了发送端和接收端的地址,所以即使同一条线路同时为多个用户提供服务,也可以明确区分每个分组数据发往的目的地,以及它是与哪台计算机进行的通信。

2.2.分组交换

        在分组交换中,由分组交换机(路由器)连接通信线路。分组交换的大致处理过程是:发送端计算机将数据分组发送给路由器,路由器收到这些分组数据以后,缓存到自己的缓冲区,然后再转发给目标计算机。因此,分组交换也有另一个名称:蓄积交换。

        路由器接收到数据以后会按照顺序缓存到相应的队列当中,再以先进先出的顺序将它们逐一发送出去(有时,也会优先发送目标地址比较特殊的数据。) 。

        在分组交换中,计算机与路由器之间以及路由器与路由器之间通常只有一条通信线路。因此,这条线路其实是一条共享线路。在电路交换中,计算机之间的传输速度不变。然而在分组交换中,通信线路的速度可能会有所不同。根据网络拥堵的情况,数据达到目标地址的时间有长有短。另外,路由器的缓存饱和或溢出时,甚至可能会发生分组数据丢失、无法发送到对端的情况。

  

 

3.根据接收端数量分类

        网络通信当中,也可以根据目标地址的个数及其后续的行为对通信进行分类。如广播、多播等就是这种分类的产物。

单播(Unicast)

        字面上,“Uni”表示“1”,“Cast”意为“投掷”。组合起来就是指1对1通信。早先的固定电话就是单播通信的一个典型例子。

广播(Broadcast)

        字面上具有“播放”之意。因此它指是将消息从1台主机发送给与之相连的所有其他主机。广播通信的一个典型例子就是电视播放,它将电视信号一齐发送给非特定的多个接收对象。

        此外,我们知道电视信号一般都有自己的频段。只有在相应频段的可接收范围内才能收到电视信号。

        与之类似,进行广播通信的计算机也有它们的广播范围。只有在这个范围之内的计算机才能收到相应的广播消息。这个范围叫做广播域。

多播(Multicast)

        多播与广播类似,也是将消息发给多个接收主机。不同之处在于多播要限定某一组主机作为接收端。多播通信 最典型的例子就是电视会议,这是由多组人在不同的地方参加的一种远程会议。在这种形式下,会由一台主机发送消息给特定的多台主机。电视会议通常不能使用广播方式。否则将无从掌握是谁在哪儿参与电视会议。

任播(Anycast)

        任播是指在特定的多台主机中选出一台作为接收端的一种通信方式。虽然,这种方式与多播有相似之处,都是面向特定的一群主机,但是它的行为却与多播不同。任播通信从目标主机群中选择一台最符合网络条件的主机作为目标主机发送消息。通常,所被选中的那台特定主机将返回一个单播信号,随后发送端主机会只跟这台主机进行通信。    

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

使用C++编写一个语音播报时钟(Qt)

要求:当系统时间达到输入的时间时,语音播报对话框中的内容。定时可以取消。qt界面如上图所示。组件如下: countdownEdit作为书写目标时间的line_edit start_btn作为开始和停止的按钮 stop_btn作为取消的按钮 systimelab显示系统时间的lab tex…

火语言RPA流程组件介绍--鼠标拖拽元素

🚩【组件功能】:在开始位置上按下鼠标,拖动到结束坐标或指定元素上放下鼠标,实现目标元素的拖拽 配置预览 配置说明 丨拖动元素 支持T或# 默认FLOW输入项 开始拖动的元素,并从当前元素开始按下鼠标 丨拖动到 目标元素/目标位…

解锁Web3.0——Scaffold-eth打造以太坊DApp的终极指南

🚀本系列文章为个人学习笔记,目的是巩固知识并记录我的学习过程及理解。文笔和排版可能拙劣,望见谅。 目录 前言 一、快速部署 1、前期准备: 2、安装项目: ​ 二、配置部署运行环境 1、初始化本地链:…

html css网页制作成品

前言 在HTML和CSS中创建一个网页是一个简单的过程,但是要创建一个成品级的网页,你需要考虑更多的因素,例如: 响应式设计:确保你的网页在不同的设备和屏幕尺寸上都能良好显示。 访问性:确保你的网页对于大…

三天入门WebGIS开发:智慧校园篇

WebGIS开发听起来可能有点高大上,但其实只要掌握几个关键点,入门并不难。智慧校园作为WebGIS的一个热门应用场景,集成了地理信息与校园管理,为校园带来智能化革新。接下来的三天,我们将一步步带你入门WebGIS开发&#…

大数据-130 - Flink CEP 详解 - CEP开发流程 与 案例实践:恶意登录检测实现

点一下关注吧!!!非常感谢!!持续更新!!! 目前已经更新到了: Hadoop(已更完)HDFS(已更完)MapReduce(已更完&am…

8.10Laplacian算子

实验原理 Laplacian算子也是一种用于边缘检测的技术,它通过查找二阶导数的零交叉点来定位边缘。 cv::Laplacian()函数是OpenCV库提供的一个用于计算图像拉普拉斯算子的函数。拉普拉斯算子是一个二阶微分算子,常用于图像处理中检测边缘或突变区域。它通…

揭秘!全罐喂养值得吗?高性价比主食罐头推荐

家里的五岁的公猫,已绝育,不爱喝水,医生建议喂湿粮。一开始还是早干晚湿,干粮存货都处理完后,就开始全罐喂养了。身边也有许多铲屎官十分好奇全罐喂养到底值不值,那么今天就来分享一下全罐喂养的感想和经验…

卡诺图的绘制

目录 逻辑函数的卡诺图化简 最小项卡诺图的组成 相邻最小项 卡诺图的组成 二变量卡诺图 三变量卡诺图 四变量卡诺图 卡诺图中的相邻项(几何相邻) 逻辑函数的卡诺图化简 最小项卡诺图的组成 相邻最小项 互为反变量的那个变量可以消去。 卡诺图的…

.json文件的C#解析,基于Newtonsoft.Json插件

目录 1. 前言 2. 正文 2.1 问题 2.2 解决办法 2.2.1 思路 2.2.2 代码实现 2.2.3 测试结果 3. 备注 1. 前言 天气晚来秋,这几天天气变凉了,各位同学注意好多穿衣服。回归正题 由于需要,需要将json的配置里面的调理解析出来&#xff…

RV1126采集VI视频数据流

本章节内容 这个章节主要是讲解如何通过RKMEDIA的API获取RV1126的VI视频流,虽然这部分在之前的课程里面讲解了很多次,但还是要带着大家回顾一下这部分代码。 采集VI数据的代码实现 2.1. VI模块的初始化并使能 上图是VI模块的初始化,这部分的…

STM32+ESP8266 WiFi连接机智云平台APP远程控制教程

本文档将介绍如何用STM32ESP8266 WiFi模块从零开始连接上机智云,并通过APP进行远程控制。 机智云官网:机智云|智能物联网操作系统 (gizwits.com) 准备:STM32、ESP8266、手机、可上网的WiFi。 1.创建设备 1.1 注册登陆 请自行注册账号并登陆…

ASUS华硕ROG幻16 Air 2024款锐龙AI版GA605WI,GA605WV工厂模式原厂Win11系统,含MyASUS WinRE恢复重置还原功能

适用型号:【GA605WI、GA605WV】,原装出厂Windows11系统工厂包下载 链接:https://pan.baidu.com/s/1IVolLwB7fddGKZY0IxOqaA?pwd62e2 提取码:62e2 华硕原装系统工厂安装包,带有MyASUS WinRE RECOVERY恢复功能、自带…

健身房|基于springboot的健身房管理系统设计与实现(附项目源码+论文+数据库)

私信或留言即免费送开题报告和任务书(可指定任意题目) 目录 一、摘要 二、相关技术 三、系统设计 四、数据库设计 五、核心代码 六、论文参考 七、源码获取 一、摘要 随着信息技术在管理上越来越深入而广泛的应用,管理…

基于node.js koa2模拟快递柜存储取出快递微信小程序

本文介绍了一个基于Node.js Koa2框架的快递柜存储和取出快递的微信小程序。首先,我们使用Koa2框架搭建了一个简单的后端服务器,用于处理微信小程序发送的请求。然后,我们实现了快递柜的存储和取出功能,用户可以通过微信小程序扫描…

分布式通信:多计算平台的任务分配

目录 1. 分布式通信 1.1 树莓派配置流程​编辑 1.2 树莓派和laptop处于同一网络​编辑 1.3 laptop配置 1.4 通信测试 1.5 分组通信 ​编辑 1.6 分布式通信测试 ​编辑参考资料 1. 分布式通信 机器人体积较小,采用树莓派作为控制器,实现传感器处…

音视频入门基础:AAC专题(1)——AAC官方文档下载

一、AAC简介 高级音频编码(英语:Advanced Audio Coding,AAC)是有损音频压缩的专利数字音频编码标准,由Fraunhofer IIS、杜比实验室、贝尔实验室、Sony、Nokia等公司共同开发。出现于1997年,为一种基于MPEG…

HTML生日蛋糕

目录 写在前面 完整代码 下载代码 代码分析 系列文章 写在最后 写在前面 HTML实现的生日蛋糕来喽,小编亲测,发给好友可以直接打开哦。在代码的第183行可以写下对朋友的祝福,快拿去送给你的好朋友吧! 完整代码 <!DOCTYPE html> <html lang="en"…

OAuth 2.0 授权流程详解与 FastAPI 实现

在现代网络应用中&#xff0c;OAuth 2.0 已成为授权和认证的标准协议。它允许用户将访问权限授予第三方应用&#xff0c;而无需暴露自己的用户名和密码。本文将详细介绍 OAuth 2.0 的常见授权流程&#xff0c;并展示如何在 FastAPI 中实现这些流程。 OAuth 2.0 简介 OAuth 2…

N-152基于java贪吃蛇游戏5

开发工具eclipse,jdk1.8 文档截图&#xff1a; N-152基于java贪吃蛇游戏5