5.3、UDP 和 TCP 的对比

news2024/11/24 15:55:22

在使用 TCP/IP 体系结构的网络通信中,这两个协议的使用频率仅次于网际层的 IP 协议

image-20230104174811333

TCP/IP 体系结构应用层中的某些协议需要使用运输层的 TCP 提供的服务

  • 而另一些协议需要使用运输层的 UDP 提供的服务

1、UCP(无连接) & TCP(面向连接)

1.1、UDP

如下所示,它们在运输层使用 UDP 协议进行通信,纵坐标为时间

使用 UDP 协议的通信双方可以随时发送数据

image-20230104175231569


1.2、TCP

使用 TCP 协议的双方在进行通信之前必须使用 “三报文握手” 来建立 TCP 连接

TCP 连接建立成功后才能进行数据传输

数据传输结束后必须使用 “四报文挥手” 来释放 TCP 连接

image-20230104175224008

三报文握手与四报文挥手属于 TCP 连接管理,过程比较复杂

具体介绍连接:TCP的连接建立


注意:这里逻辑连接是指逻辑连接关系,而不是物理连接

综上所述

  • UDP 是无连接的,
  • TCP 是面向连接的

2、UDP(单、多、广播)/TCP(单播)

2.1、UDP

如下所示,使用 UDP 协议进行通信的四台主机

  • 其中,任何一台主机都可以向其他三台主机发送广播
  • 也可以向某个多播组发送多播
  • 还可以向某台主机发送单播

image-20230104175738428

也就是说,UDP 支持单播、多播以及广播

  • 话句话说,UDP 支持一对一、一对多、以及一对全的通信

image-20230104175811901


2.2、TCP

使用 TCP 协议的双方在进行通信之前必须使用 “三报文握手” 来建立 TCP 连接

TCP 连接建立成功后才能进行数据传输

数据传输结束后必须使用 “四报文挥手” 来释放 TCP 连接

image-20230104175224008

三报文握手与四报文挥手属于 TCP 连接管理,过程比较复杂

具体介绍连接:TCP的连接建立


3、两个协议对应用报文的处理

3.1、UDP(面向应用报文)

image-20230104180536246

发送方的应用进程将应用层的报文交付给运输层的 UDP

UDP 直接给应用层报文添加一个 UDP 首部,使之称为 UDP 用户数据报,然后进行发送

udpfasong.gif

为了简单起见,忽略运输层下面的各层处理


接收方的 UDP 收到该 UDP 用户数据报后,去掉 UDP 首部,将应用层报文交付给应用进程

udpjieshou.gif


也就是说 UDP 对应用层交付下来的报文既不合并也不拆分,而是保留这些报文的边界

  • 换句话说,UDP面向应用报文

image-20230104181516270

3.2、TCP(面向字节流) 发送缓存/接收缓存

发送方的 TCP 把应用进程交付下来的数据块仅仅看作是一连串的、无结构的字节流

TCP 并不知道这些待传送的字节流的含义,仅将他们编号并存储在自己的发送缓存

TCP 根据发送策略,从发送缓存中提取一定数量的字节,构建 TCP 报文段并发送

image-20230104181713238


接收方的 TCP

  • 一方面从接受到的 TCP 报文段中去除数据载荷部分并存储在接受缓存中

  • 一方面将接受缓存中的一些字节交付给应用进程

image-20230104181947521


TCP 不保证接收方应用进程所受到的数据块与发送方所发出的数据块具有对应大小的关系

例如:发送方应用进程交给发送方的 TCP 10 10 10 个数据块

  • 但接受方的 TCP 可能只用了 4 4 4 个数据块,就把收到的字节流交付给了上层的应用进程

但是接收方应用进程收到的字节流 必须 \color{red}必须 必须和发送方应用进程发出的字节流完全一样

当然,接收方的应用进程必须有能力识别收到的字节流,把它还原成有意义的应用层数据

  • 要求接收方应用进程又出力这种乱序,多次传输后还能拼接完整的能力

也就是说,TCP 是面向字节流的

  • 这正是 TCP 实现可靠传输、流量控制、以及拥塞控制的基础

image-20230104182354926

说明:

  • 以上之展示出了一个方向的数据流

    • 在实际网络中,基于 TCP 连接的两端可以同时进行 TCP 报文段的发送和接受

    • 也就是全双工通信

  • 实际中,一个 TCP 报文段包含上千个字节是很常见的


4、UDP(不可靠) & TCP(可靠)

4.1、UDP

我们知道,TCP/IP 体系结构中的网际层上其上层提供的是无连接不可靠的传输服务

当运输层使用 UDP 协议时,想起上层提供的也是无连接不可靠的传输服务

image-20230104210133638


发送方给接收方发送 UDP 用户数据报,而传输过程中用户数据报受到干扰而产生误码

