Linux网络编程——浅谈 TCP 三次握手和四次挥手

一、tcp协议格式

二、三次握手

在 TCP/IP 协议中。TCP 协议提供可靠的连接服务,採用三次握手建立一个连接。

第一次握手:建立连接时,client发送 syn 包(tcp协议中syn位置1。序号为J)到server,并进入 SYN_SEND 状态。等待server确认;

第二次握手:server收到 syn 包,必须确认客户的 SYN,同一时候自己也发送一个 SYN 包,即 SYN+ACK包(tcp协议中syn位置1,ack位置1。序号K,确定序号为J+1),此时server进入 SYN_RECV
状态。

第三次握手:client收到server的 SYN+ACK 包,向server发送确认包 ACK(tcp协议中ack位置1。确认序号K+1)。此包发送完毕,client和server进入 ESTABLISHED 状态,完毕三次握手。

通过这种

url=eZXiFRQOKsO6NUMErlv_ourWMexrPfxtUhSw1f5waWf_gVDDeOpI7xFga2VygpC-qZWFVkj-XTcQeKx7UQO7fq" style="color:rgb(202,0,0); text-decoration:none">三次握手。client与服务端建立起可靠的双工的连接,開始传送数据。 三次握手的最主要目的是保证连接是双工的,可靠很多其它的是通过重传机制来保证的。可是为什么一定要进行三次握手来保证连接是双工的呢。一次不行么?两次不行么?

我们举一个现实生活中两个人进行语言沟通的样例来模拟

url=eZXiFRQOKsO6NUMErlv_ourWMexrPfxtUhSw1f5waWf_gVDDeOpI7xFga2VygpC-qZWFVkj-XTcQeKx7UQO7fq" style="color:rgb(202,0,0); text-decoration:none">三次握手

第一次对话: 

老婆让甲出去打酱油。半路碰到一个朋友乙。甲问了一句:哥们你吃饭了么?

结果乙带着耳机听歌呢。根本没听到,没反应。

甲心里想:跟你说话也没个音,不跟你说了,沟通失败。说明乙接受不到甲传过来的信息的情况下沟通肯定是失败的。

假设乙听到了甲说的话,那么第一次对话成功,接下来进行第二次对话。

第二次对话: 

乙听到了甲说的话,可是他是老外,中文不好。不知道甲说的啥意思也不知道如何回答。于是随便回答了一句学过的中文 :我去厕所了。甲一听立马笑喷了,“去厕所吃饭”?道不同不相为谋,离你远点吧。沟通失败。说明乙无法做出正确应答的情况下沟通失败。

假设乙听到了甲的话,做出了正确的应答,而且还进行了反问:我吃饭了,你呢?那么第二次握手成功。

通过前两次对话证明了乙可以听懂甲说的话,而且能做出正确的应答。

接下来进行第三次对话。

第三次对话:

甲刚和乙打了个招呼,突然老婆喊他。“你个死鬼,打个酱油咋这么半天,看我回家咋收拾你”,甲是个妻管严,听完吓得二话不说就跑回家了,把乙自己晾那了。

乙心想:这什么人啊,得,我也回家吧,沟通失败。说明甲无法做出应答的情况下沟通失败。

假设甲也做出了正确的应答:我也吃了。那么第三次对话成功,两人已经建立起了顺畅的沟通渠道,接下来開始持续的聊天。

通过第二次和第三次的对话证明了甲可以听懂乙说的话。而且能做出正确的应答。 可见。两个人进行有效的语言沟通。这三次对话的过程是必须的。

同理对于TCP为什么须要进行三次握手我们能够一样的理解:

为了保证服务端能收接受到client的信息并能做出正确的应答而进行前两次(第一次和第二次)握手,为了保证client可以接收到服务端的信息并能做出正确的应答而进行后两次(第二次和第三次)握手。

三、四次挥手

url=8_DsYi4pjWpNRFrSX10jiGxe0PLruypbRhv4o56eXOi07tQPokeFgnt1_leXVDy7ELc-uR4_E1cr1NfV3lJUYK" style="color:rgb(202,0,0); text-decoration:none">因为
TCP 连接是全双工的。因此每一个方向都必须单独进行关闭
。这好比,我们打电话(全双工),正常的情况下(出于礼貌),通话的两方都要说再见后才干挂电话,保证通信两方都把话说完了才挂电话

TCP
的四次握手
是为了保证通信两方都关闭了连接,详细步骤例如以下:

