“揭秘网络握手与挥别:TCP三次握手和四次挥手全解析“
前言
在计算机网络中,TCP(传输控制协议)是一种重要的通信协议,用于在网络中的两台计算机之间建立可靠的连接并交换数据。TCP协议通过“三次握手”和“四次挥手”的过程来建立和终止连接,确保数据的准确传输。
一、三次握手(Three-Way Handshake))
三次握手是指建立一个TCP连接时,需要客户端和服务器总共发送3个包以确认连接的建立。这个过程主要是为了同步双方的序列号和确认号,并交换TCP窗口大小信息。

第一次握手:
- 客户端发送一个TCP的SYN(synchronize)报文段到服务器,其中SYN标志位被设置为1,选择一个初始的序列号x。这表明客户端希望建立连接,并且客户端准备发送数据。
 
第二次握手:
- 服务器收到SYN报文段后,如果同意建立连接,则会发送一个SYN+ACK(acknowledge)报文段作为响应。该报文段中SYN标志位被设置为1,ACK标志位也被设置为1,确认号为x+1,同时选择自己的初始序列号y。
 
第三次握手:
- 客户端收到服务器的SYN+ACK报文段后,向服务器发送一个ACK报文段,其中ACK标志位被设置为1,序列号为x+1,确认号为y+1。这表明客户端收到了服务器的确认,且客户端准备好了发送数据。
 
至此,三次握手完成,客户端与服务器之间建立了连接,可以开始数据传输。
如图:

为什么是三次握手而不是两次?
1. 防止旧连接请求的干扰
- 在网络通信中,由于网络延迟或其他因素,一个旧的连接请求可能会在网络中滞留,并在不适当的时间到达服务器。如果只用两次握手建立连接,服务器收到一个客户端的连接请求(SYN)后,直接回复确认(ACK)并建立连接,那么即使这个请求是一个过时的请求,连接也会被建立。
 
2. 确认双方的接收与发送能力
- 如果使用两次握手,服务器在收到过时的连接请求后就立即分配资源建立连接,这将导致服务器资源的浪费,因为客户端实际上并不期望建立这个过时的连接。三次握手通过确保双方都明确表示了建立当前连接的意图,避免了因误建立过时连接而浪费服务器资源。
 
三次握手通过一个额外的回合来确保双方都准备好进行数据传输。在第三次握手中,客户端发送ACK确认后,这个确认也告诉服务器,客户端确实准备好了接收服务器的数据。如果没有这个额外的确认,就没有办法保证客户端真的准备好了接收数据。
二、四次挥手(Four-Way Handshake)
在TCP(传输控制协议)中,当数据传输完成后,连接的终止过程需要通过一个称为“四次挥手”(Four-way Handshake)的过程来实现。这个过程确保了双方数据传输的完整性和连接的可靠终止。
第一次挥手:
- 客户端发送关闭连接请求报文(FIN)给服务器。
 - 客户端进入FIN_WAIT_1状态,等待服务器的确认。
 
第二次挥手:
- 服务器收到关闭连接请求后,发送确认报文(ACK)给客户端。
 - 服务器进入CLOSE_WAIT状态,等待自己的发送通道关闭。
 
第三次挥手:
- 服务器发送关闭连接请求报文(FIN)给客户端。
 - 服务器进入LAST_ACK状态,等待客户端的确认。
 
第四次挥手:
- 客户端收到关闭连接请求后,发送确认报文(ACK)给服务器。
 - 客户端进入TIME_WAIT状态,等待一段时间后连接彻底关闭。
 - 服务器收到客户端的确认后,关闭连接。
 

如果上面大家没有看明白的话,我们可以通过一个日常生活中的比喻来重新梳理和理解这一过程。
假设两位好朋友A和B在一天的结束时准备告别:
A是客户端,而B是服务器。他们的告别过程可以分为以下四个步骤:
第一次挥手:A表达离开意愿
- 场景比喻:A对B说:“我得走了。”
 - 技术解释:A(客户端)向B(服务器)发送一个FIN报文,表示自己没有数据要发送了,并希望开始关闭连接。
 
