`

转:tcp 建立连接和断开连接及中间状态

阅读更多

1、建立连接协议(三次握手)
(1)客户端发送一个带SYN标志的TCP报文到服务器。这是三次握手过程中的报文1。
(2) 服务器端回应客户端的,这是三次握手中的第2个报文,这个报文同时带ACK标志和SYN标志。因此它表示对刚才客户端SYN报文的回应;同时又标志SYN给客户端,询问客户端是否准备好进行数据通讯。
(3) 客户必须再次回应服务段一个ACK报文,这是报文段3。
2、连接终止协议(四次挥手)
   由于TCP连接是全双工的,因此每个方向都必须单独进行关闭。这原则是当一方完成它的数据发送任务后就能发送一个FIN来终止这个方向的连接。收到一个 FIN只意味着这一方向上没有数据流动,一个TCP连接在收到一个FIN后仍能发送数据。首先进行关闭的一方将执行主动关闭,而另一方执行被动关闭。
 (1) TCP客户端发送一个FIN,用来关闭客户到服务器的数据传送(报文段4)。
 (2) 服务器收到这个FIN,它发回一个ACK,确认序号为收到的序号加1(报文段5)。和SYN一样,一个FIN将占用一个序号。
 (3) 服务器关闭客户端的连接,发送一个FIN给客户端(报文段6)。
 (4) 客户段发回ACK报文确认,并将确认序号设置为收到序号加1(报文段7)。
CLOSED: 表示初始状态。
LISTEN: 这个也是非常容易理解的一个状态,表示服务器端的某个SOCKET处于监听状态,可以接受连接了。
SYN_RCVD: 这个状态表示接受到了SYN报文,在正常情况下,这个状态是服务器端的SOCKET在建立TCP连接时的三次握手会话过程中的一个中间状态,很短暂,基本上用netstat你是很难看到这种状态的,除非你特意写了一个客户端测试程序,故意将三次TCP握手过程中最后一个ACK报文不予发送。因此这种状态时,当收到客户端的ACK报文后,它会进入到ESTABLISHED状态。
SYN_SENT: 这个状态与SYN_RCVD遥想呼应,当客户端SOCKET执行CONNECT连接时,它首先发送SYN报文,因此也随即它会进入到了SYN_SENT状态,并等待服务端的发送三次握手中的第2个报文。SYN_SENT状态表示客户端已发送SYN报文。
ESTABLISHED: 这个容易理解了,表示连接已经建立了。
FIN_WAIT_1: 这个状态要好好解释一下,其实FIN_WAIT_1和FIN_WAIT_2状态的真正含义都是表示等待对方的FIN报文。而这两种状态的区别是:FIN_WAIT_1状态实际上是当SOCKET在ESTABLISHED状态时,它想主动关闭连接,向对方发送了FIN报文,此时该SOCKET即进入到FIN_WAIT_1状态。而当对方回应ACK报文后,则进入到FIN_WAIT_2状态,当然在实际的正常情况下,无论对方何种情况下,都应该马上回应ACK报文,所以FIN_WAIT_1状态一般是比较难见到的,而FIN_WAIT_2状态还有时常常可以用netstat看到。
FIN_WAIT_2: 上面已经详细解释了这种状态,实际上FIN_WAIT_2状态下的SOCKET,表示半连接,也即有一方要求close连接,但另外还告诉对方,我暂时还有点数据需要传送给你,稍后再关闭连接。
TIME_WAIT: 表示收到了对方的FIN报文,并发送出了ACK报文,就等2MSL后即可回到CLOSED可用状态了。如果FIN_WAIT_1状态下,收到了对方同时带FIN标志和ACK标志的报文时,可以直接进入到TIME_WAIT状态,而无须经过FIN_WAIT_2状态。
CLOSING: 这种状态比较特殊,实际情况中应该是很少见,属于一种比较罕见的例外状态。正常情况下,当你发送FIN报文后,按理来说是应该先收到(或同时收到)对方的ACK报文,再收到对方的FIN报文。但是CLOSING状态表示你发送FIN报文后,并没有收到对方的ACK报文,反而却也收到了对方的FIN报文。什么情况下会出现此种情况呢?其实细想一下,也不难得出结论:那就是如果双方几乎在同时close一个SOCKET的话,那么就出现了双方同时发送FIN报文的情况,也即会出现CLOSING状态,表示双方都正在关闭SOCKET连接。
CLOSE_WAIT: 这种状态的含义其实是表示在等待关闭。怎么理解呢?当对方close一个SOCKET后发送FIN报文给自己,你系统毫无疑问地会回应一个ACK报文给对方,此时则进入到CLOSE_WAIT状态。接下来呢,实际上你真正需要考虑的事情是察看你是否还有数据发送给对方,如果没有的话,那么你也就可以close这个SOCKET,发送FIN报文给对方,也即关闭连接。所以你在CLOSE_WAIT状态下,需要完成的事情是等待你去关闭连接。
LAST_ACK: 这个状态还是比较容易好理解的,它是被动关闭一方在发送FIN报文后,最后等待对方的ACK报文。当收到ACK报文后,也即可以进入到CLOSED可用状态了。
最后有2个问题的回答,我自己分析后的结论(不一定保证100%正确)
1、 为什么建立连接协议是三次握手,而关闭连接却是四次握手呢?
这是因为服务端的LISTEN状态下的SOCKET当收到SYN报文的建连请求后,它可以把ACK和SYN(ACK起应答作用,而SYN起同步作用)放在一个报文里来发送。但关闭连接时,当收到对方的FIN报文通知时,它仅仅表示对方没有数据发送给你了;但未必你所有的数据都全部发送给对方了,所以你可以未必会马上会关闭SOCKET,也即你可能还需要发送一些数据给对方之后,再发送FIN报文给对方来表示你同意现在可以关闭连接了,所以它这里的ACK报文和FIN报文多数情况下都是分开发送的。
2、 为什么TIME_WAIT状态还需要等2MSL后才能返回到CLOSED状态?
这是因为:虽然双方都同意关闭连接了,而且握手的4个报文也都协调和发送完毕,按理可以直接回到CLOSED状态(就好比从SYN_SEND状态到ESTABLISH状态那样);但是因为我们必须要假想网络是不可靠的,你无法保证你最后发送的ACK报文会一定被对方收到,因此对方处于LAST_ACK状态下的SOCKET可能会因为超时未收到ACK报文,而重发FIN报文,所以这个TIME_WAIT状态的作用就是用来重发可能丢失的ACK报文

分享到:
评论

相关推荐

    8.2.3 TCP的连接管理1

    7. **控制位(Flags)**:TCP报文段头部有多个控制位,如SYN、ACK、FIN、URG、PSH、RST、ECN、CWR,用于控制连接状态和数据传输特性。例如,RST用于快速断开连接,URG标记紧急指针等。 8. **连接管理中的安全性**:...

    TCP/IPsocket长连接

    TCP建立连接需要经过三次握手过程,确保双方都有能力并愿意进行通信。连接建立后,数据可以双向流动。在长连接中,一旦连接建立,就会保持开放状态,直到一方主动关闭连接或因网络问题导致连接断开。这种机制对于...

    TCP.rar_TCP 调试_tcp调试_tcp调试工具_visual c_调试工具

    3. **TCP断开连接**:四次挥手(FIN-FIN/ACK-ACK)用于终止TCP连接。若出现异常断连,可能是FIN或FIN/ACK包未正确传递,需要检查网络状况和程序逻辑。 4. **TCP疑难问题**:常见的TCP问题有TCP慢启动、TIME_WAIT...

    Android Tcp通信demo

    3. 断开连接:当通信结束后,双方会进行四次挥手来释放连接,即FIN(结束)和ACK交互。 在Android客户端的实现中,我们可以使用java.net.Socket类来创建TCP连接,如下: ```java Socket socket = new Socket(...

    基于TCP协议的聊天工具4

    TCP通过三次握手建立连接,四次挥手断开连接,保证了连接的稳定性和数据的准确性。 【TCP聊天工具设计】 1. **连接建立**:在聊天工具中,用户A首先需要与服务器进行TCP连接。这涉及到A向服务器发送一个SYN(同步...

    TcpTrace工具

    TcpTrace通过捕获这些TCP数据包,可以展示网络中发生的所有交互,包括连接建立、数据传输、断开连接等过程。这对于调试应用程序的网络行为,查找网络故障,或者分析网络安全问题都非常有帮助。 TcpTrace的主要特性...

    安卓版TCP/IP

    - TCP通过三次握手建立连接。客户端首先发送SYN报文请求连接,服务器回应SYN+ACK,最后客户端再发送一个ACK确认连接建立。 - 当通信结束时,双方会通过四次挥手来终止连接,即FIN-ACK-FIN-ACK流程。 2. **Socket...

    EC20建立一路SOCKT发数据_TCP透传.zip

    这个过程中,STM32F407需要处理TCP连接的状态,如连接建立、数据传输、断开连接等。 5. **异常处理与错误恢复**:在数据传输过程中,可能出现网络中断、超时等问题,此时STM32F407需要有相应的错误处理机制,如重试...

    tcp详解123

    - **三次握手(Three-Way Handshake)**:TCP连接的建立需要经过三次交互,即SYN(Synchronize Sequence Numbers)、SYN+ACK(Acknowledgment)和ACK。这个过程确保了双方都有能力发送和接收数据。 - **四次挥手(Four...

    C#TCP协议的同步通信(聊天项目)

    创建TcpClient实例后,调用Connect方法与指定的IP地址和端口号建立连接。然后,通过GetStream方法获取一个NetworkStream对象,该对象可以读写数据。 2. **TcpListener类**:TcpListener则用于创建服务器端,监听...

    高仿TCP,IP长连接小程序源码.zip

    在TCP/IP长连接中,两个设备在通信前会先建立连接,然后在连接保持期间可以进行多次数据交换,直到双方都同意断开连接。长连接的特点在于减少了每次通信时的握手和挥手过程,提高了通信效率,尤其适用于需要频繁交互...

    安卓TCP源码

    TCP通过三次握手建立连接,通过四次挥手断开连接,并采用滑动窗口机制来控制流量和确认接收。在Android中,TCP通信通常基于Java的Socket API,提供`java.net.Socket`和`java.net.ServerSocket`类来创建客户端和...

    基于Verilog语言的TCP代理程序

    在Verilog实现的TCP代理中,需要理解并实现TCP的握手过程(SYN/SYN+ACK/ACK)、数据传输、以及断开连接的四次挥手过程,同时还需要处理TCP首部中的序列号、确认号、窗口大小等关键字段。 **实现细节** 1. **连接...

    TCP通信存入数据库

    TCP通信是客户端和服务器之间建立连接并交换数据的基础,是互联网上众多应用如HTTP、FTP等协议的基础。在这个场景中,我们需要实现一个系统,它能通过TCP连接进行数据交换,并且利用心跳包来维持连接状态,同时将...

    TCP通信框架

    TCP(Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层通信协议,它确保了数据在传输过程中的完整性,通过三次握手建立连接,四次挥手断开连接,提供拥塞控制和流量控制机制。...

    tcp.rar_6tcp27.com_tcp_tcp 969.com_wince6 vs2005_wince6.0 tcp

    TCP是面向连接的、可靠的传输层协议,它通过三次握手建立连接,四次挥手断开连接,确保数据的有序和无损传输。TCP提供全双工通信,并且具备流量控制、拥塞控制机制,可以适应网络的不同状况。 2. **Windows CE 6.0...

    VCServerClient(TCP转发服务例程).rar

    TCP提供了一种可靠的数据传输服务,通过三次握手建立连接,四次挥手断开连接,确保数据的有序和无损传输。在TCP中,每个连接都有一个唯一的标识——socket(套接字),由源IP地址、源端口号、目标IP地址和目标端口号...

    TCPTrace HTTP

    TCP提供连接导向的服务,通过三次握手建立连接,并通过确认、重传和流量控制等机制保证数据准确无误地送达目的地。在HTTP(HyperText Transfer Protocol)协议中,TCP是其基础,承载HTTP请求和响应的数据流。 TCP...

    Based-on-the-TCP-client-and-server.rar_TCP中转_The Client_java Tcp

    1. 面向连接:在数据传输前,TCP需要先建立连接,即三次握手过程。 2. 可靠性:通过序列号、确认应答、重传机制等确保数据包按序、无丢失、无重复地到达目的地。 3. 流量控制:通过滑动窗口机制控制发送速率,避免...

    tcp.zip_TCP聊天_c语言 tcp_c语言聊天

    - TCP通过三次握手建立连接,四次挥手断开连接,确保连接的可靠性和数据的完整性。 - TCP使用滑动窗口机制来控制流量和确认数据包的接收,从而实现流量控制和拥塞控制。 2. **C语言编程基础**: - C语言是一种...

Global site tag (gtag.js) - Google Analytics