在上一篇我们了解的TCP的报文格式和TCP连接管理机制:TCP初认识

今天来理解什么是三次握手,什么是四次挥手

图1 TCP连接管理

什么是三次握手

在网络数据传输中,传输层协议TCP(传输控制协议)是建立连接的可靠传输,TCP建立连接的过程,我们称为三次握手。
第一次,客户端向服务器发送SYN同步报文段,请求建立连接
第二次,服务器确认收到客户端的连接请求,并向客户端发送SYN同步报文,表示要向客户端建立连接
第三次,客户端收到服务器端的确认请求后,处于建立连接状态,向服务器发送确认报文
客户端是在收到确认请求后,先建立连接
服务器是在收到最后客户端的确认后,建立连接
发起连接请求的一定是客户端

为什么建立连接时要进行三次握手?

我们可以分析一次握手肯定是不行的,这样服务器都不一定能收到连接请求

那么如果是两次握手呢?

如果是两次握手,连接过程应该是这样的,当服务器收到对端的连接请求时,就认为连接建立好了,进入ESTABLISHED状态。客户端在收到服务器发来的同步确认报文后,就认为连接建立好了,进入ESTABLISHED,在报文都能正常收到的情况下,两次握手是可以安全建立连接的。
但是存在这样的情况,假设第二次握手的报文丢失了,当前的状态是,服务器认为连接已经建立好了,可是客户端没有收到同步确认报文,认为连接还没有建立好,此时,服务器端的连接其实是无效连接,客户端因为没有收到确认,便会向服务器重传同步报文,同样,在服务器收到客户端的同步报文时,认为连接已经建立好了,同样糟糕的事情发生了,服务器给客户端发送的同步确认报文丢失了,或者是说有人恶意向服务器不断发送SYN同步报文(SYN洪水)。那么服务器端就会有大量的无效连接,服务器处理连接的数量是有限的,当有大量的无效连接建立后,服务器处理有效连接是能力就会受限,且建立连接会消耗大量是资源,至此有可能导致服务器崩溃。
这样看来两次握手是不可行的。

三次握手为什么是可行的呢?

在上面的两次握手的方案中,我们看到建立连接过程中,是服务器先处于连接建立好的状态,出现差错时,客户端没有连接建立成功,致使服务器可能有大量的无效连接,导致服务器安全问题。
那么在三次握手方案中,客户端收到服务器的同步确认报文后,就认为连接建立好了(先处于连接建立好的状态),而服务器是要收到客户端的确认报文后才认为连接建立好了。
那么也可能存在这样的问题,在最后一次握手时,服务器没有收到客户端的确认报文,此时的状态是,客户端处于建立连接状态,服务器处于没有建立连接状态,此时客户端负责维护这次连接

  1. 三次握手中,是谁先发起请求,谁来负责维护这次连接,那么会出现上面类似SYN洪水的问题吗?显然是不会的,自己发出SYN,最终无效连接还是建立在自己这方,客户端也不会这么无聊吧
  2. 而当客户端尝试向服务器发送数据时,服务器看到的是,还没有建立连接的数据,服务器会响应一个带有RST标志位的报文,告知客户端你需要先建立连接,此时当客户端收到这个报文时,就会重新发起建立连接的请求。

总结下来就是,三次握手中,即使建立连接失败,对服务器是没有影响的,保证服务器的安全,而对客户端而言,也不过是多次建立连接而已。并且在经过验证,三次握手的成功率也是非常高的。

四次握手可行吗?

很明显,三次握手已经可以满足我们的需求了,也就没必要多一次而浪费资源了。
在两次握手和三次握手的方案中,我们发现要保证客户端先建立连接的话,能保证连接的安全建立。若是偶数次握手,或者是说让服务器先建立连接,就是不安全不可行的方案。所以四次 握手是不可行的。

什么是四次挥手

在网络数据传输中,传输层协议断开连接的过程我们称为四次挥手
第一次,A端像B端发送FIN结束报文段,准备关闭连接
第二次,B端确认A端的FIN,表示自己已经收到对方关闭连接的请求
中间这段时间,A端停止向B端发送数据,但是B端可以向A端发送数据,要将自己未处理完任务处理完
第三次,B端向A端发送FIN结束报文段,准备关闭连接
第四次,A端确认B端的FIN,进入TIME_WAIT状态,此时A端进程已经退出,但是连接还在
当B端收到A端的ACK之后,先断开连接
当A端等待2 MSL之后,确认的B端接收到ACK后,再断开连接
发起断开连接请求的一端最后要进入有一个TIME_WAIT状态
发起连接请求的可以是客户端也可以是服务器端

为什么断开连接要四次?
不像建立连接的过程,服务器端在调用了accept()之后,剩下的都交给内核来处理,用户空间不用做什么,断开连接是,A端调用close()关闭文件描述符后,A端就停止发送数据了进行发送,B端收到后结束报文段之后,的得知A端要断开连接了,但是B端可能有自己还没有处理完的数据,不能立即断开连接,就要先给出回复,表示自己已经收到消息了,然后将自己的数据处理完之后,可以断开连接的时候,再调用close()发出断开连接请求,在收到A端的确认回复之后,断开连接,这样看来每一步都不能少,但是有时候若服务器端没有什么要处理的数据,就看可以直接调用close()捎带上响应报文,此时就是3次
为什么先发起断开连接请求的一端最后要等待 2MSL?
MSL为一段报文从一段到一段的最大时间,也称为报文的最大生存时间,我们假设在上面的四次挥手过程中最后A端在收到B端的FIN之后,就关闭连接,最后B端在收到A端的确认报文之后也断开连接,这种情况是我们预期的
试想是否存在这样的情况,在A端已经关闭连接后,但是发给B端的ACK报文中途丢失,此时B端就会重发FIN结束报文段,但是A端已经关闭与这台服务器的连接,并且已经开始了一段新的连接,那么A端收到这个过期的FIN,误认为是关闭当前连接,给出错误处理。
也就是说A端等待 2MSL就 可以保证在B端没有收到A 到ACK时,B端重发的FIN,A端来的及处理,然后重新确认等待2 MSL,保证了最后的ACK 报文 B端成功收到。

