【计算机网络】--tcp三次握手
文章目录
- 示意图:
- 抓包结果:
- 第一次握手(Client → Server)
- 第二次握手(Server → Client)
- 第三次握手(Client → Server)
- 为什么是三次握手 不是两次或者四次
示意图:
抓包结果:
第一次握手(Client → Server)
- 客户端发送一个带有 SYN 报文(SYN=1,Seq=x)给服务器。
- 表示:客户端想建立连接,该报文中有客户端的初始序列号(Sequence Number)。
- 客户端进入syn_send状态
第二次握手(Server → Client)
- 服务器收到 SYN 后,返回一个 SYN+ACK 的报文(SYN=1,ACK=1,Seq=y,Ack=x+1)。
- 表示:服务器同意连接请求,同时发送自己的初始序列号,并确认收到了客户端的 SYN。
- 服务端进入syn_received状态
第三次握手(Client → Server)
- 客户端收到 SYN+ACK 后,再发一个 ACK 报文(ACK=1,Seq=x+1,Ack=y+1)确认连接建立。
- 此时客户端进入 established 状态。
- 在服务端收到客户端的ACK报文后 也会变成establish状态
为什么是三次握手 不是两次或者四次
-
两次握手不够–确认双方的收报和发包的能力
第一次握手 说明客户端可以发送数据
第二次握手 说明 服务端可以接收和发送数据
第三次握手 可以说明客户端可以接受数据
假如只有两次握手 不能确保客户端能否接收数据,导致建立单方面的连接 -
防止旧的重复连接
三次握手可以防止历史连接请求(延迟的 SYN 报文)误建立连接;
若无第三次确认,Server 无法判断这个连接是不是“现在真正的请求”; -
保证连接可靠性
握手过程可以交换双方的初始序列号,为后续数据传输做好准备;
增强了 TCP 的安全性(抗序列号预测攻击)