1)client A 在应用层调用close时会激发底层发送一个 FIN(tcp协议中FIN位置1、序号为M。结合上图分析)请求,用来关闭客户 A 到server B 的数据传送,clientA此时处于半关闭状态(应用层无法接收数据但底层还能够接收数据)。

2)server B
底层收到clientA的FIN时会做两件事

2.1)第1件事:收到clientA的FIN时底层会主动回发一个ACK(tcp协议中ACK位置1。确认序号M+1)

2.2)第2件事:收到clientA的FIN时。导致serverB的应用层read()返回0(告诉serverB应用层:clientA关闭了)

3)serverB应用层调用close()激发底层给client A 发送一个 FIN(tcp协议中FIN位置1、序号为N),这是serverB已处于半关闭状态;

4)client A
底层回发 ACK(tcp协议中ACK位置1,确认序号N+1) 给serverB,这是clientA、serverB都处于全然关闭状态。回收对应的资源。

为什么建立连接协议是三次握手。而关闭连接却是四次握手呢?

这是由于服务端的 LISTEN 状态下的 SOCKET 当收到 SYN 报文的建连请求后,它能够把 ACK 和 SYN(ACK 起应答作用。而 SYN 起同步作用)放在一个报文里来发送。

但关闭连接时,当收到FIN
报文通知时,假设能将ACK、FIN放在一个报文里那么就有了三次挥手。可是这是不可能。由于ACK是serverB一收到FIN报文底层就回发的,而serverB的FIN是应用层调用close()激发的。所以它这里的
ACK 报文和 FIN 报文在发送的时间上都是分开的,不可能同一时候发送。

为什么 TIME_WAIT 状态还须要等 2MS L后才干返回到 CLOSED 状态?

