“揭秘网络握手与挥别: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自定义机器人 设置关键词 添加完成后,获得改机器人的…...

Opencv中的addweighted函数
一.addweighted函数作用 addweighted()是OpenCV库中用于图像处理的函数,主要功能是将两个输入图像(尺寸和类型相同)按照指定的权重进行加权叠加(图像融合),并添加一个标量值&#x…...
第25节 Node.js 断言测试
Node.js的assert模块主要用于编写程序的单元测试时使用,通过断言可以提早发现和排查出错误。 稳定性: 5 - 锁定 这个模块可用于应用的单元测试,通过 require(assert) 可以使用这个模块。 assert.fail(actual, expected, message, operator) 使用参数…...

现代密码学 | 椭圆曲线密码学—附py代码
Elliptic Curve Cryptography 椭圆曲线密码学(ECC)是一种基于有限域上椭圆曲线数学特性的公钥加密技术。其核心原理涉及椭圆曲线的代数性质、离散对数问题以及有限域上的运算。 椭圆曲线密码学是多种数字签名算法的基础,例如椭圆曲线数字签…...
什么是EULA和DPA
文章目录 EULA(End User License Agreement)DPA(Data Protection Agreement)一、定义与背景二、核心内容三、法律效力与责任四、实际应用与意义 EULA(End User License Agreement) 定义: EULA即…...
【RockeMQ】第2节|RocketMQ快速实战以及核⼼概念详解(二)
升级Dledger高可用集群 一、主从架构的不足与Dledger的定位 主从架构缺陷 数据备份依赖Slave节点,但无自动故障转移能力,Master宕机后需人工切换,期间消息可能无法读取。Slave仅存储数据,无法主动升级为Master响应请求ÿ…...

C# 求圆面积的程序(Program to find area of a circle)
给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...

LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf
FTP 客服管理系统 实现kefu123登录,不允许匿名访问,kefu只能访问/data/kefu目录,不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...

MySQL 知识小结(一)
一、my.cnf配置详解 我们知道安装MySQL有两种方式来安装咱们的MySQL数据库,分别是二进制安装编译数据库或者使用三方yum来进行安装,第三方yum的安装相对于二进制压缩包的安装更快捷,但是文件存放起来数据比较冗余,用二进制能够更好管理咱们M…...

云原生安全实战:API网关Kong的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关(API Gateway) API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座…...
第7篇:中间件全链路监控与 SQL 性能分析实践
7.1 章节导读 在构建数据库中间件的过程中,可观测性 和 性能分析 是保障系统稳定性与可维护性的核心能力。 特别是在复杂分布式场景中,必须做到: 🔍 追踪每一条 SQL 的生命周期(从入口到数据库执行)&#…...