接收方 UDP 可以通过该数据报首部中的校验和字段的值检查出产生误码的情况

  • 但是仅仅丢弃该数据报,其他什么也不做

image-20230104210355844

发送方给接收方发送 UDP 数据报,若该数据报被因特网中的某个路由器丢弃了

  • 发送方 UDP 不做任何处理

因为 UDP 向上层提供的是无连接不可靠的传输服务

  • 因此,对于 UDP 用户数据报出现的误码和丢失等问题,UDP 并不关心

image-20230104210621525

基于 UDP 这个特点,UDP 适用于实时应用(例如: IP 电话、视频会议等)


4.2、TCP

尽管网际层中的 IP 协议向上层提供的是无连接不可靠的传输服务

  • 也就是说 IP 数据报可能再传输过程中出现丢失或误码

但只要运输层使用 TCP 协议,就可向其上层提供面向连接的可靠传输服务

  • 我们可以想象成,使用 TCP 协议的收发双方基于 TCP 连接的可靠信道进行数据传输

不会出现传输差错(误码,丢失,乱序,重复)

TCP 适用于要求可靠传输的应用,例如文件传输

image-20230104214541359

5、二者首部对比

5.1、UDP

一个 UDP 用户数据报的首部由首部和数据载荷两部分构成

首部格式如下所示,仅有 4 4 4 个字段,每个字段长度为 2 2 2 个字节

image-20230104214824151

由于 UDP 不提供可靠传输服务,它仅仅在网际层的基础上添加了区分应用进程的端口,

  • 因此,它的首部非常简单,仅有 8 8 8 个字节

5.2、TCP

一个 TCP 报文段由首部和数据载荷两部分构成

首部格式如下所示,这比 UDP 用户数据报的首部复杂的多,

其最小长度为 20 20 20 字节,最大长度为 60 60 60 字节

  • 这是因为 TCP 要实现可靠传输、流量控制、拥塞控制等服务

首部中的字段比较多,首部长度也比较长

image-20230104221114414

6、小结

image-20230104221311671

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

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

相关文章

小程序:会议OA项目-其它页面

目录 一、tabs组件及会议管理布局 自定义tabs组件 跟着官网来感受一下 会议管理的布局 二、个人中心布局 一、tabs组件及会议管理布局 自定义tabs组件 文档参考:自定义组件 | 微信开放文档 跟着官网来感受一下 先建一个文件夹名为components,里面再建一个tabs的…

【C语言进阶(NEW)】六、文件操作(一)|文件|文件的打开和关闭|文件的顺序读写|文件读取结束的判定

目录 一、文件 1.1 什么是文件 1.1.1 程序文件 1.1.2 数据文件 1.2 为什么使用文件 1.3 文件名 二、文件的打开和关闭 2.1 文件指针 2.2 文件的打开和关闭 三、文件的顺序读写 3.1 fgetc 和 fputc(字符输入输出函数) 3.2 fgets 和 fputs&am…

20行原生JS代码手写ElementUI表格组件

又是许久没有写博客了,这几年的疫情,总是居家,时间久了,慢慢的总会想很多。现在越发觉得想做的事情一定要尽早去做,不然总说等下一次,很多时候,就没有下一次了。 今天给大家分享一下如何用原生…

从0到1完成一个Vue后台管理项目(十七、使用Echarts:柱状图、折线图)

往期 从0到1完成一个Vue后台管理项目(一、创建项目) 从0到1完成一个Vue后台管理项目(二、使用element-ui) 从0到1完成一个Vue后台管理项目(三、使用SCSS/LESS,安装图标库) 从0到1完成一个Vu…

DB性能跟不上,加缓存就够了?

服务端软件开发时,通常会把数据存储在DB。而服务端系统遇到的第一个性能瓶颈,往往发生在访问DB时。 这时大部分开发会拿出“缓存”,通过使用Redis在DB前提供一层缓存数据,缓解DB压力,提升服务端性能。 在数据库前添加…

nohup后台运行,进程查看与终止(ubuntu)

1.nohup用途:不挂断地运行命令。语法:nohup Command [ Arg … ] [ & ]无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out 文件中。如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohu…

threejs 学习一

前提 threejs官网:https://threejs.org/ 由于官网访问慢,可以github下载压缩包解压后本地启动 github地址:https://github.com/mrdoob/three.js/ 下载好后解压 安装依赖 npm install 启动:npm start 目录介绍: …

语音识别技术简叙述

语音识别技术简述 语音识别的概念 语音识别技术都是让智能设备能够听懂人类语言,其实一门涉及数学信号处理、人工智能、语言学、数理统计学、声学、情感学及心理学等多学科交叉的学科。这项技术可以提供比如自动客服、自动语音翻译、命令控制,语音验证…

【vue】关于vue2和vue3响应式原理的区别