这是由于尽管两方都允许关闭连接了,并且握手的 4 个报文也都协调和发送完成,按理能够直接回到 CLOSED 状态(就好比从 SYN_SEND 状态到 ESTABLISH 状态那样)。可是由于我们必需要假想网络是不可靠的,你无法保证你最后发送的 ACK 报文会一定被对方收到。因此对方处于
LAST_ACK 状态下的 SOCKET 可能会由于超时未收到 ACK 报文。而重发 FIN 报文。所以这个 TIME_WAIT 状态的作用就是用来重发可能丢失的 ACK 报文。(里面涉及的状态是什么意思,详情请看《TCP
通信过程中各步骤的状态》

时间: 2024-07-29 01:18:55

Linux网络编程——浅谈 TCP 三次握手和四次挥手的相关文章

Linux网络编程一、tcp三次握手,四次挥手

一.TCP报文格式 (图片来源网络) SYN:请求建立连接标志位 ACK:应答标志位 FIN:断开连接标志位 二.三次握手,数据传输,四次挥手 (流程图,图片来源于网络) (tcp状态转换图,图片来源于网络) 1.客户端向处于监听状态(LISTEN)的服务端发送请求连接的报文.此时,报文中SYN标志位为1(表明其为请求建立连接的报文),同时还会随机生成一个32位的随机序号(图中1000),请求连接的报文可以可以携带数据(图中(0)表明没有携带数据).客户端变为SYN_SENT状态. 2.服务器接

[转帖]脑残式网络编程入门(一):跟着动画来学TCP三次握手和四次挥手

脑残式网络编程入门(一):跟着动画来学TCP三次握手和四次挥手 http://www.52im.net/thread-1729-1-1.html 1.引言 网络编程中TCP协议的三次握手和四次挥手的问题,在面试中是最为常见的知识点之一.很多读者都知道"三次"和"四次",但是如果问深入一点,他们往往都无法作出准确回答. 本篇文章尝试使用动画图片的方式,来对这个知识点进行"脑残式"讲解(哈哈),期望读者们可以更加简单.直观地理解TCP网络通信交互的本

浅谈浏览器解析 URL+DNS 域名解析+TCP 三次握手与四次挥手+浏览器渲染页面

(1)浏览器解析 URL 为了能让我们的知识层面看起来更有深度,我们应该考虑下面两个问题了: 从浏览器输入 URL 到渲染成功的过程中,究竟发生了什么? 浏览器渲染过程中,发生了什么,是不是也有重绘与回流? OK,兴致来了,我们就先从 浏览器解析 URL 看起,先来看看当用户输入 URL,到浏览器呈现给用户页面,经历了以下过程: 版本 A: 用户输入 URL 地址. 对 URL 地址进行 DNS 域名解析. 建立 TCP 连接(三次握手). 浏览器发起 HTTP 请求报文. 服务器返回 HTTP

应聘复习基础笔记1:网络编程之TCP与UDP的优缺点,TCP三次握手、四次挥手、传输窗口控制、存在问题

重要性:必考 一.TCP与UDP的优缺点 ①TCP---传输控制协议,提供的是面向连接.可靠的字节流服务.当客户和服务器彼此交换数据前,必须先在双方之间建立一个TCP连接,之后才能传输数据.TCP提供超时重发,丢弃重复数据,检验数据,流量控制等功能,保证数据能从一端传到另一端的可靠传输.对可靠性要求较高的应用层协议,如FTP.Telnet.SMTP.HTTP.POP3 ②UDP---用户数据报协议,是一个简单的面向数据报的运输层协议.UDP不提供可靠性,它只是把应用程序传给IP层的数据报发送出去

硬不硬你说了算!35 张图解被问千百遍的 TCP 三次握手和四次挥手面试题

每日一句英语学习,每天进步一点点: 前言 不管面试 Java .C/C++.Python 等开发岗位, TCP 的知识点可以说是的必问的了. 任 TCP 虐我千百遍,我仍待 TCP 如初恋. 遥想小林当年校招时常因 TCP 面试题被刷,真是又爱又狠…. 过去不会没关系,今天就让我们来消除这份恐惧,微笑着勇敢的面对它吧! 所以小林整理了关于 TCP 三次握手和四次挥手的面试题型,跟大家一起探讨探讨. TCP 基本认识 TCP 连接建立 TCP 连接断开 Socket 编程 PS:本次文章不涉及 T

硬不硬你说了算!近 40 张图解被问千百遍的 TCP 三次握手和四次挥手面试题

前言 不管面试 Java .C/C++.Python 等开发岗位,?TCP?的知识点可以说是的必问的了. 任 TCP 虐我千百遍,我仍待 TCP 如初恋. 不会没关系,今天就让我们来消除这份恐惧,微笑着勇敢的面对它吧! 于是我整理了关于?TCP 三次握手和四次挥手的面试题型,跟大家一起探讨探讨. TCP 基本认识 TCP 连接建立 TCP 连接断开 Socket 编程 PS:本次文章不涉及 TCP 流量控制.拥塞控制.可靠性传输等方面知识,这些留在下篇哈! 正文 01 TCP 基本认识 瞧瞧 T

TCP三次握手与四次挥手详解

TCP三次握手与四次挥手详解 @(TCP/IP) [TOC] 1.TCP报文格式 TCP(Transmission Control Protocol) 传输控制协议.TCP是主机对主机层的传输控制协议,提供可靠的连接服务,采用三次握手确认建立一个连接. 我们需要知道TCP在网络OSI的七层模型中的第四层(Transport层),IP在第三层(Network层),第二层(Data Link层),在第二层上的数据,我们叫Frame,在第三层上的数据叫Packet,第四层的数据叫Segment. TC

TCP三次握手、四次挥手出现意外情况时,为保证稳定,是如何处理的?

一. 序当我们聊到 TCP 协议的时候,聊的最多的就是三次握手与四次挥手.但是大部分资料和文章,写的都是正常的情况下的流程.但是你有没有想过,三次握手或者四次挥手时,如果发生异常了,是如何处理的?又是由谁来处理? TCP 作为一个靠谱的协议,在传输数据的前后,需要在双端之间建立连接,并在双端各自维护连接的状态.TCP 并没有什么特别之处,在面对多变的网络情况,也只能通过不断的重传和各种算法来保证可靠性. 建立连接前,TCP 会通过三次握手来保证双端状态正确,然后就可以正常传输数据了.当数据传输完

网络通信 --> TCP三次握手和四次挥手

TCP三次握手和四次挥手 建立TCP需要三次握手才能建立,而断开连接则需要四次握手.整个过程如下图所示: 一.TCP报文格式 如下图: (1)序号:Seq序号,占32位,用来标识从TCP源端向目的端发送的字节流,发起方发送数据时对此进行标记. (2)确认序号:Ack序号,占32位,只有ACK标志位为1时,确认序号字段才有效,Ack=Seq+1.(3)标志位:共6个,即URG.ACK.PSH.RST.SYN.FIN等,具体含义如下:               (A)URG:紧急指针(urgent