TCP 为什么做三次握手、四次挥手?

TCP 是为了解决可靠传输出现的。为了实现可靠性,TCP 做了流量控制、拥塞控制,并且在建立、关闭连接前做些机制:三次握手、四次挥手。

三次握手是为了让客户端、服务器在建立连接前能保证相互可以发送、接收报文;

四次挥手也一样,客户端、服务器保证相互都得知要关闭时再关闭连接。

如果建立、关闭连接前没有做出这种保障,而直接发送报文或率先关闭,会出现报文丢失等风险。

(注意这里的保证不是指百分百的)

那为什么是三次握手?而不是两次、四次?

假如客户端 A、服务器 B,这里用打电话来做比喻:

  1. A 说:喂喂,听得到吗?

  2. (B 听了之后,知道了自己能听到 A 讲的话。)

    B 回复说:可以。你能听得到吗?

  3. (A 听了之后,他就能知道 B 可以听到自己的讲的话,并且自己也能听到 B。

    但此时 B 还不知道 A 能不能听得到他自己说的话,所以 A 还要回复。)

    A 回复:嗯,听得到。

    这时 A、B 便可以知道相互都能说、听,接下来可以开始聊了(即建立连接开始发送数据)。

如果是两次握手

从上面例子就能看出,如果只做两次握手,假如当 A 手机没电被关机时,B 就可能不知道情况而一直讲话。

所以,建立连接前,如果想可靠传输,必须要先保证相互能正常接收报文。

如果是四次握手

四次五次或者更多都可以,但这样其实会有点多余了。所以做三次握手即可。

为什么是四次挥手?而不是一次、两次、三次?

与上面例子一样,客户端 A、服务器 B 在打电话:

  1. A 说:我困了,想睡觉。

  2. B 回复:OK,等我还有些事要跟你讲。

  3. B 讲完后,说:我说完了,你去睡吧,拜拜。

  4. A 回复:嗯,晚安。

    这时 A、B 就可以挂电话了。

    说完,A 等 2 秒后挂了电话,同时 B 听到回复后也挂了,即关闭了连接。

如果是一次、两次挥手

从上面例子可以看出,因为 B 可能还有话要讲,所以 A 不能说完就挂掉。

如果是三次挥手

B 说拜拜后直接关闭,他就不确定 A 有没有听到他之前(2到3)讲的话。并且假如 A 恰好没有听到 B 说拜拜,A 就可能一直拿着电话。

所以 B 还要等 A 的回复。

第四次挥手后,客户端为什么还要等 2MSL 的时间后再关闭连接?

(这里 MSL 是:Maximum Segment Lifetime,即报文最大生存时间。是任何报文在网络中存在的最长时间。超过这个时间将被丢弃。)

同上,如果 A 直接关掉,假如 B 没有收到第四次挥手,他就不知道 A 有没有听到自己讲过的话。

所以 B 超过一段时间没收到的话,会再次跟 A 说拜拜。而 A 等待的 2MSL 的时间内,可以接收到该重发的消息,这样 A 就可以再次向 B 回复。(A、B 都有超时机制,如果还是一直收不到会断开连接。)

此外,A 直接关闭的另一个风险就是:如果 A 的原进程端口恰好又被其他新进程占用,那么新进程就会被接收到来自 B 的消息。

其他文章

上面写的例子只是为了简单理解,举的例子其实是不严谨的。比如,由于可能接收到的报文是已经过期的,双方需要用唯一序列号来做下验证等。

TCP没那么难吧?

TCP没那么难吧【续】

认个错,TCP的“三次握手、四次挥手”,不能想当然

关于TCP/IP系列文章的番外篇