我们都知道,在Vue2中的数据响应式原理存在许多缺陷。 例如无法对新增和直接删除的数据做到响应式,无法直接操作数组进行响应式处理等等。 而在Vue3中,作者很好的解决了这些缺陷,让我们来对比一下Vue2与Vue3对数据响应式处理的具体…

前端如何保证设置的font-family成功生效?

背景 最近开发的一个新页面,在产品验收的时候跟我反馈说页面里的字体跟设计稿中的字体不一样; 问题的关键是我明明记得我有单独设置过 font-family属性,于是我通过Chorme浏览器的调试工具查看了一下DOM的生效样式; 明明是已经设…

IDEA、TortoiseSVN,TortoiseGit提交忽略文件或文件夹

使用IDEA 的SVN插件提交文件是总是会提交一些不需要提交的文件; 我们可以通过一些简单设置忽略这些文件&#xff1a; 1、IDEA 1、idea设置<<--File Types<<--ignore files and folders 原有的过滤条件&#xff1a;*.hprof;*.pyc;*.pyo;*.rbc;*.yarb;*~;.DS_Store…

yolov3-tiny的darknet权重转onnx

前言 之前一直鸽了yolov3-tiny的onnx模型修复&#xff0c;今天终于把最后一个bug解决了&#xff0c;如果想直接享受成果的&#xff0c;直接点我的github仓库下载&#xff0c;使用说明都写了&#xff0c;这篇文章呢主要是给大家分享一下思路和过程&#xff0c;希望能够启发更多…

初识Linux

文章目录初识Linux操作系统概述硬件和软件操作系统常见操作系统总结初识LinuxLinux的诞生Linux内核Linux发行版总结虚拟机介绍虚拟机总结远程连接Linux系统图形化、命令行使用命令行学习Linux系统远程连接工具总结初识Linux 操作系统概述 硬件和软件 我们所熟知的计算机是由…

领域驱动设计:微服务设计为什么要选择DDD?

我们知道&#xff0c;微服务设计过程中往往会面临边界如何划定的问题&#xff0c;我经常看到项目团队为微服务到底应该拆多小而争得面红耳赤。不同的人会根据自己对微服务的理解而拆分出不同的微服务&#xff0c;于是大家各执一词&#xff0c;谁也说服不了谁&#xff0c;都觉得…

Day855.生产者-消费者模式 -Java 并发编程实战

生产者-消费者模式 Hi&#xff0c;我是阿昌&#xff0c;今天学习记录的是关于生产者-消费者模式的内容。 Worker Thread 模式类比的是工厂里车间工人的工作模式。 但其实在现实世界&#xff0c;工厂里还有一种流水线的工作模式&#xff0c;类比到编程领域&#xff0c;就是生…

RoboMaster EP 实用功能开发(三): 基于树莓派的ROS2机器人系统搭建

功能&#xff1a;在树莓派4b上安装ros2系统&#xff0c;引入robomaster sdk&#xff0c;搭建一个基于ROS2的机器人系统&#xff0c;用于ROS系统的学习、开发和实践。 硬件&#xff1a;RobotMaster EP、树莓派4b 系统平台&#xff1a;Ubuntu 20.04、ROS2&#xff08;Foxy&…

Selenium【Selenium环境搭建与Junit5】

Selenium【Selenium环境搭建与Junit5】&#x1f34e;一. 自行下载谷歌浏览器或者火狐浏览器&#x1f352;1.1 安装好之后需要去掉谷歌(火狐)浏览器自动更新(建议)&#x1f352;1.2下载谷歌(火狐)驱动&#x1f34e;二.Selenium下载与配置&#x1f352;2.1Selenium下载&#x1f3…

服务案例|SQL Server数据库监控反复重启问题

监控平台对主流数据库的监控&#xff0c;能够及时发现异常&#xff0c;快速响应&#xff0c;保障业务系统的稳定。平台通过对SQL Server数据库监控&#xff0c;帮助用户在数据库出现异常时事件处理。 SQL Server数据库监控内容如下 1 、数据库服务器基本性能监控。包括&#…

Hive/MaxCompute SQL性能优化(三):数据倾斜优化实战

SQL性能优化系列&#xff1a;Hive/MaxCompute SQL性能优化(一)&#xff1a;什么是数据倾斜Hive/MaxCompute SQL性能优化(二)&#xff1a;如何定位数据倾斜前面介绍了如何定位数据倾斜&#xff0c;本文介绍如果遇到各种数据倾斜的情况该怎样优化代码。Map长尾优化一、Map读取数据…

ArcGIS如何将Excel表格转换为SHP格式

概述数据的获取渠道是多种多样的&#xff0c;获取的数据格式也是多种多样&#xff0c;作为一名GISer&#xff0c;需要熟练掌握各种格式的数据之间的转换&#xff0c;例如本文要介绍的Excel格式的数据&#xff0c;经常会遇到&#xff0c;这里为大家介绍一下转换方法&#xff0c;…