什么是三次握手、什么是四次握手相关推荐

  1. 用wireshark抓包分析TCP协议的三次握手连接、四次握手断开

    用wireshark抓包分析TCP协议的三次握手连接.四次握手断开 一.TCP三次握手图解 二.TCP得四次挥手过程 三.用Fiddler抓包,分析验证一个HTTPS网站的TCP连接过程 一.TCP三 ...

  2. 三次握手过程和四次握手过程

    第一次握手:建立连接时,客户端发送syn包(syn=j)到服务器,并进入SYN_SENT状态,等待服务器确认:SYN:同步序列编号(Synchronize Sequence Numbers). 第二次 ...

  3. 什么是三次握手和四次握手

    什么是三次握手和四次握手 1. 三次握手 1.1 什么是三次握手 (three-way handshake)? 1.2 TCP建立连接可以两次握手吗?为什么? 1.3 可以采用四次握手吗?为什么? 1 ...

  4. wifi四次握手过程

    https://www.jianshu.com/p/590d859d8d78 初始化: 第一次握手: 第二次握手: 第三次握手: 第四次握手: 其实整个原理就是密钥交换,请查看胡哥的<加密的类型 ...

  5. TCP四次握手释放连接

    一.四次握手的过程 TCP需要三次握手才能建立连接,整个过程如下图所示: 假设A运行的是TCP客户端进程,而B运行的是TCP服务端进程.最开始的时候两端的TCP进程都处于ESTABLISHED(已建立 ...

  6. TCP/IP协议三次握手与四次握手流程解析

    原文链接地址:http://www.2cto.com/net/201310/251896.html TCP/IP协议三次握手与四次握手流程解析 TCP/IP协议的详细信息参看<TCP/IP协议详 ...

  7. 为什么tcp不采用停等协议_为什么TCP建立连接协议是三次握手,而关闭连接却是四次握手呢?...

    看到了一道面试题:"为什么TCP建立连接协议是三次握手,而关闭连接却是四次握手呢?为什么不能用两次握手进行连接?",想想最近也到金三银四了,所以就查阅了相关资料,整理出来了这篇文章 ...

  8. TCP三次握手建立连接四次挥手断开连接

    仅用于做笔记,转载自https://blog.csdn.net/whuslei/article/details/6667471 首先Client端发送连接请求报文,Server段接受连接后回复ACK报 ...

  9. HTTP 三次握手  建立连接 和  四次握手断开连接

    三次握手建立连接  第一次握手:主机A发送位码为syn=1,随机产生seq number=1234567的数据包到服务器,主机B由SYN=1知道,A要求建立联机: 第二次握手:主机B收到请求后要确认联 ...

  10. TCP/IP详解--TCP/IP中三次握手 四次握手状态分析

    TCP(Transmission Control Protocol) 传输控制协议 TCP是主机对主机层的传输控制协议,提供可靠的连接服务,采用三次握手确认建立一个连接: 位码即tcp标志位,有6种标 ...

最新文章

  1. jsp cookie 中文乱码 的解决方法
  2. python学习干货教程(11):元组
  3. 项目实战-自动生成文档工具
  4. 微软技术专家为您解读深度学习
  5. HTML5中Audio使用踩坑汇总
  6. 英语音标原来这么丰富,换个角度把欧洲语言作为一个体系
  7. 【下载】快速通过Python笔试?学大家一样先把LeetCode答案私藏了
  8. 手动实现一门图灵完备的编程语言——Brainfuck
  9. 《心经》-翻译、中英梵对照
  10. # 写论文也要告别abandon模式
  11. PHP 两个多维数组根据某个键的值进行组合排序的几种思路
  12. dis的前缀单词有哪些_以ir dis为前缀的单词各20个,要多种词性
  13. npm install的报错 npm ERR! code ENOENTnpm ERR! syscall opennpm ERR! path D:\work\main/package.jsonnp
  14. SQL语句条件判断之case when基本用法
  15. 贯彻这三件事情,你将会迅速到达波澜不惊
  16. 计算机应用技术怎样为祖国做出贡献,计算机应用技术
  17. ubuntu Hyperf-skeleton初体验
  18. Android面试题线程篇
  19. 复盘案例:橱柜安装不合适,导致柜体、台面均重做
  20. 电脑超级使用的快捷键和小工具!高手都是很酷的~

热门文章

  1. 贝叶斯概率综述和课堂思路整理.2
  2. 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(一)
  3. WAP网站的推广方式(自整合篇)
  4. .NET 5.0 正式版发布了!
  5. 微信小程序 todolist
  6. JAVA第10课:标识符的定义及规则
  7. Python-OpenCV之操作像素进行反色(反相)处理
  8. python画玫瑰图_三步学会用python画一个简单的玫瑰图
  9. 交通行业舆情危机管理方案
  10. 为什么N型MOS管占据主导地位