前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >TCP 三次握手和四次挥手是怎么回事

TCP 三次握手和四次挥手是怎么回事

作者头像
happyJared
发布2019-06-24 15:25:12
6830
发布2019-06-24 15:25:12
举报
文章被收录于专栏:happyJaredhappyJaredhappyJared

为保证数据的准确可靠,TCP 协议采用的是经典的三次握手策略。

如下图所示,下面的两个机器人通过3次握手,确定了对方能正确接收和发送消息(来源:《图解HTTP》)。

TCP三次握手

TCP三次握手

  • 第一次握手:客户端 -> 发送带有 SYN 标志的数据包 -> 服务端
  • 第二次握手:服务端 -> 发送带有 SYN/ACK 标志的数据包 -> 客户端
  • 第三次握手:客户端 -> 发送带有带有 ACK 标志的数据包 -> 服务端
为什么要三次握手

当然是为了建立可靠的通信信道。说到通讯,简单来说,就是数据的发送与接收,而三次握手最主要的目的,就是让双方都能确认自己与对方的发送和接收是正常的。

  • 第一次握手:Client 什么都不能确认;Server 确认了对方发送正常
  • 第二次握手:Client 确认了:自己发送、接收正常,对方发送、接收正常;Server 确认了:自己接收正常,对方发送正常
  • 第三次握手:Client 确认了:自己发送、接收正常,对方发送、接收正常;Server 确认了:自己发送、接收正常,对方发送、接收正常

因此,必须经过三次握手,才确认双发收发功能都正常,这缺一不可。

为什么要传回 SYN

接收端传回发送端所发送的 SYN,是为了告诉发送端,我接收到的信息确实就是你所发送的信号。

SYN 是 TCP/IP 建立连接时使用的握手信号。客户机和服务器之间建立正常的 TCP 网络连接时,客户机首先发出一个 SYN 消息,服务器使用 SYN-ACK 应答,表示接收到了这个消息,最后客户机再以 ACK 确认消息响应。

传了 SYN,为啥还要传 ACK

要保证双方通信无误,则必须是两者互相发送信息都无误。传了 SYN,证明发送方到接收方的通道没有问题,但是接收方到发送方的通道,还需要 ACK 信号来进行验证。

TCP 四次挥手

断开 TCP 连接,需要经过 “四次挥手”:

  • 第1次挥手: 客户端 -> 发送一个 FIN,用来关闭客户端到服务器的数据传送
  • 第2次挥手: 服务器 -> 收到这个 FIN,它发回一个 ACK,确认序号为收到的序号加1。和 SYN 一样,一个 FIN 将占用一个序号
  • 第3次挥手: 服务器 -> 关闭与客户端的连接,发送一个 FIN 给客户端
  • 第4次挥手: 客户端 -> 发回 ACK 报文确认,并将确认序号设置为收到序号加1
为什么要四次挥手

任何一方都可以在数据传送结束后发出连接释放的通知,待对方确认后,进入半关闭状态。当另一方也没有数据再发送的时候,则发出连接释放的通知,对方确认后,TCP 连接将完全关闭。

Take Example:A 和 B 打电话,通话即将结束后,A 说 “我没啥要说的了”,B 表示 “我知道了”,但是 B 可能还有要说的话,因此 A 不能要求 B 跟着自己的节奏来结束通话,于是 B 可能又巴拉巴拉说了一通,最后 B 说 “我说完了”,A 回答 “知道了”,这样通话才算真正结束。

这里讲的比较概括,推荐一篇讲的比较细致的文章:TCP的三次握手与四次挥手(详解+动图)

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019.06.23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 为什么要三次握手
  • 为什么要传回 SYN
  • 传了 SYN,为啥还要传 ACK
  • TCP 四次挥手
  • 为什么要四次挥手
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档