TCP连接的状态转移

TCP是一个面向连接的传输层协议,因此不论哪一方需要传输数据,都需要在双方之间建立一条传输连接。

TCP连接的状态转移


用TCP的三次握手与四次挥手来解释TCP的各个状态之间的会比较清晰。

一、TCP的三次握手:

a)         单方主动发起连接:

TCP连接的状态转移

1、  服务器端应用层的应用程序创建了一个socket,使服务端被动打开,从CLOSED状态切换至LISTEN状态;

2、  此时客户端向服务端发送了一个SYN=1seq=i的数据段,主动打开,并将状态从CLOSED切换至SYN_SENT(此为TCP三次握手中的第一次握手);

3、  服务端收到客户端的发来的同步请求后,给客户端回应一个SYN=1ACK=1seq=jack=i+1的数据段,并将状态从LISTEN切换至SYN_RCVD,等待客户端的最后的ACK(此为TCP三次握手中的第二次握手);

4、  客户端收到服务端发来的ACKSYN请求后,回应服务端ACK=1seq=i+1ack=j+1数据段,并将状态从SYN_SENT转换至ESTABLISHED(此为TCP三次握手中的第三次握手);

5、  服务端收到客户端发来的ACK确认后,将状态从SYN_RCVD转换至ESTABLISHED.

 

b)         双方同时发起连接请求:
TCP连接的状态转移
此种状态并不存在一方为服务器,一方为客户端的情况,主机A与主机B既是客户端又是服务端。

1、  主机A与主机B同时向对方发起同步请求;并将状态从CLOSED转换到SYN_SENT
  A
