百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

面试干货:TCP/IP 协议的经典面试知识点总结

myzbx 2025-04-24 05:30 10 浏览

今天给大家推荐的是,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++的项目学习视频资料哦!已经设置好了关键词自动回复,自动领取就好了!

相关推荐

一键生成高颜值图表!让你的文字瞬间有画面感,职场人必备!

哈喽,打工人们!忙碌的周中,大熊又来给你们带来一个超实用的效率神器啦!这次的宝藏网站绝对是那种用过就离不开的"真香"型产品!假设你明天就要做重要汇报,可面对一大堆密密麻麻的文字材料,你...

批量将 Word 转换为 PDF/Excel/Txt/图片等多种格式

Word文档是我们工作中经常会打交道的一种文档格式,我们也经常会有需要对Word文档进行格式转换的需求,比如将Word格式转换为PDF、将Word文档转换为Excel、将Word...

绝了!一键用AI生成高颜值动态PPT(附详细步骤+Prompt)

大家好,我是一名酷爱研究AI的产品经理,最近我有个新发现:那些花了你3天做出来的PPT,现在用AI可以1小时搞定!而且颜值还高!为什么AI做PPT比传统方式效率高10倍?我用一张图就能告诉你:AI生成...

ztext - 简单几行代码创建酷炫3D特效文字的开源JS库

把网页上的文字变成酷炫的3D风格,还能制作旋转动效,有了ztext.js,只需要几行代码。ztext能做什么ztext.js是一个能把常规的平面文字变成3D样式的前端开源代码库,让开发者...

文字内插入小图片,也太可爱了吧(文字中怎么插图片)

图文排版H5手机版秀米有小伙伴留言问添加图片的时候可不可以把图片添加到文字之间比如下面这句话中的小贴纸图片后面可以接着输入文字其实吧这就是咱们的『文字内插入小图片』功能嘛可以用来在文字内加个表情包又...

Linux环境下C++代码性能分析方法(linux怎么写c++代码)

技术背景在开发C++应用程序时,找出代码中运行缓慢的部分是进行性能优化的关键。在Linux系统上,有多种工具和方法可用于对C++代码进行性能分析,每种方法都有其特点和适用场景。实现步骤手动中断调试法在...

SVG互动图文,让你的文章更有趣!教你4种简单易学的黑科技玩法!

如果你是一个公众号创作者,那么你一定想知道如何让你的文章更加吸引人,更加有趣,更加有创意。你可能已经尝试过各种图文排版技巧,但是你是否知道,有一种黑科技可以让你的文章变得更加酷炫,更加互动,更加爆款?...

Videoscribe怎么实现实心中文汉字的手绘制作

很多朋友在制作手绘视频的时候,不知道怎么输入实心的中文汉字,之前我们已经给大家分享了怎么输入汉字的方法,但是有一点遗憾的是输出的汉字是空心的手绘展示,在视觉上并不是非常的美观。经过大家不断的探索,终于...

一款用于将文本转化成图表的现代化脚本语言

大家好,又见面了,我是GitHub精选君!今天要给大家推荐一个GitHub开源项目terrastruct/d2,该项目在GitHub有超过10.3kStar,用一句话介绍该项目就是:...

探秘 Web 水印技术(制作水印网站)

作者:fransli,腾讯PCG前端开发工程师Web水印技术在信息安全和版权保护等领域有着广泛的应用,对防止信息泄露或知识产品被侵犯有重要意义。水印根据可见性可分为可见水印和不可见水印(盲水印)...

不忍心卸载的五款神仙工具(不忍心卸载的五款神仙工具是什么)

001.效率工具uTools-装机必备的生产力工具集uTools是一款非常强大的可以装下几乎所有效率工具的电脑生产力工具集,目前拥有Windows、Mac和Linux三个版本。软件界面...

「SVG」飞花令!这份最高检工作报告“超有料”

原标题:【SVG】飞花令!这份最高检工作报告“超有料”栏目主编:秦红文字编辑:沈佳灵来源:作者:最高人民检察院...

svg|2025政府工作报告,有没有你关心的数据?

··<setattributeName="visibility"begin="click+0s"dur="1ms"fill="freeze"restart="never"to="hi...

videoscribe只能输入英文,如何输入中文文本?

videoscribe只能输入英文,如何输入中文文本?打开VideoScribe软件,打开要添加中文字体的位置。打开Photoshop并在文件中创建一个新的透明背景图层。注意:必须是透明背景层。...

五个流行的SVG在线编辑器(svg编辑工具)

随着响应网络的发展,越来越多的高质量的SVG在线编辑器被公众所熟知。SVG矢量图形也越来越受欢迎,以便在任何设备上呈现图像,甚至一些易于使用的SVG在线编辑器,可以替代PS,本文总结了五种流行的SVG...