网络面试-0x11 TCP为什么需要三次握手和四次挥手?

news2024/11/23 11:48:54

网络面试-0x11 TCP为什么需要三次握手和四次挥手?

alt

一、三次握手

三次握手[three-way-handshake]:客户端和服务器总共发送3个包,以建立TCP连接。

什么是连接了?主要作用是什么?

连接:
主要作用:为了确认双方的接收能力发送能力是否正常,指定自己的初始化序列号为后面的可靠性传送做准备。

alt 过程如下:
1)第一次握手:客户端发送搞一个SYN报文给服务端,并且报文中指明了客户端的初始化系列seq=ISN(c),此时,客户端处于SYN_SENT状态
2)第二次握手:服务器收到客户端的SYN包,处理之后,发送自己的SYN+ACK包,将客户端的ISN+1作为ack的值,此时,服务器处于SYN_RCVD的状态。
3)第三次握手:客户端发送一个ACK报文,seq=ISN+1。此时客户端处于ESTABLISHED状态。 服务器收到ACK报文之后,也处于ESTABLISHED状态,此时,双方已建立起了连接。

每次握手的作用:

第一次握手:客户端的发送能力、服务器的接收能力是正常的。
第二次握手:服务器的接收、发送能力正常,客户端的接收、发送能力是正常的。 不过,此时服务器并不能确认客户端的接收能力是否正常。
第三次握手:客户端接收、发送能力正常,服务器自己的发送、接收能力也正常。

1、为什么不是两次握手?

如果两次握手,发送端能够确定自己发送的信息对方能够收到,而对方发送的消息,发送端也能够收到。 接收端只能够确定对方发送的消息自己能够收到,而无法确定自己发送的消息对方能够收到。

2、第2次握手传回了ACK,为什么要穿SYN?

ACK 是告诉客户端发来的数据已经接受无误,而传回SYN是为了把自己的初始化序列号seq同步给客户端。

二、 四次挥手

TCP 终止一个连接, 需要经过四次发包的过程。

alt 挥手过程:
1)第一次挥手:客户端发送一个FIN报文,报文中指定一个序列号。 此时,客户端处于FIN_WAIT1状态, 停止发送数据,等待服务端的确认。seq=x
2)第二次挥手:服务端接收到FIN报文之后,发送ACK报文, ack=x+1, seq=Y, 此时,服务端处于CLOSE_ WAIT状态。
3)第三次挥手:如果服务端也想断开连接, 和客户端的第一次挥手是一样的,发送FIN报文, 指定一个序列号, 此时,服务器处于LAST_ACK的状态。
4)第四次挥手:客户端收到FIN之后,一样发送一个ACK报文作为应答,且把服务器的序列号值+1作为自己ACK报文的序号值,此时客户端处于TIME_WAIT状态。需要过一阵子以确保服务端收到自己的ACK报文之后才会进入CLOSED状态,服务端收到ACK报文之后,就处于关闭比连接了,处于CLOSED状态。

1、 四次挥手原因

服务端在收到客户端断开连接FIN报文后,并不会立即关闭连接, 而是先发送一个ACK包线告诉客户端收到关闭连接的请求,只有当服务器的所有报文发送完毕之后,才发送FIN报文断开连接,因此需要四次挥手。

2、CLOSE-WAIT 和 TIME-WAIT 的状态和意义

CLOSE-WAIT: 服务器收到客户端关闭连接的请求并告诉客户端自己已经成功收到了请求之后, 服务器进入CLOSE-WAIT状态,然而此时有可能服务端还有一些数据没有传输完成,因此不能立即关闭连接, 而CLOSE-WAIT状态就是为了保证服务器在关闭连接之前将待发送的数据发送完成。

TIME-WAIT:发生在第四次挥手,当客户端收到那个服务端发送ACK确认报文后进入该状态,若取消该状态,即客户端在收到服务端的FIN报文后立即关闭连接,此时,
(1)服务端相应的端口并没有关闭,若客户端在相同的端口立即建立了新的连接,则有可能接收到上次连接残留的数据包,可能会导致不可以预料的异常出现。—— 保证没有收到残余的数据
(2)除此之外,假设客户端最后一次发送的ACK包在传输时候丢失,由于TCP协议的超时重传机制,服务端将重发FIN报文,若客户端并没有维持TIME-WAIT状态而直接关闭的话,当收到服务端重新发送的FIN包时,客户端就会用RST包来响应服务端,这就会使得对方认为是有错误发生,然而其实只是正常的关闭连接过程,并没有出现异常情况。 —— 保证最后一个ACK到达

