网络原理-TCP/IP(3) - 三次握手超详解析

news2024/10/6 4:11:27

TCP协议

连接管理

TCP的连接是虚拟的,抽象的,目的是让通信双方保存对方信息.在正常情况下,TCP要经过三次握手建立连接,四次挥手断开连接.

之前我们在网络编程中的 socket = new Socket(ip, port); 这个操作就是建立连接.而这个操作知识调用了socket的api,真正建立的过程,是在操作系统内核中完成.

主流程如下:

三次握手

也就是上图的第一个部分,截取如下:

 

所谓三次握手就是建立连接的过程.确保通信双方各自给对方发起一个SYN,各自给对方回应一个ACK.

什么是SYN?

在之前其实也见过,就是TCP报头中的其中一个标志位,作为一个特殊的TCP数据报存在,意为同步(TCP这里的同步,是进入连接状态).

1.没有载荷,不会携带应用层数据

2.六个标志位的第五位SYN为1时,表达语义:我想与你建立连接(抽象的)->告诉服务器:"我是谁".最后有两种可能:1.服务器同意建立连接,2.不同意(少见,一般是服务器载荷过大)

3. SYN不代表任何程序的业务逻辑,只是打招呼,称为握手.

过程解释:

1.第一次:客户端向服务器发送SYN

第一次握手,客户端把自己的信息告诉服务器了,但服务器对于是否要存储,还需要观望一下.等到所有的握手完成,才会保存客户端信息.

2.第二次:服务器向客户端发送SYN+ACK

其中ACK表示的是确认应答的内容("我接收到了"),SYN表示我同意.之所以这两条能够合并,是因为触发时机完全一致,都是内核在收到SYN之后立即触发.

3.第三次:客户端向服务器返回ACK

"我知道你收到了".

如果觉得上述讲解比较抽象,可以看一下下面的例子:

比如我和我对象远程联机打LOL,在之前,我们需要确保一下各自双方的耳机和麦克风是否能正常工作,因此我们需要通过三次握手确认一下.(之前我和朋友设定了一个暗号:我先说"派大星", 她听见了后说"海绵宝宝", 我听见了之后再说"我们一起去抓水母吧").过程过程如下:

 建立连接的意义:

1.投石问路,确认当前路径是否畅通(可靠性的前提条件).

因此,三次握手对于可靠传输是有意义的,它的作用有限,关键的可靠传输还是通过确认应答以及超时重传来保证的.毕竟三次握手,只是通信最开始的时候握了一下.后面开始传输的时候,就和三次握手无关了.

2.验证通信双方,发送能力和接收能力是否正常.(之前讲的我和对象开黑的例子)

3.协商参数,通信双方共同确认一些通信中必备参数的值.(关注点在两端).

往往以"选项"部分体现,防止"前朝的剑,斩本朝的人".  其中有一个信息挺关键,就是TCP通信信号的起始值.TCP在一次通信的过程中,序号是从0/1开始计算的.而是先选择一个较大的数字,以这个数的开头计算.即使是同一个客户端,服务器多次连接,也能保证序号不同.这时什么情况呢,再看下面的例子:

在第一次连接的过程中,比如传的一个数据在路上堵车了,迟迟未到达对端.

等到了对端的时候,之前的连接已经没了,早已经是新连接了,此时,这一份数据就应该丢弃.

而通过上面的机制,发现这个包的序号和新连接的序号差异很大,这样就可以精确把包丢弃掉.

四次挥手

也就是最下面的部分,图示如下:

所谓四次挥手就是为了断开连接,所谓断开连接,就是把对端中的信息,从数据结构中删除掉/释放掉.只是"逻辑删除"->断开连接

1.其中,FIN为结束报文段,socket.close()就会触发FIN(如果进程结束,也会触发FIN).

2.中间的FIN和ACK不能像三次握手一样合并,原因是ACK是内核触发的,而FIN是通过代码触发的(具体取决于代码结构),两者可能会存在时间间隔(但时间间隔小就可以合并).

3.四次挥手,不一定是客户端先发FIN,也可能是服务器先发FIN.(这一点和三次握手不一样,三次握手,一定是客户端主动).

四次挥手和三次握手之间,相似和不同之处:

相似:1.都是通信双方各自给对方发送一个fin/syn,各自给对方返回ack.

         2.数据传输过程:syn/ack/syn/ack,fin/ack/fin/ack.它们中间的两个指令在同一个机器上.

不同:1.三次握手中间两次一定可以合并,四次挥手不一定.

         2.三次握手是客户端请求,四次挥手都可以.

TCP状态

TCP状态和"线程状态"是一个类似的概念.TCP服务器和客户端都要有一定的数据结构来保存连接这个信息,在这个数据结构中,其中一个属性叫做"状态".操作系统根据内核的状态不同决定要做什么.

较细的实线表示服务端状态的变化情况.

