乐趣区

快速理解TCPIP三次握手与四次挥手

TCP/IP 三次握手

TCP 建立连接为什么是三次握手,而不是两次或四次?
TCP,名为传输控制协议,是一种可靠的传输层协议,IP 协议号为 6。
顺便说一句,原则上任何数据传输都无法确保绝对可靠,三次握手只是确保可靠的基本需要。

对应为客户端与服务器之间的通信:

于是有了以下对话:
我:1+ 1 等于几?
她:2,2+ 2 等于几?
我:4

首先两个人约定协议
1. 感觉网络情况不对的时候,任何一方都可以发起询问
2. 任何情况下,若发起询问后 5 秒还没收到回复,则认为网络不通
3. 网络不通的情况下等 1min 路由器之后再发起询问

对于我而言,发起“1+ 1 等于几”的询问后

  1. 若 5s 内没有收到回复,则认为网络不通
  2. 若收到回复,则我确认①我能听到她的消息 ②她能听到我的消息,然后回复她的问题的答案

对于她而言,当感觉网络情况不对的时候

  1. 若没有收到我的询问,则她发起询问
  2. 若收到“1+ 1 等于几”,则她确认 ①她可以听到我的消息,然后回复我的问题的答案和她的问题“2,2+ 2 等于几”
  3. 若 5s 内没有收到我的回复“4”,则她确认 ②我听不见她的消息
  4. 若 5s 内收到了我的回复“4”,则她确认 ②我可以听见她的消息

这样,如果上面的对话得以完成,就证明双方都可以确认自己可以听到对方的声音,对方也可以听到自己的声音!

这个解释足够简单了吧!接下来我们看四次挥手。

TCP/IP 四次挥手

三次握手耳熟能详,四次挥手估计就.. 所谓四次挥手(Four-Way Wavehand)即终止 TCP 连接,就是指断开一个 TCP 连接时,需要客户端和服务端总共发送 4 个包以确认连接的断开。在 socket 编程中,这一过程由客户端或服务端任一方执行 close 来触发,整个流程如下图所示:

服务端在 LISTEN 状态下,收到建立连接请求的 SYN 报文后,把 ACK 和 SYN 放在一个报文里发送给客户端。而关闭连接时,当收到对方的 FIN 报文时,仅仅表示对方不再发送数据了但是还能接收数据,己方也未必全部数据都发送给对方了,所以己方可以立即 close,也可以发送一些数据给对方后,再发送 FIN 报文给对方来表示同意现在关闭连接,因此,己方 ACK 和 FIN 一般都会分开发送。

简单点说,当被动方收到主动方的 FIN 报文通知时,它仅仅表示主动方没有数据再发送给被动方了。

但未必被动方所有的数据都完整的发送给了主动方,所以被动方不会马上关闭 SOCKET, 它可能还需要发送一些数据给主动方后,

再发送 FIN 报文给主动方,告诉主动方同意关闭连接,所以这里的 ACK 报文和 FIN 报文多数情况下都是分开发送的。

退出移动版