TCP的三次握⼿中为什么是三次?为什么不是两 次、四次?

TCP 三次握手(Three-way Handshake)是为了在不可靠的网络环境中建立可靠的、双向的连接。之所以选择三次握手,而不是两次或四次,是为了在效率和可靠性之间取得平衡。

三次握手的过程:

  1. SYN (Client -> Server):

    • 客户端选择一个初始序列号(client_isn,通常是随机生成的)。
    • 客户端发送一个 SYN 报文段(SYN=1,seq=client_isn)到服务器。
    • 客户端进入 SYN_SENT 状态。
  2. SYN + ACK (Server -> Client):

    • 服务器收到客户端的 SYN 报文段。
    • 服务器选择自己的初始序列号(server_isn,通常是随机生成的)。
    • 服务器发送一个 SYN+ACK 报文段(SYN=1, ACK=1, seq=server_isn, ack=client_isn+1)到客户端。
      • SYN=1 表示这是一个 SYN 报文段。
      • ACK=1 表示这是一个 ACK 报文段。
      • seq=server_isn 表示服务器的初始序列号。
      • ack=client_isn+1 表示服务器期望接收的下一个序列号(即客户端的初始序列号加 1)。
    • 服务器进入 SYN_RCVD 状态。
  3. ACK (Client -> Server):

    • 客户端收到服务器的 SYN+ACK 报文段。
    • 客户端发送一个 ACK 报文段(ACK=1, seq=client_isn+1, ack=server_isn+1)到服务器。
      • ACK=1 表示这是一个 ACK 报文段。
      • seq=client_isn+1 表示客户端的下一个序列号。
      • ack=server_isn+1 表示客户端期望接收的下一个序列号(即服务器的初始序列号加 1)。
    • 客户端进入 ESTABLISHED 状态。
    • 服务器收到客户端的 ACK 报文段后,也进入 ESTABLISHED 状态。

为什么不是两次握手?

两次握手无法防止历史连接的建立,可能导致错误。

  • 场景:

    1. 客户端发送 SYN 报文段(请求建立连接),但该报文段在网络中滞留了。
    2. 客户端超时重传 SYN 报文段,并成功与服务器建立了连接,完成了数据传输,然后关闭了连接。
    3. 滞留的 SYN 报文段最终到达了服务器。
    4. 服务器收到 SYN 报文段后,回复 SYN+ACK 报文段(如果只有两次握手,此时服务器认为连接已建立)。
    5. 客户端收到 SYN+ACK 报文段,但发现这是一个过期的连接请求,因此会忽略它(或者发送 RST 报文段重置连接)。
    6. 服务器不知道客户端已经丢弃了这个连接请求,会一直等待客户端发送数据,导致资源浪费。
  • 问题: 两次握手无法让客户端确认服务器是否收到了它的 SYN 报文段,也无法让服务器知道客户端是否已经放弃了连接请求。

三次握手如何解决两次握手的问题:

  • 在第三次握手中,客户端发送 ACK 报文段,确认收到了服务器的 SYN+ACK 报文段,并携带了正确的序列号。
  • 服务器收到客户端的 ACK 报文段后,才能确认连接已建立。
  • 如果服务器没有收到客户端的 ACK 报文段(例如,因为客户端已经放弃了连接请求),服务器会超时重传 SYN+ACK 报文段,或者最终放弃连接。

为什么不是四次握手?

理论上,四次握手也可以建立可靠的连接,但三次握手已经足够了,四次握手会增加不必要的开销。

  • 四次握手的一种可能形式:

    1. Client -> Server: SYN
    2. Server -> Client: ACK (确认收到 SYN)
    3. Server -> Client: SYN
    4. Client -> Server: ACK (确认收到 SYN)
  • 问题: 第二次和第三次握手可以合并为一次(SYN+ACK),因为它们都是由服务器发送的,并且都与服务器的初始序列号有关。