3、TIME-WAIT 状态会导致什么问题?怎么解决?

场景: 高并发业务
在高并发短连接的TCP服务器上,当服务器处理完请求后,主动请求关闭连接,这样服务器上会有大量的连接处于TIME_WAIT状态,服务器维护每个连接需要一个socket,也就是每个连接会占用一个文件描述符,而文件描述符的使用有上限的,如果持续高并发,会导致一些正常的连接失败。
解决方案:修改配置或设置SO_REUSEADDR套接字,使得服务器处于TIME-WAIT状态下的端口能够快速回收和重用。

4、TIME-WAIT为什么是2MSL?

当客户端发出最后的ACK确认报文时,并不能够确定服务器端能够接收到该段报文。 所以,此时会设置一个2MSL的计时器。2MSL即是服务器端发出FIN报文和客户端发出的ACK确认报文所能保持有效的最大时长。
若是服务器没有收到ACK报文,再次向客户端发送FIN报文。 如果客户端在2MSL内收到了服务器再次发来的FIN报文,说明服务器由于一些原因并没有收到客户端发出的ACK确认报文。客户端将再次向服务器发出ACK确认报文,并重新开始2MSL计时。 所以:客户端要经历2MSL市场的TIME-WAIT阶段,为的是确认服务器能否接收到客户端发出的ACK确认报文。

区分 MSL, TTL, RTT

1、MSL(Maximum Segment Lifetime) 报文最大生存空间,任何报文在网络上存在的最长时间,超过这个时间报文将被丢弃,因为TCP报文(segment)是IP数据报(datagram)的数据部分。 每个具体的TCP实现都必须选择一个确定的MSL值。RFC 1122建议是2分钟。
2、TTL(time to live)生存时间。ip头中有一个TTL域,这个生存时间是由源主机设置初始值但并不是存的具体时间,而是存储的一个IP数据报可以经过的最大路由数,每经过一个处理他的路由器此值就-1,当此值位0则数据报将被丢弃,同时发送ICMP报文通知源主机。RFC 793中规定MSL为2分钟,实际应用中常用的是30秒,1分钟和2分钟等。
2MSL即两倍的MSL,TCP的TIME_WAIT状态也称为2MSL等待状态,当TCP的一端发起主动关闭,在发出最后一个ACK包后,即第3次握手完成后发送了第四次握手的ACK包后就进入了TIME_WAIT状态,必须在此状态上停留两倍的MSL时间,等待2MSL时间主要目的是怕最后一个ACK包对方没收到,那么对方在超时后将重发第三次握手的FIN包,主动关闭端接到重发的FIN包后可以再发一个ACK应答包。在TIME_WAIT状态时两端的端口不能使用,要等到2MSL时间结束才可继续使用。当连接处于2MSL等待阶段时任何迟到的报文段都将被丢弃。不过在实际应用中可以通过设置SO_REUSEADDR选项达到不必等待2MSL时间结束再使用此端口。 TTL与MSL是有关系的但不是简单的相等关系,MSL要大于等于TTL。
3、RTT(round-trip time) 客户端到服务器往返所花的时间。TCP含有动态估算RTT的算法。TCP还持续估算一个给定连接的RTT,这是因为RTT受网络传输拥塞程序的变化而变化。
表示从发送端发送数据开始,到发送端收到来自接收端的确认(接收端收到数据后便立即发送确认),总共经历的时延。
一般认为单向时延=传输时延t1+传播时延t2+排队时延t3
t1是数据从进入节点到传输媒体所需要的时间,通常等于数据块长度/信道带宽
t2是信号在信道中需要传播一定距离而花费的时间,等于信道长度/传播速率(光纤中电磁波的传播速率约为210^5 km/s,铜缆中2.310^5 km/s)
t3可笼统归纳为随机噪声,由途径的每一跳设备及收发两端负荷情况及吞吐排队情况决定(包含互联网设备和传输设备时延)

5、有很多TIME-WAIT状态如何解决?

服务器可以设置SO_REUSEADDR套接字选项来通知内核,如果端口被占用,但 TCP 连接位于 TIME_WAIT 状态时可以重用端口。如果你的服务器程序停止后想立即重启,而新的套接字依旧希望使用同一端口,此时 SO_REUSEADDR 选项就可以避免 TIME-WAIT 状态。
也可以采用长连接的方式减少 TCP 的连接与断开,在长连接的业务中往往不需要考虑 TIME-WAIT 状态,但其实在长连接的业务中并发量一般不会太高。

