为什么tcp连接的时候是三次握手,关闭的时候是四次握手
TCP的三次握手和四次断开 TCP是一个面向连接的服务,面向连接的服务是电话系统服务模式的抽象,每一次完整的数据传输都必须经过建立连接,数据传输和终止连接3个过程,TCP建立连接的过程称为三次握手,下面看一下三次握手的具本过程TCP三次握手过程1 主机A通过向主机B 发送一个含有同步序列号的标志位的数据段给主机B ,向主机B 请求建立连接,通过这个数据段,主机A告诉主机B 两件事:我想要和你通信;你可以用哪个序列号作为起始数据段来回应我.2 主机B 收到主机A的请求后,用一个带有确认应答(ACK)和同步序列号(SYN)标志位的数据段响应主机A,也告诉主机A两件事:我已经收到你的请求了,你可以传输数据了;你要用哪个序列号作为起始数据段来回应我3 主机A收到这个数据段后,再发送一个确认应答,确认已收到主机B 的数据段:"我已收到回复,我现在要开始传输实际数据了这样3次握手就完成了,主机A和主机B 就可以传输数据了.3次握手的特点没有应用层的数据SYN这个标志位只有在TCP建产连接时才会被置1握手完成后SYN标志位被置04次断开1 当主机A完成数据传输后,将控制位FIN置1,提出停止TCP连接的请求2 主机B收到FIN后对其作出响应,确认这一方向上的TCP连接将关闭,将ACK置13 由B 端再提出反方向的关闭请求,将FIN置14 主机A对主机B的请求进行确认,将ACK置1,双方向的关闭结束.由TCP的三次握手和四次断开可以看出,TCP使用面向连接的通信方式,大大提高了数据通信的可靠性,使发送数据端和接收端在数据正式传输前就有了交互,为数据正式传输打下了可靠的基础名词解释ACK TCP报头的控制位之一,对数据进行确认.确认由目的端发出,用它来告诉发送端这个序列号之前的数据段都收到了.比如,确认号为X,则表示前X-1个数据段都收到了,只有当ACK=1时,确认号才有效,当ACK=0时,确认号无效,这时会要求重传数据,保证数据的完整性.SYN 同步序列号,TCP建立连接时将这个位置1FIN 发送端完成发送任务位,当TCP完成数据传输需要断开时,提出断开连接的一方将这位置1解释原因:TCP建立连接要进行3次握手,而断开连接要进行4次,这是由于TCP的半关闭造成的,因为TCP连接是全双工的(即数据可在两个方向上同时传递)所以进行关闭时每个方向上都要单独进行关闭,这个单方向的关闭就叫半关闭.关闭的方法是一方完成它的数据传输后,就发送一个FIN来向另一方通告将要终止这个方向的连接.当一端收到一个FIN,它必须通知应用层TCP连接已终止了这个方向的数据传送,发送FIN通常是应用层进行关闭的结果.另一种解释:这是因为服务端的LISTEN状态下的SOCKET当收到SYN报文的建连请求后,它可以把ACK和SYN(ACK起应答作用,而SYN起同步作用)放在一个报文里来发送。但关闭连接时,当收到对方的FIN报文通知时,它仅仅表示对方没有数据发送给你了;但未必你所有的数据都全部发送给对方了,所以你可以未必会马上会关闭SOCKET,也即你可能还需要发送一些数据给对方之后,再发送FIN报文给对方来表示你同意现在可以关闭连接了,所以它这里的ACK报文和FIN报文多数情况下都是分开发送的。为什么不能两次握手能进行连接?我们知道,3次握手完成两个重要的功能,既要双方做好发送数据的准备工作(双方都知道彼此已准备好),也要允许双方就初始序列号进行协商,这个序列号在握手过程中被发送和确认。 现在把三次握手改成仅需要两次握手,死锁是可能发生的。作为例子,考虑计算机S和C之间的通信,假定C给S发送一个连接请求分组,S收到了这个分组,并发送了确认应答分组。按照两次握手的协定,S认为连接已经成功地建立了,可以开始发送数据分组。可是,C在S的应答分组在传输中被丢失的情况下,将不知道S是否已准备好,不知道S建立什么样的序列号,C甚至怀疑S是否收到自己的连接请求分组。在这种情况下,C认为连接还未建立成功,将忽略S发来的任何数据分组,只等待连接确认应答分组。而S在发出的分组超时后,重复发送同样的分组。这样就形成了死锁。
TCP需要三次握手才能建立连接,那么为什么需要三次握手呢?

1.HTTP协议为什么要三次握手,而不是2次/4次握手?
三次握手是为了实现正常确认连接成功的最简单的步骤模型。 2次太少,无法获取到对方的状态。 4次的交互有点效率低,在第二次发起交互的时候,被连接端就可以把自己的确认状态发送过去,效率较高。
答: 第一次握手:建立连接时

