学习计算机网络中的一些疑问及解答

2023-09-17 22:04:30


前言

一个本硕双非的小菜鸡,备战24年秋招,在学习计算机网络的过程中遇到了一些问题,思考并解答。
部分参考小林大佬的解答 :小林coding

一、为什么要进行三次握手

因为三次握手才能保证双方具有接收和发送的能力。
三次握手才可以阻止重复历史连接的初始化(主要原因)
三次握手才可以同步双方的初始序列号
三次握手才可以避免资源浪费

通过三次握手能防止历史连接的建立,能减少双方不必要的资源开销,能帮助双方同步初始化序列号。序列号能够保证数据包不重复、不丢弃和按序传输。

不使用「两次握手」和「四次握手」的原因:
「两次握手」:无法防止历史连接的建立,会造成双方资源的浪费,也无法可靠的同步双方序列号;
「四次握手」:三次握手就已经理论上最少可靠连接建立,所以不需要使用更多的通信次数。

二、三次握手的流程

请添加图片描述

  1. 一开始,客户端和服务端都处于CLOSE状态。先是服务端主动监听某个端口,处于 LISTEN状态。
  2. 然后客户端主动发起连接 SYN,之后处于 SYN-SEND 状态。此时发送的是一个特殊的TCP报文段,该报文段不包含应用层数据,但是在报文段的首部中的一个标志位被置为1,会随机选择一个初始序号client_sin,该报文段也称SYN报文段。
  3. 服务端收到发起的连接,返回 SYN,并且 ACK 客户端的 SYN,之后处于SYN-RCVD 状态。该报文段SYN比特被置为1,首部的确认字号段被置为client_sin + 1,并选择自己的初始序号(server_isn)将其放置到TCP报文段首部的序号字段中,该报文段也称SYNACK报文段。。
  4. 客户端收到服务端发送的 SYN 和ACK 之后,发送 ACK的 ACK,之后处于ESTABLISHED 状态,因为它一发一收成功了。该SYN比特置0,确认号字段server_isn+ 1,初始序号为client_sin + 1,并且可以在报文段负载中携带客户到服务器的数据。
  5. 服务端收到 ACK的 ACK 之后,处于 ESTABLISHED 状态,因为它也一发一收了。

三、三次握手中seq和ack的值

seq(初始序号)与ack(确认号)
一次:client_sin,暂无
二次:server_isn,client_sin + 1
三次:client_sin + 1,server_isn + 1

四、四次挥手流程

请添加图片描述

  1. 主动方打算关闭连接,此时会发送一个 TCP首部 FIN 标志位被置1的报文,也即 FIN报文,之后主动方进入 FIN WAIT_1 状态。
  2. 被动方收到该报文后,就向主动方发送 ACK应答报文,接着被动方进入 CLOSED_WAIT 状态。
  3. 主动方收到被动方的 ACK 应答报文后,之后进入 FIN WAIT 2状态
  4. 等待被动方处理完数据后,也向主动方发送FIN 报文,之后被动方进入 LAST_ACK 状。
  5. 主动方收到被动方的 FIN 报文后,回一个ACK 应答报文,之后进入 TIME WAIT 状态。
  6. 被动方收到了 ACK 应答报文后,就进入了CLOSED 状态,至此被动方已经完成连接的关闭。
  7. 主动方在经过 2MSL 一段时间后,自动进入CLOSED 状态,至此主动方也完成连接的关闭。
    但是在特定情况下,四次挥手是可以变成三次挥手的

五、四次挥手中seq和ack的值

seq(初始序号)与ack(确认号)
一次:client_sin,server_isn + 1
二次:server_isn + 1,client_sin + 1
三次:server_isn + 2,client_sin + 1
四次:client_sin + 1,server_isn + 3

六、为什么要等待才回复

防止历史连接中的数据,被后面相同四元组的连接错误的接收;
保证「被动关闭连接」的一方,能被正确的关闭;

七、为什么等待2MSL

最后一个等2MSL(一个MSL是报文段的最大存活时间),2MSL保证最后一个ACK对方一定收到。
网络中可能存在来自发送方的数据包,当这些发送方的数据包被接收方处理后又会向对方发送响应,所以一来一回需要等待 2 倍的时间。
可以看到 2MSL时长 这其实是相当于至少允许报文丢失一次。

总结

网络初学,主要是为了CSAPP的最后一个Lab,以后有时间考虑看看CS144(网络这方面我当时学的是真的菜)。

