【TCP与UDP】day4

news/2024/5/18 14:41:57 标签: tcp/ip, udp, 网络协议

1.连接性
TCP是面向连接的,它在传输数据之前要先建立连接,传输完毕后再释放连接。
UDP是无连接的,发送数据之前不需要建立连接,也不会维护连接状态。
2.可靠性
TCP 提供可靠的数据传输,通过确认、重传、流量控制和拥塞控制等机制保证数据的完整性和可靠性。
UDP 不提供可靠性保证,发送的数据包可能会丢失、重复或乱序,应用层需要自行处理这些问题。
3.速度
UDP 比 TCP 快,因为它没有建立连接和维护状态的开销,以及不进行确认和重传等复杂的处理。
TCP 在传输过程中会增加额外的开销,因此速度相对较慢。
4.应用场景
TCP 适用于要求可靠性的应用,如文件传输、Web 浏览、电子邮件等。
UDP 适用于实时性要求较高、对可靠性要求较低的应用,如音频、视频流、在线游戏等。

TCP 三次握手:
第一步 - 客户端向服务器发送 SYN 包:
客户端发送一个 SYN包,其中包含一个随机生成的序列号(Seq=X)。
第二步 - 服务器回复 SYN + ACK 包:
服务器收到 SYN 包后,会回复一个 SYN和 ACK包,其中 SYN 包含另一个随机生成的序列号(Seq=Y),ACK 包含确认号(ACK=X+1)。
第三步 - 客户端发送 ACK 包:
客户端收到 SYN+ACK 包后,会发送一个确认号为服务器序列号加一的 ACK包,即 ACK=Y+1。
TCP 四次挥手:
第一步 - 客户端发送 FIN 包:
客户端发送一个 FIN包,表示数据发送完毕,请求关闭连接。
第二步 - 服务器回复 ACK 包:
服务器收到 FIN 包后,会发送一个确认号为客户端序列号加一的 ACK包,表示确认收到了客户端的关闭请求。
第三步 - 服务器发送 FIN 包:
服务器发送一个 FIN 包,表示服务器也准备关闭连接。
第四步 - 客户端回复 ACK 包:
客户端收到服务器的 FIN 包后,会发送一个确认号为服务器序列号加一的 ACK(确认)包,表示确认收到了服务器的关闭请求。此时连接关闭。


http://www.niftyadmin.cn/n/5368312.html

相关文章

【Android辟邪】之:gradle——在项目间共享依赖关系版本

翻译和简单修改自:https://docs.gradle.org/current/userguide/platforms.html#sec:sharing-catalogs 建议看原文(有能力的话) 现在 Gradle 脚本可以使用两种语法编写:Kotlin 和 Groovy 本文只使用kotlin脚本语法,更…

在 Java 中处理整数上溢和下溢

本文介绍整数数据类型的上溢和下溢以及该问题的处理。 Java 中整数上溢和下溢概述 如果您使用整数值,则可能会遇到上溢或下溢错误。 当我们错误地声明变量时,就会发生这种情况,例如分配的值超出了声明的数据类型的范围。 众所周知&#xff…

156基于Matlab的光纤陀螺随机噪声和信号

基于Matlab的光纤陀螺随机噪声和信号,利用固定步长和可调步长的LMS自适应滤波、最小二乘法、滑动均值三种方法进行降噪处理,最后用阿兰方差评价降噪效果。程序已调通,可直接运行。 156 信号处理 自适应滤波 降噪效果评估 (xiaohongshu.com)

社交分享效果统计:Xinstall助您精确追踪用户行为,优化推广策略

在移动互联网时代,社交分享已成为App推广的重要手段之一。通过微信、QQ等社交工具及主流浏览器的多渠道分享邀请,可以实现裂变式的推广效果,迅速扩大App的用户群体。然而,如何精确统计社交分享带来的安装量、注册量等关键数据&…

vue安装依赖--save-dev和--save的区别是啥

就是使用这2种方法后就发现哪种都可以 dependencies:运行时的依赖,发布后,即生产环境下还需要用的模块 devDependencies:开发时的依赖。里面的模块是开发时用的,发布时用不到它。 作为一名后端开发人员,我…

探索PostgreSQL:从基础到实践(简单实例)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 下载前言一、PostgreSQL是什么?二、使用步骤1.引入库2.读入数据 总结 下载 点击下载提取码888999 前言 在当今的大数据时代,数据库作为信…

Windows中如何使用 Anaconda 和 gempy地质建模

GemPy是一个免费开源的Python软件包,主要用于建立三维地质模型。以下是windows下GemPy的安装过程。 一、(可选步骤)N卡加速 如果使用的是英伟达的RTX显卡,可以去N卡官网下载cuda安装包以启用GPU加速。 首先检查显卡支持的CUDA版…

完全背包理论基础 C++力扣题目518--零钱兑换II

动态规划:完全背包理论基础 本题力扣上没有原题,大家可以去卡码网第52题 (opens new window) #思路 #完全背包 有N件物品和一个最多能背重量为W的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品都有无限个&#xff0…