SYN=1  seq=i —–>  B(在收到对方的SYN请求后,状态从SYN_SENT转换到SYN_RCVD
  B
SYN=1  seq=j —–>  A(在收到对方的SYN请求后,状态从SYN_SENT转换到SYN_RCVD

2、  主机A与主机B再同时确认对方的同步请求;
  A
SYN=1 ACK=1  seq=i+1  ack=j+1 —–>  B(在收到对方的ACK确认后,状态从SYN_RCVD转换到ESTABLISHED
  B
SYN=1 ACK=1  seq=j+1  ack=i+1 —–>  A(在收到对方的ACK确认后,状态从SYN_RCVD转换到ESTABLISHED
                                                           
注:注意同时发起请求时各状态转换的时间

二、TCP的四次挥手:

a)         单方主动发起断开请求:
TCP连接的状态转移

1、  假设由客户端主动发起断开请求,客户端向服务器端发送FIN=1seq=m的数据段,请求断开连接,并将状态从ESTABLISHED转换至FIN_WAIT 1 等待服务器确认;(此为四次挥手中的第一次挥手)

2、  服务器端接收到客户端发来的FIN请求后,会回应给客户端一个ACK=1
seq=n
ack=m+1的数据段,并将状态从ESTABLISHED转换至CLOSE_WAIT;此时如果服务器端还由未发送完成的数据,则会继续发送;(此为四次挥手中的第二次挥手)

3、  客户端收到来自服务器端发来的ACK数据段后,关闭客户端至服务器方向TCP连接,此时整个TCP连接处于半关闭状态(half-close);
客户端状态从FIN_WAIT 1切换至FIN_WAIT 2 ;等待服务器端发送FIN确认可以断开连接;注:此时客户端仍然可以接收来自服务器端发送的数据

4、  当服务器端数据传输完成,向客户端发送FIN=1 ACK=1 seq=w ack=m+1的数据段(此时服务器ack确认的数据段为客户端关闭TCP连接的最后一个数据段的序号),并将状态从CLOSE_WAIT转换至LAST_ACK,等待客户端的ACK确认(此为TCP四次挥手的第3次挥手)

5、  客户端收到来自服务器端发送的FIN数据段后,向服务器段发送ACK确认数据段,并将状态从FIN_WAIT 2转换至TIMED_WAIT;等待2MSL(最大报文段生存时间),如果没有收到来自服务器端的回应,关闭TCP连接,从TIMED_WAIT状态转换至CLOSED状态(此为TCP四次挥手的第四次挥手)

6、  服务器端在收到客户端发送的ACK后,将状态转换为LISTEN;如果在一定时间内收不到客户端的ACK,会重新向客户端发送FIN数据段

b)         双方同时发起FIN请求:
TCP连接的状态转移

1、  双方同时向对方发送FIN请求;并将状态从ESTABLISHED转换至FIN_WAIT 1

2、  双方都收到来自对方发送的FIN请求时,将状态从FIN_WAIT
1
转换至CLOSING;给对方发送ACK确认数据段后,又将状态从CLOSING转换至TIMED_WAIT;双方在等待2MSL时长后,没有收到来自对方的回应后,超时进入CLOSED状态

c)         如果在客户端向服务端发起SYN请求后,服务器段不愿意进行连接,此时服务器端会向客户端发送一个FIN请求,并将状态从SYN_RCVD切换到FIN_WAIT1;客户端收到FIN后,会回应服务器端一个ACK数据段,表示双方同时尝试关闭连接;并将状态从SYN_SENT切换至CLOSING;服务器端在收到客户端发来的ACK数据段后,切换状态至TIMED_WAIT;在超时后双方即关闭连接。

三、各个状态梳理:

CLOSED:初始状态;

LISTEN:应用层应用程序创建了一个socket

SYN_RCVD:收到SYN同步请求,回应对方发送ACKSYN
SYN_SENT
:发送了SYN同步请求;
ESTABLSHED
:收到了对方的ACK确认;

FIN_WAIT 1:发起了FIN终止连接的请求,还未得到对方确认;

CLOSE_WAIT:收到了对方的FIN请求,回应给对方ACK
FIN_WAIT 2
:发送FIN请求,收到了ACKA确认,但未收到对方的FIN请求;

LAST_ACK:向对方发送了FIN请求,还未得到确认;

TIMED_WAIT:收到对方的FIN请求,回应ACK,等待2MSL

CLOSING:在向对方发送FIN后,先接到对方的FIN,从FIN_WAIT 1转换至此状态,在向对方发送ACK后会进入TIME_WAIT状态; 

原创文章,作者:M22-Zero,如若转载,请注明出处:http://www.178linux.com/71378

(1)
M22-ZeroM22-Zero
上一篇 2017-03-19
下一篇 2017-03-19

相关推荐

  • 编译安装nginx并实现反向代理负载均衡和缓存功能

    一、编译安装nginx 1、下载 [root@ns1 ~]# wget http://nginx.org/download/nginx-1.10.0.tar.gz 2、解压 [root@ns1 ~]# tar xf nginx-1.10.0.tar.gz [root@ns1 ~]…

    Linux干货 2016-05-25
  • 软件包管理

    软件包的分类,主要有以下两大类    源码包    二进制包(rpm包,系统默认包) rpm包由Redhat公司提出,被众多linux发行版所采用。 优点:建立统一的数据库文件,详细记录软件包的安装、卸载等变化信息,能够自动的分析软件包依赖关系。 查询已安装的rpm软件信息: 格式:     rpm…

    Linux干货 2016-08-25
  • http特性

    一、何为http 什么是http?http是Hyper Text Mark Language的缩写,超文本标记语言。Apache下的httpd是实现了这一功能的开源软件。 二、http特性 http特性1:持久连接及MPM参数设置 KeepAlive {On|Off} #是否启动持久连接 MaxKeepAliveRequests 100 …

    Linux干货 2015-10-15
  • 一些鲜为人知的编程事实

    我的程序员经历让我明白了一些关于软件开发的事情。下面是一些在编程中可能会让人感到诧异的事情: 一个程序员用了大约只用了10%-20%的时间来编码,而且大多数程序员,无论他的水平如何,其平均每天只有10-12行的代码最终会进入最终的软件产品中。这是因为,优秀的程序员会花费90%的时间来思考、调查、研究最佳的设计。而糟糕的程序员则会花费90%的时间来调试代码,并…

    Linux干货 2016-07-11
  • Keepalived+LVS(nginx)高可用详解

    一:前言   Keepalived使用的vrrp协议方式,虚拟路由冗余协议 (Virtual Router Redundancy Protocol,简称VRRP);Keepalived的目的是模拟路由器的高可用,一般Keepalived是实现前端高可用,常用的前端高可用的组合有,就是我们常见的LVS+Keepalived、Nginx+Ke…

    Linux干货 2017-05-15
  • 马哥教育网络19期+第十五周课程练习

    1、总结sed和awk的详细用法;   a).sed命令 sed可以实现grep的大部分功能,而且还可以查找替换 [root@localhost ~]# sed '10'p -n 1.txt [root@localhost ~]# sed &#039…

    Linux干货 2016-08-22