更多推荐

C2基础设施威胁情报对抗策略

威胁情报是指在信息安全和安全防御领域,收集、分析和解释与潜在威胁相关的信息,以便预先发现并评估可能对组织资产造成损害的潜在威胁,是一种多维度、综合性的方法,其通过信息的收集、分析和研判,帮助组织了解可能对其安全构成威胁的因素。这种方法不仅仅着重于技术层面,还包括了社会、心理、政治等多个维度,以此更好地应对不断变化和复杂

基于SSM的旅游网站系统

基于SSM的旅游网站系统【附源码文档】、前后端分离开发语言:Java数据库:MySQL技术:Spring+SpringMVC+MyBatis+Vue工具:IDEA/Ecilpse、Navicat、Maven【主要功能】角色:管理员、用户管理员:用户管理、景点信息管理、购票信息管理、酒店信息管理、客房类型管理、客房信息管

终端数据防泄漏

需求背景随着各行各业业务数据信息化发展,各类产品研发及设计等行业,都有关乎自身发展的核心数据,包括业务数据、代码数据、机密文档、用户数据等敏感信息,这些信息数据有以下共性:属于核心机密资料,万一泄密会对企业造成恶劣影响,包括市场占有率下降、丧失核心竞争力、损失客户信心等各种显性与隐性影响;核心数据类型多,还有业务系统数

Java基于SpringBoot的高校招生管理系统,附源码,教程

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝30W+,Csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌文章目录简介系统设计思路1数据库设计2系统整体设计2.1系统设计思想2.2系统流程图系统详细设计1系统功能模块2.管理员功能模块3学生功能模块六源码咨询

钉钉旧版服务端SDK支持异步方法的升级改造

最近项目中需要对接钉钉,有些钉钉API的访问需要使用旧版服务端SDK才能搞定,但是这个SDK使用的还是.NETFramework2.0框架,不能跨平台部署,也不支持async\await的异步操作方法,Nuget上也有其它用户改造的.NETCore版本,但是都不支持异步方法,于是就想自己改造一下,经过若干小时的改造,最

Stable Diffusion 系统教程 | 强大的ControlNet 控制网

2023年的2月13日,一款名叫ControlNet的插件横空出世,AI绘画变得更加可控ControlNet直译过来很简单,就叫做控制网,开发者是一名华裔,毕业于苏州大学,目前在斯坦福做读博士一年级,大佬大佬!在controlNet之前,基于扩散模型的绘画是极为难控制的,平时自嗨画画其实没有一点问题,随机就随机一点,但

Java 中的四种引用方式

文章目录Java中的四种引用方式1、强引用(StrongReference)(1)弱化方式1(2)弱化方式22、软引用(SoftReference)3、弱引用(WeakReference)4、虚引用(PhantomReference)Java中的四种引用方式1、强引用(StrongReference)强引用是最普遍的引

【Python】Python 模式匹配与正则表达式

Python模式匹配与正则表达式1.模式匹配与正则表达式你可能熟悉文本查找,即按下Ctrl-F,输入你要查找的词。“正则表达式”更进一步,它们让你指定要查找的“模式”。你也许不知道一家公司的准确电话号码,但如果你住在美国或加拿大,你就知道它有3位数字,然后是一个短横线,然后是4位数字(有时候以3位区号开始)。因此作为一

Android SurfaceFlinger导读(02)MessageQueue

该系列文章总纲链接:AndroidGUI系统之SurfaceFlinger系列文章目录说明:关于导读:导读部分主要是方便初学者理解SurfaceFlinger代码中的机制,为后面分析代码打下一个更好的基础,这样就可以把更多的精力放在surfaceFlinger的业务逻辑分析上。关于代码分支:以下代码分析均在androi

单元测试框架-pytest

单元测试框架-pytest官网常用插件pytest-html:生成html报告pytest-xdist:实现并发测试pytest-ordering:实现测试用例顺序设置pytest-rerunfailures:测试用例失败重试allure-pytest:生成测试报告引入依赖在项目根目录下创建:requirements.

RK3568开发笔记(七):在宿主机ubuntu上搭建Qt交叉编译开发环境,编译一个Demo,目标板运行Demo测试

若该文为原创文章,转载请注明原文出处本文章博客地址:https://hpzwl.blog.csdn.net/article/details/132733901红胖子网络科技博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软硬结合等等)持续更新中…瑞芯微开

热文推荐