三次握手的本质:

  • 同步序列号: 客户端和服务器需要交换彼此的初始序列号 (ISN),以便进行可靠的数据传输。
  • 确认收到: 双方都需要确认收到了对方的 SYN 报文段。
  • 防止历史连接: 防止过期的连接请求被错误地建立。

总结:

  • 两次握手无法防止历史连接的建立,可能导致错误。
  • 三次握手是建立可靠连接所需的最小次数,它既能同步序列号,又能确认双方的接收能力,还能防止历史连接。
  • 四次握手可以建立可靠连接,但没有必要,会增加开销。

三次握手是在可靠性和效率之间取得平衡的结果。它确保了连接的可靠建立,同时又避免了不必要的开销。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/27446.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【二.提示词工程与实战应用篇】【1.提示词工程入门:AI对话的艺术】

大家好,今天咱们来聊聊一个特别有意思的话题——提示词工程。你可能已经听说过这个词,或者在使用AI工具时不经意间接触过它。但提示词工程到底是什么?它为什么这么重要?咱们今天就来深入探讨一下,看看它是如何影响我们与AI的对话,以及如何在实际应用中发挥作用的。 什么…

[密码学实战]Java实现国密(SM2)密钥协商详解:原理、代码与实践

一、代码运行结果 二、国密算法与密钥协商背景 2.1 什么是国密算法? 国密算法是由中国国家密码管理局制定的商用密码标准,包括: SM2:椭圆曲线公钥密码算法(非对称加密/签名/密钥协商)SM3:密码…

unity lua属性绑定刷新

我们现在有一个 角色属性类叫heroModel,内容如下,当heroModel中的等级发生变化的时候,我们需要刷新界面显示等级信息,通常我们是在收到等级升级成功的协议的时候,发送一个事件,UI界面接受到这个事件的时候,刷新一下等级…

制服小程序的“滑手”:禁用页面左右滑动全攻略

哈哈,看来你已经很聪明地发现了小程序中左右滑动的“顽皮”行为!😄 没错,我们可以通过设置 disableScroll 属性来“管教”它,同时结合 CSS 样式让页面既禁得住横向“乱跑”,又能顺畅地上下滚动。你的方案已…

蓝桥备赛(六)- C/C++输入输出

一、OJ题目输入情况汇总 OJ(online judge) 接下来会有例题 , 根据一下题目 , 对这些情况进行分析 1.1 单组测试用例 单在 --> 程序运行一次 , 就处理一组 练习一:计算 (ab)/c 的值 B2009 计算 (ab)/c …

Golang的性能分析指标解读

Golang的性能分析指标解读 一、概述 语言)是一种由Google开发的开源编程语言,以其并发性能和高效的编译速度而闻名。对于程序员来说,了解如何对Golang应用程序进行性能分析是非常重要的,因为这能帮助他们发现潜在的性能瓶颈并对其…

【前端基础】Day 8 H5C3提高

目录 1. HTML5新特性 1.1 新增语义化标签 1.2 新增多媒体标签 1.3 新增input类型 1.4 新增表单属性 2. CSS3的新特性 2.1 新增选择器 2.1.1 属性选择器 2.1.2 结构伪类选择器 2.1.3 伪元素选择器(重点) 2.2 CSS3盒子模型 2.3 CSS3其他特性&a…

Android系统_Surface绘制流程

