面试干货:TCP/IP 协议的经典面试知识点总结
myzbx 2025-04-24 05:30 15 浏览
今天给大家推荐的是,TCP/IP协议的经典面试知识点总结,希望对大家有帮助,谢谢。
简介
我们平时经常听到的TCP/IP协议,其实是一个协议族;
只不过因为TCP、IP是其中最核心的协议,所以平时统称为TCP/IP协议;
这个协议族里面还有其他协议,比如HTTP、FTP、SMTP等;
TCP分层框架
下图是TCP/IP协议族的一个分层框架图,从上往下依次是应用层、传输层、网络层、链路层、物理层
假如我想在机器A上,发送一条"Hello World"到机器B,这个通讯过程是个什么样子呢?
首先机器A的应用层将消息内容"Hello World"打包,然后经由传输层加上双方的端口号,网络层加上双方的IP地址,链路层加上双方的Mac地址,经过多个路由器和网关,最终到达机器B,然后机器B再反过来解析出消息内容"Hello World"
简化之后的路径就是:消息实体+端口号+IP地址+Mac地址,封装发送,收到消息后,再反过来解包操作
下面我们从上往下,依次介绍各个分层的作用
应用层
按照固定的协议格式打包、解包数据。
比如SMTP协议,虽然不同公司的邮箱格式不尽相同,但是都可以解析对方发来的邮件内容,就是因为他们都遵循SMTP协议
传输层
决定数据要传输到远程机器的哪个程序(端口),同时要表明数据来自源机器的哪个程序(端口),实现端口之间的通讯。
比如本地跑一个测试程序A,监听的是8080端口;远程跑的测试程序B,监听的是8080端口;
那么传输层就会把本机的8080端口和远程的8080端口都加到数据包上;
这样远程机器解析数据时,就知道要把数据传给哪个程序。
网络层
指定双方的IP地址,并进行路由的寻址和转发
这里要明白一点就是,远程机器的IP地址不是一次跳转就可以到达的,要通过路由器和网关的多次跳转,才会到达
链路层
指定远程机器的Mac地址(确保不会发错地方),以及本机的Mac地址
既然有了Mac地址来作为机器的唯一ID,为啥还要有网络层的IP地址呢?
原因有两个
IP是会变化的,有可能今天你跟机器A在聊天,明天就变成机器B了,当然会乱掉了
现在的电脑太多了,数以千万计,从这么多电脑中找出某一个Mac地址,效率很低;但是IP不一样,IP是由网段划分的,有点类似于邮编,这样就可以分段寻址,效率高很多
TCP的三次握手,四次挥手
三次握手
三次握手就是建立连接的过程,示意图如下所示
我们来再把流程简化一点,就是:机器A发送连接请求到机器B -> 机器B收到后,确认并发送同步信号 -> 机器A收到确认信号后,再次发送确认信号到机器B
这里面涉及到几个关键词,下面列出一一说明下
标志关键词
SYN(Synchronize Sequence Numbers),同步信号,表示打算建立连接时的一个信号
ACK(Acknowledgement),数据确认信号,表示是否确认收到数据
状态关键词
LISTENING,监听状态,表示还没开始建立连接,正在监听等待连接的到来
SYN_SENT,SYN已发送,表示SYN已经发送,但是成功不成功还不知道
SYN_RCVD,SYN已收到,表示收到SYN信号,也已经给了应答,但是连接还没建立
ESTABLISHED,连接建立,表示双方已经建立了连接,可以开始相互通信了
下面详细说下三次握手的连接过程
机器A发送同步信号SYN=1,请求建立连接,并附带序列号seq=x (机器A定义)
机器B收到连接请求(SYN=1),返回 同步信号SYN=1 和 数据确认信号ACK=1,并附带序列号 seq = y(机器B自己定义),确认序列号 ack = x + 1(方便机器A校验)
机器A收到机器B的反馈后,继续发送 确认信号 ACK=1,并附带序列号 seq = x + 1,确认序列号 ack = y + 1
为什么要三次?两次行不行?
两次也可以,就是会出现脏连接和信息不对等问题。(开玩笑的,两次当然不行了,出现这么多问题,大家都不用通讯了,每天光顾着建立连接了)
什么是信息不对等?它是怎么产生的呢?
信息不对等说的是,双方对于对方的信息处理能力了解的不一致
对于机器A来说,它内部有四个跟报文收发能力有关的标志(我发送成功了吗,我接收成功了吗,对方发送成功了吗,对方接收成功了吗)
那么对于机器B来说,也应有这四个标志
现在假设只有两次握手,那么当两次握手完成后,机器A的四个标志是都确认成功了,但是机器B心里却会有个两个疑问???
疑问1:我发送成功了吗?
疑问2:对方接收成功了吗?
这时就会产生信息的不对等。
就好比两个人用对讲机交流,我听到你的讲话了,我也回应了,但是你突然不理我了。那我就对自己的表达能力产生疑问了。。。
下面这个表格很形象的说明了 两次握手导致信息不对等的问题
什么是脏连接?它又是怎么产生的呢?
了解脏读之前要先明白一个知识点,就是报文存活的时间 > 请求连接的超时时间(一般情况下)
现在假设我们用的是两次握手,那么脏连接就是机器A有一次请求连接超时,然后请求重连,等到重连成功后,上一次超时的请求又来,此时这个请求对于机器B来说就是脏连接
下面是产生两次握手产生脏连接的示意图
从图中可以看到,重新发送的连接请求,两次握手成功并断开连接后,之前超时的请求又来了,此时机器B发送第二次握手,连接建立;
但是因为此时客户端的状态是ESTABLISHED(已建立连接),而不是SYN_SENT(同步信号已发送),所以机器A不认这个连接,无法通讯,也就成了脏连接。
四次挥手
四次挥手就是断开连接的过程,示意图如下所示
这里面涉及到几个上面没提到的关键词,下面列出一一说明下
标志关键词
FIN(Finish),完成信号,表示通讯已经完成,接下来打算关闭连接了
状态关键词
FIN_WAIT_1,发送断开连接后的等待状态阶段1,表示已经发送了 FIN 请求,但是对方还没确认
FIN_WAIT_2,发送断开连接后的等待状态阶段2,表示对方 ACK 确认了,但是对方还没发送 FIN 请求
TIME_WAIT,固定时间等待期,表示对方已经发送了 FIN 请求 和 ACK 确认信号,我也发送了确认信号 ACK ,过一会就可以关闭连接了
CLOSE_WAIT,关闭等待期,表示接收到 FIN 请求,并发送了 ACK 确认信号,这边开始准备断开连接的收尾工作
LAST_ACK,最后确认,表示已经发送了 FIN 请求和 ACK 确认信号,等待对方 ACK 确认就可以关闭了
CLOSED,关闭状态,表示已经关闭连接
下面详细说下四次挥手的断开连接过程
机器A发送 FIN 信号,请求关闭连接,并附带序列号 seq = u
机器B收到 FIN 信号,返回 ACK 确认信号,并开始准备断开连接的收尾工作
等到收尾完成,机器B再发送 FIN 信号 和 ACK 确认信号,并附带序列号 seq = v, 确认序列号 ack = u + 1
机器A收到后,进入 TIME_WAIT 期,并发送 ACK 确认信号,附带序列号 seq = u + 1,确认序列号 ack = v + 1
机器B收到后,关闭连接
机器A等待固定时间(2MSL,下面会介绍这个参数)后,也关闭连接
为什么握手是三次,挥手却要四次呢?
因为挥手多了一个清理现场的部分,就是发送剩余的数据,处理现场,关闭相关资源
其实如果没有什么可以清理的,机器B也可能省略这个阶段,然后在收到机器A的 FIN 信号时,直接返回 FIN 和 ACK 信号,这样就会变成三次挥手
2MSL是什么参数?
这个 2MSL 就是报文在网络上的生存时长,意思就是报文如果在网络上存在的时间超过这个参数,那么报文就会自动丢弃
这个数值如果过大,会造成资源的浪费
因为如果数值过大,好多连接就会卡在TIME_WAIT这里,还占着端口,那么这个端口就啥也不干了
所以一般建议这个数值调小一点(建议小于30S),尤其是在服务器端
那TIME_WAIT 这个阶段可以跳过吗?为什么要在这里等待一段时间呢?
不可以,原因有二
有可能机器A最后发完 ACK 确认信号后,对方没收到,此时机器A如果立马断开连接,就会导致报文丢失;
相反的,正因为有了这个阶段,所以当对方没收到ACK信号时,对方过段时间会重发FIN+ACK信号,此时机器A会重新发送ACK信号,并重新计时
防止失效请求,防止已失效连接的请求数据包和正常连接的请求数据包混淆而发生异常
已失效的连接,指的是握手过程中由于某些原因没有成功,但是也没断开的连接
现在有了这个TIME_WAIT阶段,那么前面已失效的连接就会因为超时而被丢弃,从而不会干扰到正常的连接
总结
以上只是关于TCP/IP协议的简单介绍,主要为了小白入门。如果你想更好的提升你的编程核心能力(内功)不妨从现在开始!
编程学习书籍分享:
编程学习视频分享:
整理分享(多年学习的源码、项目实战视频、项目笔记,基础入门教程)
欢迎转行和学习编程的伙伴,利用更多的资料学习成长比自己琢磨更快哦!
对于C/C++感兴趣可以关注小编在后台私信我:【编程交流】一起来学习哦!可以领取一些C/C++的项目学习视频资料哦!已经设置好了关键词自动回复,自动领取就好了!
- 上一篇:TCPDUMP 基础使用
- 下一篇:网络篇(四):《图解 TCP/IP》读书笔记
相关推荐
- 怎么恢复7z文件 7z文件删除了怎么恢复
-
7z是一种压缩格式的文件,它运用LZMA压缩算法,该压缩算法的输出稍后被算数编码进行处理以便后续进一步压缩,压缩比十分高。我们可以将文件压缩成这种格式,便于传输,保存,占空间少。了解更多7z文件知识...
- 郎酒让消费者喝得明明白白 算术题里有答案
-
日前,『郎酒酱香产品企业内控准则』颁布,郎酒首次公开酱香产品生产全过程,公布酱香产品产能、储能及投放计划。随后,郎酒官微向消费者发出「品控算术题」有奖问答。郎酒亮出家底,消费者踊跃留言。8天后,谜底揭...
- 学龄前,比识字、算术更重要的是这三件事
-
“为了给孩子选择一家合适的幼儿园,我曾穿梭于纽约各家幼儿园的开放日,这些幼儿员既包括主流的公立幼儿园,还包括那些遥不可及的私人幼儿园。我的目的就是想了解他们的教育理念是什么,到底厉害在哪里,看看对于我...
- 参加CSP-J信奥赛需要掌握数学知识
-
在C++语法的学习中需要储备的数学知识如下①数据类型:需要知道整数、正整数、负整数、小数、判断对错②算术运算符:加法、减法、乘法、除法、取模运算③关系表达式:大于、大于等于、小于、小...
- 1g米饭能做多少深蹲?今天我们来算一算
-
减重我们都知道3分在练,7分在吃,吃这件事情上,真的是每一口都算数。今天我们来算一笔账,1粒米饭可以做多少事情?本着认真负责的态度,今天在食物秤上称了1g米饭,是16粒。根据能量换算:100g米饭是4...
- web 自动化测试,一定得掌握的 8 个核心知识点
-
使用cypress进行端对端测试,和其他的一些框架有一个显著不同的地方,它使用JavaScript作为编程语言。传统主流的selenium框架是支持多语言的,大多数QA会的pytho...
- 大话C语言:赋值运算符(c语言中赋值运算符是什么)
-
赋值运算符是最基本的运算符之一,用于将右侧的值或表达式的计算结果赋给左侧的变量。它是一个二元运算符,意味着它需要两个操作数:一个是目标变量(左侧),另一个是要赋给该变量的值或表达式(右侧)。赋值运算符...
- Vue进阶(幺幺伍):js 将字符串转换为boolean
-
Boolean();参数为0、null和无参数返回false,有参数返回true。Boolean("");//输出为:falseBoolean(null);//输出为...
- mongodb查询的语法(大于,小于,大于或等于,小于或等于等等)
-
1).大于,小于,大于或等于,小于或等于$gt:大于$lt:小于$gte:大于或等于$lte:小于或等于例子:db.collection.find({"field":{$gt:valu...
- Python学不会来打我(21)python表达式知识点汇总
-
在Python中,表达式是由变量、运算符、函数调用等组合而成的语句,用于产生值或执行特定操作。以下是对Python中常见表达式的详细讲解:1.1算术表达式涉及数学运算的表达式。例如:a=5b...
- C|数据存储地址与字节偏移、数据索引
-
话说C是面向内存的编程语言。数据要能存得进去,取得出来,且要考虑效率。不管是顺序存储还是链式存储,其寻址方式总是很重要。顺序存储是连续存储。同质结构的数组通过其索引表示位置偏移,异质结构的结构体通过其...
- 下班后累懵?4 个 JS 手写题帮你搞定前端面试高频考点
-
打工人下班后最痛苦的事,莫过于拖着疲惫的身子还要啃前端面试题吧?看着那些密密麻麻的JS代码,脑子都快转不动了!别担心,今天咱就用轻松的方式,带你吃透4道高频手写题,让你在面试时自信满满,再也不...
- 嵌入式数据库sqlite3【进阶篇】-子句和函数的使用,小白一文入门
-
sqlite在《嵌入式数据库sqlite3命令操作基础篇-增删改查,小白一文入门》一文中讲解了如何实现sqlite3的基本操作增删改查,本文介绍一些其他复杂一点的操作。比如where、orderby...
- 前缀表达式与后缀表达式(前缀表达式后缀表达式中缀表达式计算)
-
昨天晚上和儿子一起学习了前缀表达式和后缀表达式。这应该是字符串算式如何被计算机识别并计算的2种方法。本来是想先给他讲一个逆波兰式(后缀表达式),以后再讲前缀表达式。没想到他还挺聪明,很快就把2个都掌握...
- Python快速入门教程1:基本语法、数据类型、运算符、数字字符串
-
Python3的基础教程,涵盖了基本语法、数据类型、类型转换、解释器、注释、运算符、数字和字符串等内容,并附有使用实例场景。Python3的基础教程,涵盖了基本语法、数据类型、类型转换、解释器、注释、...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 选择器 (30)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)