博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
TCP三次握手与四次挥手
阅读量:7224 次
发布时间:2019-06-29

本文共 2134 字,大约阅读时间需要 7 分钟。

hot3.png

经过整理教材、百度百科、他人博客,总结如下:

 

第一次握手:建立连接时,发送包(syn=j)到,并进入状态,等待服务器确认;SYN:同步序列编号(Synchronize Sequence Numbers)。

:收到包,必须确认客户的SYN(=j+1),同时自己也发送一个SYN包(syn=k),即SYN+ACK包,此时服务器进入状态;

第三次握手:收到器的SYN+ACK包,向发送确认包ACK(=k+1),此包发送完毕,客户端和服务器进入(TCP连接成功)状态,完成三次握手。

完成三次握手,与服务器开始传送,在上述过程中,还有一些重要的概念:

未连接队列

在中,维护一个未连接队列,该队列为每个的SYN包(=j)开设一个条目,该条目表明服务器已收到SYN包,并向客户发出确认,正在等待客户的确认包。这些条目所标识的连接在处于SYN_RECV状态,当服务器收到客户的确认包时,删除该条目,服务器进入ESTABLISHED状态。

 

关闭TCP连接:改进的三次握手

对于一个已经建立的连接,TCP使用改进的三次握手来释放连接(使用一个带有FIN附加标记的报文段)。TCP关闭连接的步骤如下:

第一步,当主机A的应用程序通知TCP数据已经发送完毕时,TCP向主机B发送一个带有FIN附加标记的报文段(FIN表示英文finish)。

第二步,主机B收到这个FIN报文段之后,并不立即用FIN报文段回复主机A,而是先向主机A发送一个确认序号ACK,同时通知自己相应的应用程序:对方要求关闭连接(先发送ACK的目的是为了防止在这段时间内,对方重传FIN报文段)。

第三步,主机B的应用程序告诉TCP:我要彻底的关闭连接,TCP向主机A送一个FIN报文段。

第四步,主机A收到这个FIN报文段后,向主机B发送一个ACK表示连接彻底释放。

为什么要采用三次握手,两次不行吗?

经过整理教材、百度百科、他人博客,总结如下:

 

第一次握手:建立连接时,发送包(syn=j)到,并进入状态,等待服务器确认;SYN:同步序列编号(Synchronize Sequence Numbers)。

:收到包,必须确认客户的SYN(=j+1),同时自己也发送一个SYN包(syn=k),即SYN+ACK包,此时服务器进入状态;

第三次握手:收到器的SYN+ACK包,向发送确认包ACK(=k+1),此包发送完毕,客户端和服务器进入(TCP连接成功)状态,完成三次握手。

完成三次握手,与服务器开始传送,在上述过程中,还有一些重要的概念:

未连接队列

在中,维护一个未连接队列,该队列为每个的SYN包(=j)开设一个条目,该条目表明服务器已收到SYN包,并向客户发出确认,正在等待客户的确认包。这些条目所标识的连接在处于SYN_RECV状态,当服务器收到客户的确认包时,删除该条目,服务器进入ESTABLISHED状态。

 

关闭TCP连接:改进的三次握手

对于一个已经建立的连接,TCP使用改进的三次握手来释放连接(使用一个带有FIN附加标记的报文段)。TCP关闭连接的步骤如下:

第一步,当主机A的应用程序通知TCP数据已经发送完毕时,TCP向主机B发送一个带有FIN附加标记的报文段(FIN表示英文finish)。

第二步,主机B收到这个FIN报文段之后,并不立即用FIN报文段回复主机A,而是先向主机A发送一个确认序号ACK,同时通知自己相应的应用程序:对方要求关闭连接(先发送ACK的目的是为了防止在这段时间内,对方重传FIN报文段)。

第三步,主机B的应用程序告诉TCP:我要彻底的关闭连接,TCP向主机A送一个FIN报文段。

第四步,主机A收到这个FIN报文段后,向主机B发送一个ACK表示连接彻底释放。

为什么要采用三次握手,两次不行吗?

 

 

 

 

 

保活计时器:

设想有这样的情况:客户端已主动与服务器建立了TCP连接,但后来客户端的主机突然出现故障。

通常设为2小时。若2小时没有收到客户端的数据,服务器就发送一个探测报文段,以后则每隔75分钟发送一次。若一连发送10个探测报文段后仍无客户端的响应,服务器就认为客户端出现了故障,接着就关闭这个连接。

 

 

 

 

为什么连接的时候是三次握手,关闭的时候却是四次握手?

答:因为当Server端收到Client端的SYN连接请求报文后,可以直接发送SYN+ACK报文。其中ACK报文是用来应答的,SYN报文是用来同步的。但是关闭连接时,当Server端收到FIN报文时,很可能并不会立即关闭SOCKET,所以只能先回复一个ACK报文,告诉Client端,"你发的FIN报文我收到了"。只有等到我Server端所有的报文都发送完了,我才能发送FIN报文,因此不能一起发送。故需要四步握手。

为什么TIME_WAIT状态需要经过2MSL(最大报文段生存时间)才能返回到CLOSE状态?

答:虽然按道理,四个报文都发送完毕,我们可以直接进入CLOSE状态了,但是我们必须假象网络是不可靠的,有可以最后一个ACK丢失。所以TIME_WAIT状态就是用来重发可能丢失的ACK报文。

转载于:https://my.oschina.net/huyuBlog/blog/1816003

你可能感兴趣的文章
Android4.0(Phone)来电过程分析
查看>>
Postgresql中的数据类型大全
查看>>
Java 动态太极图 DynamicTaiChi (整理)
查看>>
在WIN7系统的笔记本上建立WIFI热点
查看>>
Struts2的Convention插件
查看>>
2016第2周日
查看>>
Centos 6.5 Oracle11g 安装
查看>>
linux中断申请之request_threaded_irq 【转】
查看>>
3、使用Lucene实现千度搜索
查看>>
单链表逆序的几种方法
查看>>
Hardwood Species
查看>>
android 项目中log信息的正确处理
查看>>
C# 定时器运用
查看>>
【转载】NIO客户端序列图
查看>>
Maven单元测试报告及测试覆盖率
查看>>
做开发的目的是为了什么
查看>>
怎样为virtualbox添加新的分辨率
查看>>
HDU 1853Cyclic Tour(网络流之最小费用流)
查看>>
网络通信分享(二):外网ip和内网ip
查看>>
phpstudy2016最新版本mysql无法使用innodb的问题解决
查看>>