目录 一,框架图 二,核心代码 一,框架图 对上面这张图的总结 二,核心代码 /Volumes/aosp/android-8.1.0_r52/frameworks/native/services/surfaceflinger/SurfaceFlinger.cpp void SurfaceFlinger::onMessageReceived(int32_t what) {ATRACE_CALL();switch (what) {case Mes…

CDefView::_OnFSNotify函数分析

进入CDefView::_OnFSNotify函数时状态栏 _UpdateStatusBar函数之后增加一个对象,变成7个对象。 LRESULT CDefView::_OnFSNotify(LONG lNotification, LPCITEMIDLIST* ppidl) { LPITEMIDLIST pidl; LPCITEMIDLIST pidlItem; // we may be registered for no…

KVMOVS组网配置案例-4

0.配置要求 1.使用ovs创建一个网桥,网桥上添加宿主机eth0接口,接口为trunk,可转发所有vlan的数据2.使用KVM创建并图形安装两个linux虚拟机vm1,vm2。3.vm1关联ovs的vlan10接口,vm2关联ovs的vlan20接口。4.vm1获取vlan10的IP地址,v…

C#—Settings配置详解

C#—Settings配置详解 在C#项目中,全局配置通常指的是应用程序的设置(settings),这些设置可以跨多个类或组件使用,并且通常用于存储应用程序的配置信息,如数据库连接字符串、用户偏好设置等。 Settings配置…

Redis 哨兵模式

哨兵模式(Sentinel) 是 Redis 提供的一种高可用性(High Availability, HA)解决方案,用于监控和管理 Redis 主从架构中的主节点(Master)和从节点(Slave)。当主节点出现故障…

【大厂AI实践】美团:美团智能客服核心技术与实践

【大厂AI实践】美团:美团智能客服核心技术与实践 🌟 嗨,你好,我是 青松 ! 🌈 自小刺头深草里,而今渐觉出蓬蒿。 NLP Github 项目推荐: 【AI 藏经阁】:https://gitee.com…

linux离线安装miniconda环境

1 下载安装包 可以在官网下载最新版 https://www.anaconda.com/download/success#miniconda 或者在软件目录选择合适的版本 https://repo.anaconda.com/miniconda/ 安装包传入离线服务器 ./Miniconda3-py311_24.9.2-0-Linux-x86_64.sh2 运行安装包 ./Miniconda3-py311_24…

线程相关八股

1. 线程和进程的区别? 进程:进程可以简单理解为进行一个程序,比如说我们打开一个浏览器,打开一个文本,这就是开启了一个进程,一个进程想要在计算机中运行,需要将程序交给CPU,将数据…

水仙花数(华为OD)

题目描述 所谓水仙花数,是指一个n位的正整数,其各位数字的n次方和等于该数本身。 例如153是水仙花数,153是一个3位数,并且153 13 53 33。 输入描述 第一行输入一个整数n,表示一个n位的正整数。n在3到7之间&#x…

写一写idea中使用tomcat启动activiti过程

一 环境 tomcat 9.0.62 activiti的war包版本 7.1.0.M6 二 操作 官网下载:https://www.activiti.org/get-started 2.1 先在idea中编辑配置 2.2 点击加号然后选择tomcat本地进行确认 2.3 点击部署之后下边小加号 选择第二个之后就是选择自己想要使用tomcat启动的…

【每日一题 | 2025】2.24 ~ 3.2

个人主页:Guiat 归属专栏:每日一题 文章目录 1. 【2.24】P10424 [蓝桥杯 2024 省 B] 好数2. 【2.25】P8665 [蓝桥杯 2018 省 A] 航班时间3. 【2.26】P10905 [蓝桥杯 2024 省 C] 回文字符串4. 【2.27】P10425 [蓝桥杯 2024 省 B] R 格式5. 【2.28】P10426…

11.【线性代数】——矩阵空间,秩1矩阵,小世界图

十一 矩阵空间,秩1矩阵,小世界图 1. 矩阵空间交集 和 和集 2. 所有解空间3. r 1 r1 r1的矩阵4. 题目5. 小世界图 空间:组成空间的元素的线性组合都在这个空间中。 1. 矩阵空间 举例:矩阵空间( M M M 所有3x3的矩阵&…

我代表中国受邀在亚马逊云科技全球云计算大会re:Invent中技术演讲

大家好我是小李哥,本名叫李少奕,目前在一家金融行业公司担任首席云计算工程师。去年5月很荣幸在全球千万名开发者中被选为了全球亚马逊云科技认证技术专家(AWS Hero),是近10年来大陆地区仅有的第9名大陆专家。同时作为…