较粗的实线表示客户端状态的变化情况.

CLOSED是一个假想的起始点,并不是真实的状态. 

简单介绍两个状态:

LISTEN:表示服务器创建好了ServerSocket了,并且绑定端口号完成了(手机开机信号好,可随时和我打电话).

ESTABLISHED:已确立,客户端和服务器连接已完毕(三次握手结束).

重点介绍两个状态:

TIME_WAIT

 在连接管理的过程中,谁主动断开连接就会进入这个过程,表示本端给对端发起FIN,对端也给我发FIN,此时本端进入TIME_WAIT,给最后一个ACK重传留有一定时间.

 留给重传ACK的时间大概是2msl(最大生存时间单位).

这就可以保证在两个传输方向上的尚未被接收或者迟到的报文段都已经消失(否则服务器立即重启,可能会收到上一个进程迟到的数据,但是这种数据很有可能是错误的);

同时也是在理论上保证最后一个报文可靠到达(假设最后一个ACK丢失,那么服务器会再重发一个FIN.虽然此时客户端的进程不在了,但是TCP连接还在,仍然LAST_ACK);

客户端如果在这个环节把TCP释放掉,此时意味着重传的FIN就无法返回ACK了(保存对端的数据结构存在,才能给这个连接提供各种操作,返回ACK).

CLOSE_WAIT

表示接下来的代码需要调用close来主动发起FIN,是收到对方的FIN进入这个状态的(谁被动断开谁进入).

正常情况下,CLOSE_WAIT不宜观察,代码中也会比较快速的关闭socket,这时就从CLOSE_WAIT变为LAST_ACK.

但是如果发现,服务器/客户端中出现大量的CLOSE_WAIT状态,原因就是服务器没有正确关闭socket,导致四次挥手没有完成,这是一个bug,只需要加上对应的close即可解决问题.

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

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

相关文章

FW如何区别 PAW3212DB-TJDT 和 PAW3220DB-TJDL/TJDR/TJDS

PAW3212DB-TJDT 和 PAW3220DB-TJDL/TJDR/TJDS 的引脚功能定义是一样的,只是封装有一点不一样。PAW3212DB-TJDT是圆形火山口,配的是圆孔透镜,PAW3220DB-TJDL/TJDR/TJDS是方形火山口,配的是方孔透镜。 PAW3212DB-TJDT 和 PAW3220DB-…

杂题——试题-算法训练-P0602