为什么是三次握手而不是两次握手,为什么是四次挥手
问题一:可以这么理解,SERVER的超时时间是可以调整的。 问题二:主要是为了多重复几次FIN,其实一般的用户程序做不了什么了。

详解三次握手和四次挥手:遇到心动的女孩时,如何去把握?
我有一个朋友,小泷,他与我倾诉:他在咖啡厅与朋友闲谈,遇到了一个让时间彷佛静止的女孩。他描述,那一刻,他的心彻底被抓住了,脑中轰然,眼睛无法再从她身上移开。 而女孩,也时不时向她望来,那是一双如秋水般清澈的明眸。小泷说,他非常非常想想把握,这一次心动。然而,自始自终,他没能迈出那一步,他不知道该怎么办。小泷的困境,是每个男孩的困境。我告诉他,如果你懂得TCP协议,就会把握一段感情了。TCP(Transmission control protocal),传输控制协议,既是机器与机器间传输信息的基础协议,也是人与人联立联系的准则。如何体面地认识她? 如果读懂她是否对你有好感? 如何给予她安全感? 如何离别时要到她的手机号? TCP协议,把一切写得清清楚楚。我对小泷说:一个女孩,不管她性格有多高冷,永远是欣然接受你的好感的。你要做的,也必须要做的,是:我告诉小泷,我也曾经在机场遇到过让我瞬间心动的女孩,我所做的,只是很自然走上去,告诉她:"你好像也坐这趟飞机? 航班号是KN5855没错吧"这对男孩是很简单的事情,因为你们出现的地点,就是共鸣。你关于这个地方,一定有一些具体信息可以分享。所以,小泷,你应走上去说:你也常来这家咖啡厅吧,他们家的焦糖玛奇朵非常棒。这样的谈话,对女孩是提供安全感的:你是一个拥有共同话题,并且会提供实质性价值的男士,而不是随随便便乱勾搭的人。 共鸣的力量是非常强大的,没有女孩会拒绝回应的,即使长相略显寒酸。说回TCP协议,它是这样规定的:(SYN是synchronization同步的简称,seq为sequcence序号的缩写。)这时,客户端的状态更改为SYN-SENT(synchronization_sent同步已发送)状态。也就是说,小泷,你耐心待着女孩回应就是了。这就是“第一次握手”。有了你提供的同步请求SYN=1和具体信息seq=x。女孩会根据这个信息做出响应。女孩这时的状态从LISTEN变为SYNC_RCVD(synchronization_recieved同步已收到)。我在机场遇到的女孩是这样回答我的:嗯嗯,我也坐这趟航班,不过没看到你。你是来深圳出差么?这样回答,是人之常情。你一定可以得到亲切友善的回应。TCP协议中是这样规定的:(ACK是acknowledgement确认的简称,小写的ack是确认编号)所以,女孩一定会认同你,并根据刚刚的信息点延展,而且会提供一个新的信息点。女孩对你不反感,但她也需要确认你是不是真对她有好感。假如我真的只是觉得航班数字很吉利呢?假如你小泷真是就喜欢喝焦糖玛奇朵呢? 她无法确认男生是不是想和她交流,所以一定提出新话题。 而且,抛出新话题才会让彼此显得不尴尬。女孩几乎一定会这样回应:所以小泷,你心动女孩几乎一定会类似的回应:嗯嗯,我喜欢榛仁玛奇朵。我住这附近,你呢?你收到这样友好的回应,心中一定,知道,以后至少可以建立起初步的友谊了。 这时,你的状态更改为ESTABLISHED。(建立连接)虽然对于你,这段男女间青涩的友谊已经建立起了。但女孩,她还在等待你的回应 —— 她也在担忧你只是随意的询问吧。快赶紧安抚这一个善良美好的女孩吧!比如我会回答:嗯是的,有几个客户在深圳需要谈。我坐的商务舱所以没看到你吧。所以,小泷,你需要对她的新话题有所回应,并且不要丢掉自己的话题。这样两个话题都可以聊下去。在TCP协议中这样规定:这对女孩是非常重要的,你对她的话也表示认同,并且也能接住她的话题,同时自己的话题也没有丢掉。——是个能照顾她感受,也坚持自我的人。这时,女孩的状态成为了ESTABLISHED。你们双方都成为了ESTABLISHED,接下来,你们就可以畅通无阻地交流了。男孩会想,我怎么表现得靠谱? TCP给出了答案,共鸣 + 具体话题。女孩心中会想: 他对我感兴趣吗?他是聊得来的人吗? 如何进行“废物测试”?TCP给出了答案:共鸣 + 同意 + 对方话题的延展 + 新具体话题。男孩心中会想,怎么给她留下有主见高情商的好印象?TCP给出了答案: 同意 + 对方话题的延展 + 继续自己话题。仔细想想,这样的方式,让双方既不显尴尬,又体面舒适,又节约了两个人的时间与精力。时间总是短暂的,你们相谈甚欢,到了离别的时候。只有一个体面的离别,才意味着未来依然可以关系持续升温。放心,TCP协议已经为你规划好了。作为主动方的男生,需要首先表示分别,千万不要拖泥带水等到女生提出,这样才能为这段邂逅留下回味与不舍。你需要这时候,是要手机号/微信号的最佳时机。TCP协议是这样规定的:(FIN的意思是finis终结的意思)你已经请求结束了,安静地等待就好。 主动而沉默,给予女生足够的空间,这是最体面的分别方式。这时你的状态是FIN-WAIT-1(终止待待1)热情的聊天突然嘎然而止。女生心中会有些小失落,这时你要微信的请求,她几乎一定会同意。这时女生会找纸张,把自己的手机号或微信号写给你。并跟你说一些其它话。比如她说:嗯是的,等我写给你。你看外面好像快下雨了。TCP协议是这样规定的:因为是你提出离开,女孩还意犹未尽。一方面会同意离开,一方面会延展你的话题。为了确认你确实想离开了,她一般会说一个新话题,比如下雨了。女孩从接到你的离开请求,到回应你这一句的时候,她处于CLOSE_WAIT状态,她会开始进行心理建设,适应你离开时的空洞感。当然,成年人的表达方式,总是隐晦而体面的。只是一句淡淡的“天快下雨了”。而你听到她说这些,只是静静不说话。你进入FIN-WAIT-2状态。你在等着她的手机号,说话可能她突然不写了呢?忍住,别回应。当女孩低头写好手机号,她也做好了离开的心理建设,知道这一次邂逅到此为止了。这时,她说:快回去吧,我写给你啦。 不知道为什么和你呆一起挺愉快的。看,TCP协议影响着你们的一个个行为模式。你不回应,她会换个话题,她会开始猜,她会开始等,她会开始留恋。TCP协议是这样规定的:说出这句话的女孩,进入了LAST_ACK(最终动作)状态——主动权在你,她等着你。你听到女孩再次说话,你会不舍,你等着些什么。你进入TIME_WAIT阶段。知道她要离开了,你的心会突然一痛。但离开已成必然,体面地对她说最后的话吧!TCP协议是这样规定的:听到你说完这句话,女孩把车门关上,车缓缓启动了。女孩进入状态CLOSED(关闭连接)。提出离别的你,却久久站在原地。等了2MSL(两次交谈响应时间那么长),你好希望车突然停下,女孩从车上下来。但一切没有发生。美好的邂逅结束了。你进入CLOSED状态。小泷,你知道吗?懂得TCP协议,也就懂得了如何去抓住属于撩拨你心弦的那个女孩。也许,这才是邂逅时应该的画面:离别时,你们会这样不舍离别:然后,她离开了。你凝望着她,一再回头,直到消失在视线外。每天,有万亿亿次TCP连接,都在为你重演着这一个画面。勇敢一点,不用担心被拒绝,万亿亿次TCP连接都成功了,你怎么会失败呢?因为TCP是网络通讯的规则,也是人类间默契的交流规则。不动声色,内心早已暗流汹涌。却只是对你说。“好巧,我也是这趟航班”几条规则,有助于你记住这一切:

TCP 三次握手和四次挥手指的什么?
为什么要三次握手 三次握手的目的是建立可靠的通信信道,说到通讯,简单来说就是数据的发送与接收,而三次握手最主要的目的就是双方确认自己与对方的发送与接收是正常的。第一次握手:Client 什么都不能确认;Server 确认了对方发送正常,自己接收正常第二次握手:Client 确认了:自己发送、接收正常,对方发送、接收正常;Server 确认了:对方发送正常,自己接收正常第三次握手:Client 确认了:自己发送、接收正常,对方发送、接收正常;Server 确认了:自己发送、接收正常,对方发送、接收正常所以三次握手就能确认双发收发功能都正常,缺一不可。 第四次握手:任何一方都可以在数据传送结束后发出连接释放的通知,待对方确认后进入半关闭状态。当另一方也没有数据再发送的时候,则发出连接释放通知,对方确认后就完全关闭了TCP连接。
只知道三次握手,A向B发送信息,B会向A返回一个收到确认的消息,A还会对这个确认消息发送一次再确认,所以一个消息要经过三次的消息交互才算发送完成,这就是三次握手

本文由 在线网速测试 整理编辑,转载请注明出处,原文链接:https://www.wangsu123.cn/news/46730.html。