第二次挥手:B确认收到
- 场景比喻:B回应:“好的,我知道了。但让我再检查一下是否还有最后的话要说。”
 - 技术解释:B收到FIN报文后,发送一个ACK报文作为响应,确认已经知道A想要结束会面。这时,B可能还有数据需要发送给A,所以并不立即发送FIN报文。
 
第三次挥手:B也表达离开意愿
- 场景比喻:B说完所有话后,对A说:“我也得走了。”
 - 技术解释:B发送一个FIN报文给A,表示服务器端没有数据要发送了,并希望关闭连接。
 
第四次挥手:A确认并准备离开
- 场景比喻:A回应:“好的,那再见。”然后A等待片刻,确保B听到了自己的回应,防止B没听清楚而继续等待。
 - 技术解释:A收到B的FIN报文后,发送一个ACK报文作为回应,并进入TIME_WAIT状态。A等待足够的时间以确保B收到了确认的消息,然后才真正结束连接。
 
通过这个过程,A和B确保了彼此都已经完成了数据的发送和接收,且双方都同意关闭连接。这个细致的过程体现了TCP协议的设计原则,旨在保障数据传输的完整性和连接的可靠终止。
小结
三次握手和四次挥手是TCP协议中非常重要的过程,它们确保了网络通信的可靠性和顺畅性。通过这两个过程,TCP协议能够在不可靠的互联网环境中提供可靠的端到端通信。
相关文章:
“揭秘网络握手与挥别:TCP三次握手和四次挥手全解析“
前言 在计算机网络中,TCP(传输控制协议)是一种重要的通信协议,用于在网络中的两台计算机之间建立可靠的连接并交换数据。TCP协议通过“三次握手”和“四次挥手”的过程来建立和终止连接,确保数据的准确传输。 一、三…...
Java开发工程师面试题(Spring)
一、Spring Bean的生命周期 生命周期可以分为以下几步: 通过Spring框架的beanFactory工厂利用反射机制创建bean对象。根据set方法或者有参构造方法给bean对象的属性进行依赖注入。判断当前bean对象是否实现相关aware接口,诸如beanNameAware、beanFactor…...
【C++】string类的基础操作
💗个人主页💗 ⭐个人专栏——C学习⭐ 💫点击关注🤩一起学习C语言💯💫 目录 导读 1. 基本概述 2. string类对象的常见构造 3. string类对象的容量操作 4. string类对象的访问及遍历操作 5. 迭代器 6.…...
Java项目:40 springboot月度员工绩效考核管理系统009
作者主页:源码空间codegym 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 项目介绍 本系统的功能分为管理员和员工两个角色 管理员的功能有: (1)个人中心管理功能,添加管理员账号…...
opengl 学习(三)-----着色器
着色器 分类demo效果解析教程 分类 OPengl C demo #include "glad/glad.h" #include "glfw3.h" #include <iostream> #include <cmath> #include <vector>#include <string> #include <fstream> #include <sstream>…...
电销平台架构的演变与升级
简介 信也科技电销平台承载了公司400多坐席的日常外呼任务,随着公司业务规模不断增长,业务复杂度不断提升,营销模式需要多样化,营销流程需要更加灵活。为了更好地赋能业务、提高客户转化率,电销平台不断升级优化&#…...
轻薄蓝牙工牌室内人员定位应用
在现代化企业管理的背景下,轻薄蓝牙工牌人员定位应用逐渐崭露头角,成为提升企业效率和安全性的重要工具。本文将从轻薄蓝牙工牌的定义、特点、应用场景以及未来发展趋势等方面,对其进行全面深入的探讨。 一、轻薄蓝牙工牌的定义与特点 轻薄…...
好物周刊#46:在线工具箱
https://github.com/cunyu1943 村雨遥的好物周刊,记录每周看到的有价值的信息,主要针对计算机领域,每周五发布。 一、项目 1. twelvet 一款基于 Spring Cloud Alibaba 的权限管理系统,集成市面上流行库,可以作用为快…...
20240306-1-大数据的几个面试题目
面试题目 1. 相同URL 题目: 给定a、b两个文件,各存放50亿个url,每个url各占64字节,内存限制是4G,让你找出a、b文件共同的url? 方案1:估计每个文件的大小为50G64320G,远远大于内存限制的4G。所以…...
Vue中如何处理用户权限?
在前端开发中,处理用户权限是非常重要的一个方面。Vue作为一种流行的前端框架,提供了很多便捷的方式来管理用户权限。本文将介绍一些Vue中处理用户权限的方法 1. 使用路由守卫 Vue Router提供了一个功能强大的功能,即导航守卫(N…...
【STM32】HAL库 CubeMX教程---基本定时器 定时
目录 一、基本定时器的作用 二、常用型号的TIM时钟频率 三、CubeMX配置 四、编写执行代码 实验目标: 通过CUbeMXHAL,配置TIM6,1s中断一次,闪烁LED。 一、基本定时器的作用 基本定时器,主要用于实现定时和计数功能…...
2024年最新整理腾讯云学生服务器价格、续费和购买流程
2024年腾讯云学生服务器优惠活动「云校园」,学生服务器优惠价格:轻量应用服务器2核2G学生价30元3个月、58元6个月、112元一年,轻量应用服务器4核8G配置191.1元3个月、352.8元6个月、646.8元一年,CVM云服务器2核4G配置842.4元一年&…...
【QT】重载的信号槽/槽函数做lambda表达式
重载的信号槽 函数指针: int fun(int a,long b) int (*funp)(int, long) fun; 实现回调函数就需要函数指针 信号重载 派生类槽函数发送两个信号 派生类给父类发两个信号 void (SubWidget::*mysigsub)() &SubWidget::sigSub;connect(&subw,mysigsub,t…...
C++之类(一)
1,封装 1.1 封装的引用 封装是C面向对象三大特性之一 封装的意义: 将属性和行为作为一个整体,表现生活中的事物 将属性和行为加以权限控制 1.1.1 封装意义一: 在设计类的时候,属性和行为写在一起,表…...
【工具类】repo是什么,repo常用命令,repo和git和git-repo的关系
1. repo 1. repo 1.1. repo是什么1.2. 安装1.3. repo 命令 1.3.1. repo help1.3.2. repo init1.3.3. repo sync1.3.4. repo upload1.3.5. repo start1.3.6. repo forall 1.4. mainfest 文件1.5. git-repo简介(非android repo)1.6. 参考资料 1.1. repo是什么 Repo 是一个 go…...
Java中可以实现的定时任务策略
Java中可以实现的定时任务策略 文章目录 Java中可以实现的定时任务策略自定义独立线程JDK提供的调度线程池-**ScheduledExecutorService**内核是Spring的Task执行调度quartz调度 #mermaid-svg-mQ9rPqk0Ds3ULnvD {font-family:"trebuchet ms",verdana,arial,sans-seri…...
【目标分类图像增强方法】
图像增强方法及其原理 目标分类图像增强是一种用于提高深度学习模型泛化能力的技术,通过在训练过程中对原始图像进行各种变换来增加模型所见数据的多样性。以下是几种常见的图像增强方法及其原理: 几何变换: 旋转(Rotation&#…...
游戏盾如何应对微商城网站DDoS攻击
游戏盾如何应对微商城网站DDoS攻击?随着电子商务的快速发展,微商城网站已成为众多商家开展在线业务的重要平台。然而,与此同时,网络安全威胁也愈发严重。其中,分布式拒绝服务(DDoS)攻击是一种常…...
安卓手机如何使用JuiceSSH实现公网远程连接本地Linux服务器
文章目录 1. Linux安装cpolar2. 创建公网SSH连接地址3. JuiceSSH公网远程连接4. 固定连接SSH公网地址5. SSH固定地址连接测试 处于内网的虚拟机如何被外网访问呢?如何手机就能访问虚拟机呢? cpolarJuiceSSH 实现手机端远程连接Linux虚拟机(内网穿透,手机端连接Linux虚拟机) …...
钉钉群内自定义机器人发送消息功能实现
文章目录 钉钉群内自定义机器人发送消息功能实现1、设置webhook自定义机器人2、查看官方文档,使用open api3、编写业务代码4、发送成功结果如下 钉钉群内自定义机器人发送消息功能实现 1、设置webhook自定义机器人 设置关键词 添加完成后,获得改机器人的…...
智慧医疗能源事业线深度画像分析(上)
引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...
Unity3D中Gfx.WaitForPresent优化方案
前言 在Unity中,Gfx.WaitForPresent占用CPU过高通常表示主线程在等待GPU完成渲染(即CPU被阻塞),这表明存在GPU瓶颈或垂直同步/帧率设置问题。以下是系统的优化方案: 对惹,这里有一个游戏开发交流小组&…...
2024年赣州旅游投资集团社会招聘笔试真
2024年赣州旅游投资集团社会招聘笔试真 题 ( 满 分 1 0 0 分 时 间 1 2 0 分 钟 ) 一、单选题(每题只有一个正确答案,答错、不答或多答均不得分) 1.纪要的特点不包括()。 A.概括重点 B.指导传达 C. 客观纪实 D.有言必录 【答案】: D 2.1864年,()预言了电磁波的存在,并指出…...
1688商品列表API与其他数据源的对接思路
将1688商品列表API与其他数据源对接时,需结合业务场景设计数据流转链路,重点关注数据格式兼容性、接口调用频率控制及数据一致性维护。以下是具体对接思路及关键技术点: 一、核心对接场景与目标 商品数据同步 场景:将1688商品信息…...
鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院挂号小程序
一、开发准备 环境搭建: 安装DevEco Studio 3.0或更高版本配置HarmonyOS SDK申请开发者账号 项目创建: File > New > Create Project > Application (选择"Empty Ability") 二、核心功能实现 1. 医院科室展示 /…...
【Web 进阶篇】优雅的接口设计:统一响应、全局异常处理与参数校验
系列回顾: 在上一篇中,我们成功地为应用集成了数据库,并使用 Spring Data JPA 实现了基本的 CRUD API。我们的应用现在能“记忆”数据了!但是,如果你仔细审视那些 API,会发现它们还很“粗糙”:有…...
七、数据库的完整性
七、数据库的完整性 主要内容 7.1 数据库的完整性概述 7.2 实体完整性 7.3 参照完整性 7.4 用户定义的完整性 7.5 触发器 7.6 SQL Server中数据库完整性的实现 7.7 小结 7.1 数据库的完整性概述 数据库完整性的含义 正确性 指数据的合法性 有效性 指数据是否属于所定…...
零知开源——STM32F103RBT6驱动 ICM20948 九轴传感器及 vofa + 上位机可视化教程
STM32F1 本教程使用零知标准板(STM32F103RBT6)通过I2C驱动ICM20948九轴传感器,实现姿态解算,并通过串口将数据实时发送至VOFA上位机进行3D可视化。代码基于开源库修改优化,适合嵌入式及物联网开发者。在基础驱动上新增…...
《Docker》架构
文章目录 架构模式单机架构应用数据分离架构应用服务器集群架构读写分离/主从分离架构冷热分离架构垂直分库架构微服务架构容器编排架构什么是容器,docker,镜像,k8s 架构模式 单机架构 单机架构其实就是应用服务器和单机服务器都部署在同一…...
Spring AOP代理对象生成原理
代理对象生成的关键类是【AnnotationAwareAspectJAutoProxyCreator】,这个类继承了【BeanPostProcessor】是一个后置处理器 在bean对象生命周期中初始化时执行【org.springframework.beans.factory.config.BeanPostProcessor#postProcessAfterInitialization】方法时…...