TCP为什么做三次握手、四次挥手的更多相关文章

  1. python摸爬滚打之----tcp协议的三次握手四次挥手

    TCP协议的三次握手, 四次挥手 三次握手过程 1, 服务器时刻准备接受客户端进程的连接请求, 此时服务器就进入了LISTEN(监听)状态; 2, 客户端进程然后向服务器发出连接请求报文, 之后客户端 ...

  2. Python进阶----网络通信基础 ,OSI七层协议() ,UDP和TCP的区别 , TCP/IP协议(三次握手,四次挥手)

    Python进阶----网络通信基础 ,OSI七层协议() ,UDP和TCP的区别 , TCP/IP协议(三次握手,四次挥手) 一丶CS/BS 架构 C/S: 客户端/服务器    定义:       ...

  3. OSI七层协议&TCP协议(三次握手四次挥手)

    今日内容 python 基础回顾 软件开发架构 网络理论前戏 OSI 七层协议(五层) TCP协议 三次握手与四次挥手 UDP协议 内容详细 一.python 基础回顾 1.基本数据类型 整型 int ...

  4. TCP/IP报文 三次握手 四次挥手

    1.TCP报文格式  TCP/IP协议的详细信息参看<TCP/IP协议详解>三卷本.下面是TCP报文格式图:图1 TCP报文格式  上图中有几个字段需要重点介绍下:  (1)序号:Seq序 ...

  5. 关于TCP传输的三次握手四次挥手策略

    简单小总结: 一般为了能够准确无误地把数据送达目标处,TCP协议采用了三次握手策略.用TCP协议把数据包送出去后,TCP不会对传送后的情况置之不理,它一定会向对方确认是否成功送达. 注:握手过程中使用 ...

  6. TCP传输的三次握手四次挥手策略

    为了准确无误地数据送达目标处,TCP协议采用了三次握手策略.用TCP协议把数据包送出去后,TCP不会对传送后的情况置之不理,它一定会向对方确认是否成功送达.握手中使用了TCP的标志:SYN和ACK 发 ...

  7. tcp协议:三次握手四次挥手详解-转

    https://www.cnblogs.com/welan/p/9925119.html

  8. tcp/ip原理/三次握手/四次挥手

    @ tcp/ip原理 1.1 tcp/ip三次握手 1.1.1 建立过程说明 a)   由主机A发送建立TCP连接的请求报文, 其中报文中包含seq序列号, 是由发送端随机生成的, 并且还将报文中SY ...

  9. TCP/IP,三次握手四次挥手,TCP/UDP , HTTP/HTTPS

    internet:通用名词,由多个计算机网络组成的网络,网络间的通信协议是任意的 Internet:专用名词,当前全球最大的开放计算机网络,采用TCP/IP协议族作为通信的规则.www万维网是广泛应用 ...

  10. TCP连接为什么三次握手四次挥手

    前几天面试某电商被问住了,问的很细,我就说了说连接过程,必然凉凉.在csdn上找了一篇很详细的博客.https://blog.csdn.net/hyg0811/article/details/1023 ...

随机推荐

  1. POJ 3631 Cow Relays Floyd+矩阵快速幂

    题目描述 For their physical fitness program, N (2 ≤ N ≤ 1,000,000) cows have decided to run a relay race ...

  2. MCU 51-2 LED and Digital tube Test

    点亮LED实验: #include <reg52.h> sbit LED1 = P1^; sbit LED2 = P1^; sbit LED8 = P1^; void main() { L ...

  3. 数据可视化之powerBI技巧(十七)在Power BI中对数据进行分组

    根据某一个维度的数据,进行分组统计,是很常见的做法,比如按年龄对客户进行分组,按考试成绩进行分组统计等,这篇文章介绍一下,在PowerBI中如何对数据进行分组. 在PowerQuery编辑器中分组 在 ...

  4. 数据可视化之DAX篇(二十四)Power BI应用技巧:在总计行实现条件格式

    https://zhuanlan.zhihu.com/p/98975646 如何将表格或者矩阵中值的条件格式也应用于总计行? 目前PowerBI并不支持这种功能,无法在总计行或者小计行上应用条件格式, ...

  5. redis(六):Redis 字符串(String)

    Redis 字符串数据类型的相关命令用于管理 redis 字符串值,基本语法如下: 语法 redis 127.0.0.1:6379> COMMAND KEY_NAME 实例 redis 127. ...

  6. 利用EasyExcel进行对表格数据的写入

    一导入依赖 <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</ ...

  7. Quartz.Net系列(十六):Misfire策略在SimpleScheduler和CronScheduler中的使用

    1.场景 ①因为工作线程都在忙碌,所以导致某些Trigger得不到触发 也就是默认10个工作线程而我有15个Trigger同时触发 这就导致有5个不能被触发,而不幸的是Trigger所关联的Job执行 ...

  8. JavaScript动画实例:旋转的正三角形

    给定一个正三角形的重心坐标为(x0,y0),高为h,可以用如下的语句绘制一个底边水平的正三角形. ctx.beginPath(); ctx.moveTo(x0,y0-h*2/3); ctx.lineT ...

  9. 太实用了!自己动手写软件——GUI编程

    这几天我有一个想法就是将我之前做测试写的一些协议脚本(如:ssh.FTP.SMTP.MySQL.Oracle等)综合在一起做一个密码PJ器,这么多的协议放在一起,每个协议都有自己特殊的参数,如果还是和 ...

  10. 面试官:请你说下N95应该怎么测试?这样回答让他竖起大拇指!

    随着”新冠疫情“慢慢地消散,各大企业都开始恢复正常的运行. 因为疫情造成很多工作人员的流失,企业也开始疯狂的招聘新鲜的人才,这对于莘莘求职者无疑是个机会. 但是因为求职者众多,很多面试官也开始想方设法 ...