分析: 把要重排序的数字转成数组对数组进行排序,从小到大排序数组转成字符串,字符串转成数字,得到最小数再把最小数的字符串反转,得到最大数注意: 在java语言中,如果使用Arrays.toString(digits…

C++之平衡二叉搜索树查找

个人主页:[PingdiGuo_guo] 收录专栏:[C干货专栏] 大家好,我是PingdiGuo,今天我们来学习平衡二叉搜索树查找。 目录 1.什么是二叉树 2.什么是二叉搜索树 3.什么是平衡二叉搜索树查找 4.如何使用平衡二叉搜索树查找 5.平衡二叉…

C#,阿格里数(Ugly Number)的多种算法与源代码

1 丑数,阿格里数 阿格里数,即丑数(Ugly Number)、逊数(Humble Number)。 一般而言:把只包含质因子2,3和5的数称作丑数(Ugly Number)。例如6、8都是丑数&…

基于PSO-BP神经网络的风电功率MATLAB预测程序

微❤关注“电气仔推送”获得资料(专享优惠) 参考文献 基于风电场运行特性的风电功率预测及应用分析——倪巡天 资源简介 由于自然风具有一定的随机性、不确定性与波动性,这将会使风电场的功率预测受到一定程度的影响,它们之间…

FPGA高端项目:Xilinx Zynq7020系列FPGA 多路视频缩放拼接 工程解决方案 提供4套工程源码+技术支持

目录 1、前言版本更新说明给读者的一封信FPGA就业高端项目培训计划免责声明 2、相关方案推荐我这里已有的FPGA图像缩放方案我已有的FPGA视频拼接叠加融合方案本方案的Xilinx Kintex7系列FPGA上的ov5640版本本方案的Xilinx Kintex7系列FPGA上的HDMI版本本方案的Xilinx Artix7系列…

探索设计模式的魅力:从单一继承到组合模式-软件设计的演变与未来

设计模式专栏:http://t.csdnimg.cn/nolNS 在面对层次结构和树状数据结构的软件设计任务时,我们如何优雅地处理单个对象与组合对象的一致性问题?组合模式(Composite Pattern)为此提供了一种简洁高效的解决方案。通过本…

C++类与对象:默认成员函数

文章目录 1.类的6个默认成员函数2.构造函数3.析构函数4. 拷贝构造函数5.赋值运算符和运算符重载6.日期类实现7.const成员8.重载流插入<< &#xff0c;流提取>>1.流插入2.流提取 9.取地址及const取地址操作符重载 1.类的6个默认成员函数 空类:也就是什么成员都没有的…

Spring Boot集成Redisson详细介绍

Redisson是一个用于Java的分布式和高可用的Java对象的框架&#xff0c;它基于Redis实现。在Spring Boot应用程序中集成Redisson可以帮助我们更轻松地实现分布式锁、分布式对象、分布式集合等功能。本文将介绍如何在Spring Boot项目中集成Redisson&#xff0c;并展示一些基本用法…

vs正则搜索 int main() 排除 // int main()

1 ctrl f 2 选择正则 3 表达式 ^\s*int\smain\(\) ^ 表示匹配行开始\s* 匹配0个或多个空格int 匹配int关键字\s 匹配一个或多个空格main\( 匹配main函数和左括号

ChatGPT真有很多人在用吗?——回答一位知友的问题

先上结论 是的。数据不会撒谎&#xff0c;用户拿脚投票&#xff0c;ChatGPT发布仅五天内就达到了100万用户&#xff0c;是有史以来增长最快的消费者应用程序。2023年全球前50款AI工具就收获了240亿次访问&#xff0c;其中ChatGPT收获了146亿次访问。 一些想法和思考 我的一些…

9.defer语句调用顺序

目录 概述实践defer结果defer和return执行顺序 结束 概述 defer 类似 java 中的异常处理中的 finally &#xff0c;在 Go 中 defer 是一种压栈出栈操作。 实践 defer package mainimport "fmt"func demo1() {fmt.Println("demo1") }func demo2() {fmt.Pr…

MySql调优(三)Query SQL优化(2)profiler诊断工具

Mysql中自带性能分析工具Profile。注意&#xff1a;profile仅对当前会话有效 一、操作步骤 1、打开 profile set profiling1; 2、执行sql语句 3、分析sql语句执行时间 show profiles 其他参数&#xff1a; ALL&#xff1a;显示所有的开销信息。 BLOCK IO&#xff1a;显示块…

深入理解 Golang 的 crypto/elliptic:椭圆曲线密码学的实践指南

深入理解 Golang 的 crypto/elliptic&#xff1a;椭圆曲线密码学的实践指南 引言crypto/elliptic 库概览基本使用教程高级应用案例性能与安全考量结论 引言 在当今数字时代&#xff0c;数据安全和加密技术成为了信息技术领域的重中之重。特别是在网络通信和数据存储领域&#…

使用Java实现HTTP持久连接:一次与网络的“长聊“

大家都知道&#xff0c;传统的HTTP连接就像是一次性的餐具&#xff0c;每发送一个请求&#xff0c;就得重新建立一个连接&#xff0c;然后快速用完就扔。这对于网络资源来说&#xff0c;简直就是一场"大肆挥霍"的派对。但幸好&#xff0c;我们有HTTP持久连接&#xf…

大力说视频号第三课:手把手教你视频号如何认证

视频号生态不断完善&#xff0c;越来越多的创作者认识到视频号认证的重要性。微信视频号认证不但能提升搜索排名&#xff0c;还能直播推流、与企业微信的关联等优势。 今天大力就来向大家介绍一下视频号如何做认证。 01 个人认证 个人认证又包括兴趣认证和职业认证。 A、兴趣…

华为突然官宣:新版鸿蒙系统,正式发布

华为&#xff0c;一家始终引领科技创新潮流的全球性企业&#xff0c;近日再次引发行业震动——全新HarmonyOS NEXT&#xff0c;被誉为“纯血版鸿蒙”的操作系统正式官宣。这是华为在操作系统领域迈出的坚实且具有突破性的一步&#xff0c;标志着华为正逐步摆脱对安卓生态系统的…

Ajax 详解及其使用

Ajax&#xff08;Asynchronous JavaScript and XML&#xff09;是一种在客户端与服务器之间进行异步通信的技术&#xff0c;它允许网页在不重新加载整个页面的情况下&#xff0c;与服务器交换数据并更新部分网页内容。Ajax 的核心是XMLHttpRequest&#xff08;XHR&#xff09;对…

【异常处理】word或ppt打开后没反应或闪退,或者报错由安全模式打开

折腾了2个小时&#xff0c;可算解决了&#xff0c;办法是在【控制面板】中右击&#xff0c;选择【更改】 选择联机修复&#xff0c;然后耐心等待&#xff0c;最后再打开就没问题了。

Task05:PPO算法

本篇博客是本人参加Datawhale组队学习第五次任务的笔记 【教程地址】https://github.com/datawhalechina/joyrl-book 【强化学习库JoyRL】https://github.com/datawhalechina/joyrl/tree/main 【JoyRL开发周报】 https://datawhale.feishu.cn/docx/OM8fdsNl0o5omoxB5nXcyzsInGe…