6、有很多CLOSE-WAIT状态如何解决?

1)检查是不是自己的代码问题(看是否服务端程序忘记关闭连接),如果是,则修改代码 2)调整系统参数,包括句柄相关的参数和TCP/IP的参数,一般一个CLOSE_WAIT会维持至少2个小时的时间,我们可以通过调整参数来缩短这个时间。

常见的关键缩写:

CWR: 拥塞窗口减(发送方降低它的发送速率) ECE: ECN会显(发送方接收到一个更早的拥塞通告) URG: 紧急(紧急指针字段有效 —— 很少被使用) ACK: 确认(确认号字段有效 —— 连接建立以后,一般都启用状态) PSH:推送(接收方应尽快给应用程序传送这个数据 —— 没被可靠地实现或用到) RST:重置连接(连接取消,经常是因为错误) SYN:用于初始化一个连接的同步序号 FIN:该报文端发送方已经结束向对方发送数据。

三、 总结

alt

公众号:`技术小难`
[简书](https://www.jianshu.com/u/1851ec413025)
[博客园](https://account.cnblogs.com/blog-apply) 链接需要替换
[CSDN](https://blog.csdn.net/u012496940?spm=1000.2115.3001.5343)
[知乎](https://www.zhihu.com/people/gu-han-90-61)
[掘金](https://juejin.cn/user/1943592286824333)
[segmentfault](https://segmentfault.com/u/natqeeak/articles)

本文由 mdnice 多平台发布

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

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

相关文章

基于Redis实现特殊的消息队列

特殊场景的消息队列 消息队列使用比较多的产品kafka,在各个领域都发挥了很大的作用,但是在以下的几种场景是无法满足需求。 场景 消息重复概率比较高时,需要对重复消息进行合并处理避免浪费有限的资源,减少延迟需要根据业务自定…

正大国际期货:投资外盘期货如何用布林线判断走势?

外盘期货的投资者越来越多,每个投资者判断大盘走势的方式也不尽相同,那么今天正大IxxxuanI就来简单的和大家说说外盘期货投资如何用布林线判断走势吧。 1、当布林线多条轨道向上或是向下运行时,这能非常有效的说明走势强劲程度。投资者应牢牢…

接触非线性分析不收敛? 写给ABAQUS初学者的N个经验

接触,在仿真分析中,绝对是个看似青铜实则王者级别的难题。一些通用的解决办法,在帮助文件的Interaction → Contact Difficulties and Diagnostics中找到,例如初始接触状况、穿透、突然分离造成的局部不稳定等等。 但是确实没有一…

slam定位学习笔记(七)-g2o学习

主要学习的是这篇文章,但大佬并没有在文章里面仔细的讲g2o,所以我在网上找了这几篇介绍g2o的文章,讲的十分详细,对入门十分友好:文章一、文章二、文章三,这三篇都是一个作者写的,主要是针对编程…

第五届“强网”拟态防御国际精英挑战赛——特邀战队篇

第五届“强网”拟态防御国际精英挑战赛即将在南京隆重开赛!本届大赛面向全球顶尖CTF战队,在创新应用场景与技术的基础上,拓展升级赛道,全面覆盖典型网络设备。大赛汇集国内外60支精英战队,参赛阵容、数量再创新高。 本…

35岁了,月薪还不足2W,辞职又怕找不到工作,该何去何从?

今天看到网上有人在吐槽:“马上就35岁了,月薪还不到2W,公司发展缓慢,想离职又怕找不到工作,不知道怎么办?” 单看月薪两万,好像也不少,不过收入跟行业和地域也有很大关系。薪资&…

JWT详解

1、什么是token,解决了什么问题? token 就是常说的 “令牌”,本质上是全局唯一的字符串,用来唯一识别一个客户端,解决了session依赖单个web服务器的问题。单体应用时,用户的会话信息保存在session中&#…

如何在视频中加水印?分享这些实用的加水印方法给你

视频要怎么添加水印呢?在我们的日常生活中,短视频已经离不开我们的视野了,我们经常通过短视频来放松、查找资料或者是丰富知识。同样的,我们也可以通过自己的剪辑并发布一些视频到各个平台上获取流量。那么在这个过程中&#xff0…

web前端-javascript-基本数据类型和引用数据类型(对象和基本数据类型保存到栈内存,对象保存在堆内存,比较两个基本数据类型或引用数据类型)

基本数据类型和引用数据类型 var a 123; var b a; a;/* console.log("a "a); console.log("b "b); */var obj new Object(); obj.new "孙悟空";var obj2 obj;//修改obj的name属性 obj.name "猪八戒";/* console.log(obj.name…

京东低代码平台:浅谈水滴拖拽画布的设计与实现

水滴低代码平台简介 京东水滴平台面向企业内部后台管理系统场景,提供可视化搭建等低代码配置、构建及部署能力。 水滴画布作为水滴低代码的核心能力之一,具备灵活、易用的特点,用户可以通过简单拖拉拽的方式,在不需要具备前端知…

【应用回归分析】CH4 假设检验与预测1——一般线性假设

目录 前言 引例 1.【例1】 2.【例2】 一、假设检验的基本思想 二、定理【4.1.1】 1.定理内容 2.定理证明 前言 在上一章,我们讨论了回归参数的几种估计方法,依据这些方法得到回归系数的估计,就可以建立经验回归方程。但是,…

python+django汽车租赁系统pycharm项目

目录 1 绪论 1 1.1课题背景 1 1.2课题研究现状 1 1.3初步设计方法与实施方案 2 1.4本文研究内容 2 4 2.3 B/S结构简介 4 2.4MySQL数据库 5 3 系统分析 6 3.1系统可行性分析 6 3.1.1经济可行性 6 3.1.2技术可行性 6 3.1.3运行可行性 6 3.2系统现状分析 6 3.3功能需求分析 7 …

Transformer for CV

文章目录Transformer 的基础结构NLP StructureVITSWINDERTTransformer 常用terms分块的batch-size自动计算Batch normLayer normMultihead Self AttentionGELU/ELU/RELUTransformer Vs CNN每个模型的详细笔记Vit图片分割自己的思考计算过程Segmenter运行 TrainTrain 里的结构DE…

命名空间提示“http://schemas.microsoft.com/xaml/behaviors”不存在Interation的解决办法

以下面的部分wpf程序为例&#xff1a; <Button Grid.Column"3" Margin"5" Content"<" FontSize"18" Background"Transparent" Foreground"LightGray"><b:Interaction.Triggers><b:EventTrigge…

static应用知识:单例设计模式

1、什么是设计模式&#xff08;Design pattern&#xff09; 开发中经常遇到一些问题&#xff0c;一个问题通常有n种解法的&#xff0c;但其中肯定有一种解法是最优的&#xff0c;这个最优的解法被人总结出来了&#xff0c;称之为设计模式。 设计模式有20多种&#xff0c;对应2…

轻松上手 | 使用国内资源安装 K3s 全攻略

作者&#xff1a; 王海龙&#xff0c;SUSE Rancher 中国社区技术经理&#xff0c;Linux Foundation APAC Evangelist&#xff0c;负责 Rancher 中国技术社区的维护和运营。拥有 8 年的云计算领域经验&#xff0c;经历了 OpenStack 到 Kubernetes 的技术变革&#xff0c;无论底层…

3D帧间匹配-----剔除动态障碍物

0. 简介 作为SLAMer在建图时最怕的就是大量的动态障碍物存在&#xff0c;这会导致建图的不精确&#xff0c;而本文主要围绕着如何剔除动态障碍物开始讲起&#xff0c;并提供一种快速的过滤障碍物的方法。 1. 主要方法 在调研的过程中主要存在有两种方法&#xff0c;第一种如…

安全标准汇总

文章目录资源导航法律法规0x01常见标准代号0x02 2022年新发布0x03 按体系分类一般性法律规定规范和惩罚信息网络犯罪的法律直接针对信息安全的特别规定具体规范信息安全技术、信息安全管理0x04 安全等级保护0x05 数据安全声明资源导航 国家标准全文公开系统&#xff1a;国家标…

代码随想录训练营第35天|LeetCode 860.柠檬水找零、406.根据身高重建队列、452. 用最少数量的箭引爆气球

参考 代码随想录 题目一&#xff1a;LeetCode 860.柠檬水找零 这个题在做的时候有误解&#xff0c;第一不能对数组bills排序&#xff0c;只能按照给定的顺序处理&#xff1b;第二&#xff0c;只能从头开始处理&#xff0c;不能中间的某个点开始。 其实这个题很简单&#xff…

synchronized锁升级过程

【一些面试真题】&#xff1a; 阿里P9——0x80的执行过程。 【 重温CAS过程 】&#xff1a; 【硬件】&#xff1a; Lock指令在执行后面指令的时候锁定一个北桥信号&#xff08;不采用锁总线的方式&#xff09;。 【用户态 与 内核态】&#xff1a; 作为操作系统来说&#x…