计算机专业课面试常见问题-计算机网络篇

目录

1. 计算机网络分为哪 5 层?

2. TCP 协议简述?                                                                

3. TCP 和 UDP 的区别?->不同的应用场景?                            

4. 从浏览器输入网址到显示页面的经历的过程?                           

5. 计算机网络每层有哪些协议?

6. TCP 的三次握手和四次挥手过程?                                         

三次握手(TCP Three-Way Handshake)

四次挥手(TCP Four-Way Handshake)

7. 流量控制和拥塞控制的概念?                                                             

8. 简述 DNS 协议?                                                            

9. 简述 DNS 域名解析的过程?                                              

10. 简述 HTTP 协议?                                                         

11.说明 CSMA/CD 与 CSMA/CA 的区别?                             

12.谈谈ip与MAC地址

13. 谈谈你对ip地址分类的理解


1. 计算机网络分为哪 5 层?

计算机网络五层结构是指物理层、数据链路层、网络层、传输层、应用层。

(1)应用层

专门针对某些应用提供服务。

(2)传输层

网络层只把数据送到主机,但不会送到进程。传输层负责进程与进程之间的传输,所以也称为端到端传送。

(3)网络层

根据包里面的目的地址,进行路由选择,决定要往哪个方向传输。

(4)数据链路层

通过物理网络传送包,这里的包是通过网络层交过来的数据报。

(5)物理层

通过线路传送原始的比特流。

2. TCP 协议简述?                                                                

TCP(Transmission Control Protocol)是一种面向连接的、可靠的传输层协议,用于在计算机网络中实现端到端的数据传输。以下是TCP协议的简要描述:

TCP协议提供了可靠的数据传输服务,通过三次握手建立连接,确保数据能够按顺序到达目标,并检测和纠正丢失或损坏的数据。它通过使用序号、确认和超时重传等机制来实现数据的可靠性。

此外,TCP还提供了拥塞控制机制,通过动态调整发送数据的速率,避免网络拥塞,确保网络的稳定性和效率。

总之,TCP协议通过连接建立、可靠性保证和拥塞控制,为应用程序提供了一个可靠的数据传输通道,是互联网上应用最广泛的传输层协议之一。

3. TCP 和 UDP 的区别?->不同的应用场景?                            

 

TCP

UDP

是否连接

面向连接

无连接

是否可靠

可靠传输,使用流量控制和拥塞控制

不可靠传输,不使用流量控制和拥塞控制

连接对象个数

只能是一对一通信

支持一对一、一对多、多对一和多对多的交互通信

传输方式

面向字节流

面向报文

首部开销

首部开销较大

首部开销小

使用场景

适用于要求可靠传输的应用,例如文件传输

适用于实时应用(视频会议、直播、语音通话)

4. 从浏览器输入网址到显示页面的经历的过程?                           

当用户在浏览器中输入网址并按下回车键后,浏览器会执行以下步骤来获取并显示网页:

  1. DNS解析: 浏览器首先会检查自身的缓存,看是否有该网址对应的IP地址。如果缓存中没有,浏览器会向本地操作系统的DNS解析器发起请求,请求解析该域名(比如www.example.com)对应的IP地址。

  2. 建立TCP连接: 一旦浏览器获取到目标服务器的IP地址,它会通过TCP协议向目标服务器发起连接请求。这个过程涉及到TCP的三次握手,确保浏览器和服务器之间建立可靠的连接。

  3. 发送HTTP请求: 一旦TCP连接建立成功,浏览器会通过该连接向服务器发送一个HTTP请求。该请求中包含了浏览器想要获取的资源(比如HTML文件、图片、CSS文件等)的详细信息,如请求方法(GET、POST等)、请求头、请求体等。

  4. 服务器处理请求并返回HTTP响应: 服务器收到浏览器发送的请求后,会根据请求的内容进行处理。服务器可能会请求其他服务器获取需要的资源(如数据库服务器),然后将响应的数据发送回浏览器。

  5. 浏览器接收响应: 浏览器接收到来自服务器的HTTP响应后,会先检查状态码(比如200表示成功,404表示未找到等)。如果响应是一个HTML文件,则浏览器会开始解析HTML文件,并根据HTML文件中的链接继续获取其他嵌入资源(如图片、CSS、JavaScript文件等)。

  6. 渲染页面: 浏览器根据收到的HTML、CSS和JavaScript等文件开始渲染页面。它会根据HTML结构构建DOM树,根据CSS样式构建渲染树,然后将它们结合起来,显示在用户界面上。JavaScript脚本可能会在这个过程中修改DOM树或者进行其他的动态操作。

  7. 完成页面加载: 当浏览器完成所有资源的下载和页面的渲染后,页面就会完全展示给用户。此时用户可以与页面进行交互,如点击链接、填写表单等。

这些步骤描述了从用户输入网址到浏览器显示页面的整个过程,涵盖了网络通信、协议解析、资源获取和页面渲染等关键步骤。

5. 计算机网络每层有哪些协议?

层名称

协议

应用层

建立在 TCP 上:HTTP、FTP、SMTP、TELNET

 

建立在 UDP 上:DNS、DHCP、TFTP

传输层

TCP、UDP

网络层

IP、ICMP、IGMP

数据链路层

ARP、RARP

物理层

ISO2210、IEEE802

6. TCP 的三次握手和四次挥手过程?                                         

 

TCP的三次握手(Three-Way Handshake)和四次挥手(Four-Way Handshake)是在建立和终止TCP连接时所涉及的重要过程。这些过程确保了数据传输的可靠性和顺序性。

三次握手(TCP Three-Way Handshake)

三次握手是TCP连接建立过程中的步骤,确保通信双方的初始化序列号(Sequence Number)和确认序号(Acknowledgment Number)的同步。

  1. 第一步:客户端向服务器发送连接请求

    • 客户端(Client)首先发送一个SYN(同步)标志位置为1的TCP报文段,指定自己的初始化序列号(ISN)。
  2. 第二步:服务器响应并确认连接请求

    • 服务器(Server)收到客户端的SYN报文段后,会确认客户端的SYN(ACK)标志位置为1,同时也会设置自己的初始化序列号(ISN)。服务器还会在响应中包含一个确认序号(Acknowledgment Number),确认客户端的序列号加1。
  3. 第三步:客户端确认服务器的响应

    • 客户端收到服务器的SYN/ACK报文段后,会向服务器发送一个确认报文段,确认收到服务器的响应。客户端将确认序号设置为服务器的序列号加1。

完成了以上三步,TCP连接就建立起来了,通信双方可以开始传输数据。

四次挥手(TCP Four-Way Handshake)

四次挥手是TCP连接终止的过程,确保双方都知道连接已经关闭。

  1. 第一步:客户端发送连接释放(FIN)报文

    • 客户端希望关闭连接时,会向服务器发送一个FIN标志置为1的报文段,表示数据传输已经完成。
  2. 第二步:服务器收到关闭请求

    • 服务器接收到客户端的FIN报文后,会发送一个ACK确认报文,确认收到了客户端的关闭请求。此时服务器进入CLOSE_WAIT状态,等待自己的数据发送完毕。
  3. 第三步:服务器发送连接释放(FIN)报文

    • 服务器在所有数据发送完毕后,会发送一个FIN标志置为1的报文段给客户端,表示服务器也准备关闭连接。
  4. 第四步:客户端确认服务器的关闭请求

    • 客户端收到服务器的FIN报文后,会发送一个ACK确认报文,确认收到了服务器的关闭请求。客户端进入TIME_WAIT状态,等待可能出现的延迟数据报文。

完成了以上四步,TCP连接就彻底关闭了,双方完成了连接的释放,释放资源。

这些过程保证了数据的可靠传输和连接的正确释放,是TCP协议中非常重要的部分。

为什么是三次握手而不是两次?

TCP协议采用三次握手而不是两次握手的主要原因是为了确保连接的可靠性和正确性,特别是在面对网络中可能存在的延迟、丢包和重复数据包的情况下。让我们来看为什么两次握手是不够的:

确认双方的接收能力和发送能力: 在TCP的三次握手中,第三次握手的ACK确认不仅仅是对服务端的SYN报文的回复,还承载了客户端对服务端初始序列号的确认。这确保了客户端和服务端都能发送和接收数据,从而建立了双向的通信。

避免旧连接的影响: 如果只进行两次握手,客户端发送SYN报文并等待服务端的ACK,此时可能发生网络延迟导致客户端的SYN报文丢失。如果服务端在这段时间内收到了旧连接的延迟数据包,并且服务端在此时发送了一个对应新连接的ACK报文,客户端可能会在收到这个报文时误以为连接已经建立。

序列号的同步: 三次握手中的第三次握手,服务端发送ACK报文并且包含新的序列号,客户端确认了这个序列号,这使得双方的序列号是同步的。

7. 流量控制和拥塞控制的概念?                                                             

流量控制:解决的是发送方和接收方速率不匹配的问题;拥塞控制解决的是避免网络资源被耗尽的问题。流量控制是通过滑动窗口来实现的;拥塞控制是通过拥塞窗口来实现的。

拥塞控制:作用于网络,防止过多的数据注入到网络中,避免出现网络负载过大的情况;常用的方法包括:慢开始、拥塞避免、快重传、快恢复。

8. 简述 DNS 协议?                                                            

DNS 协议是基于 UDP 的应用层协议,它的功能是根据用户输入的域名,解析出该域名对应的 IP 地址,从而给客户端进行访问。

9. 简述 DNS 域名解析的过程?                                              

输入域名后,先查找自己主机对应的域名服务器,域名服务器先查找自己的数据库中的数据;如果没有, 就向上级域名服务器进行查找, 依次类推;多回溯到根域名服务器,肯定能找到这个域名的 IP 地址;域名服务器自身也会进行一些缓存, 把曾经访问过的域名和对应的IP地址缓存起来,可以加速查找过程


DNS(Domain Name System,域名系统)是互联网中用于将域名(如www.example.com)转换为对应的IP地址(如192.0.2.1)的系统。域名解析的过程如下:

用户输入域名: 用户在浏览器中输入一个域名,比如www.example.com。

本地域名解析器查询: 操作系统会首先查询本地域名解析器(通常是本地的DNS缓存或者本地的DNS服务器)。如果缓存中已经有了对应域名的IP地址,解析过程就可以直接结束,否则进入下一步。

递归查询开始: 如果本地解析器没有找到所需的域名解析记录,它会向根域名服务器发起递归查询。根域名服务器是全球DNS系统的最顶层,负责指导查询流向。

根域名服务器返回顶级域名服务器地址: 根域名服务器收到请求后,会返回一个包含所查询域名的顶级域(比如.com)的权威域名服务器的地址。

顶级域名服务器查询: 本地解析器再次向顶级域名服务器发起查询请求,询问包含所需域名的下一级域名服务器(如example.com)的地址。

权威域名服务器查询: 顶级域名服务器会将本次查询重定向到负责管理所需域名的权威域名服务器(例如example.com的权威域名服务器)。

获取目标域名的IP地址: 最后,本地解析器向权威域名服务器发起查询请求,获取所需域名对应的IP地址记录。

返回IP地址给客户端: 一旦本地解析器收到了IP地址记录,它会将这个IP地址返回给操作系统,然后操作系统将其提供给应用程序(如浏览器),使得应用程序可以发起网络连接。

缓存结果: 解析器通常会在本地缓存获取到的IP地址和相应的TTL(生存时间),以便将来更快地响应类似的查询请求。

这个过程确保了域名能够正确地转换为相应的IP地址,使得用户能够通过域名访问到目标服务器上的网站或其他网络服务。

10. 简述 HTTP 协议?                                                         

HTTP 协议是超文本传输协议。它是基于 TCP 协议的应用层传输协议,规定了客户端和服务器端进行之间信息传递的一种规范,是二者共同遵守的协议。

11.说明 CSMA/CD 与 CSMA/CA 的区别?                             

1.含义不同

CSMA/CD:载波侦听多路访问/冲突检测

CSMA/CA:载波侦听多路访问/冲突避免

2.适用的场景不同

CSMA/CD 主要适用于有线以太网

CSMA/CA 主要适用于无线以太网

3.应对冲突的策略不同

CSMA/CD 关键在于冲突的检测

在发送数据之前先要检测一下总线上是否有其他计算机在发送数据,如果有,则暂时不要发送数据,以免发生碰撞。

在发送数据时,要边发边检测,如果检测到了冲突,就退避随机的一段时间。

CSMA/CA 关键在于冲突的避免

它不是在发送过程中去监听是否发生了冲突,而是事先就要设法避免冲突的发生。

当一个主机要发送消息之前,首先要监听信道。如果信道为空,首先要等待一个帧间间隔时间,之后再次监听信道,如果还为空,那么再开始一个随机退避过程。之后再次监听,如果还为空,那么就开始发送数据。

 如果上面的过程中出现信道为忙的情况,那么就终止等待过程,一直等到信道为空之后,再重新执行上面的过程。

12.谈谈ip与MAC地址

IP地址(Internet Protocol Address)和MAC地址(Media Access Control Address)是在计算机网络中用于标识和定位设备的两种不同类型的地址。

IP地址:

定义: IP地址是网络层(第三层)使用的地址,用于在互联网上唯一标识一个设备或网络接口。
功能: IP地址使得设备能够在互联网上相互通信,类似于邮政地址在现实生活中的作用。
格式: IPv4地址由32位二进制数字组成,通常以点分十进制(如192.0.2.1)表示。IPv6地址由128位二进制数字组成,通常以冒号分隔的十六进制表示(如2001:0db8:85a3:0000:0000:8a2e:0370:7334)。
主要特点包括:

分配:由网络管理员或Internet服务提供商分配。
动态分配:可以是静态的(固定不变)或动态的(根据需要变化)。
路由:用于在网络中寻址和路由数据包。
MAC地址:

定义: MAC地址是数据链路层(第二层)使用的地址,用于在局域网中唯一标识一个设备。
功能: MAC地址是设备出厂时固化在网卡上的,用于在局域网内识别和定位设备。
格式: MAC地址通常由48位二进制数字组成,分为6组十六进制数(如00:1A:2B:3C:4D:5E)。
主要特点包括:

唯一性:每个网卡的MAC地址全球唯一,由IEEE管理。
不变性:一般情况下,MAC地址在设备出厂时确定,并且通常不会更改(尽管某些情况下可以进行修改)。
用途:用于在局域网中唯一标识设备,不直接用于Internet路由。
总结:

IP地址用于全球互联网,是逻辑上的地址,通过路由器进行跨网络通信。
MAC地址用于局域网内,是物理上的地址,用于直接在网络中传递数据帧。

13. 谈谈你对ip地址分类的理解

分类是为了有效管理和分配IP地址,以支持不同规模和需求的网络。A类地址适用于大型网络,B类和C类地址则适用于中等和小型网络,而D类和E类地址则用于特定的多播和实验性目的。这种分类体现了早期互联网发展时对地址资源的合理利用和分配。

end

好想摆烂 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/365655.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Wireshark - tshark支持iptables提供数据包

tshark现在的数据包获取方式有两种,分别是读文件、网口监听(af-packet原始套接字)。两种方式在包获取上,都是通过读文件的形式;存在文件io操作,在专门处理大流量的情境下, 我们复用wireshark去做…

【mysql死锁】示例 和讨论 “SHOW ENGINE INNODB STATUS“

文章目录 mysql 死锁死锁演示表结构如下 死锁查询mysql 详情命令行 SHOW ENGINE INNODB STATUS 如果 两个事务都是按照先更新1 再更新2的顺序去做更新 会发生死锁么?验证一下所以 如果顺序是一致的 不会产生死锁 只会进行等待 防止mysql 死锁的方式优化sql 自行顺序…

2024超全盘点:5大文档加密系统,文档加密系统都有哪些功能

在众多文档加密系统中,以下是五款备受推崇的软件,其中包括安企神软件、加密精灵等,它们各自具备独特的优势和特点,以满足不同企业对数据安全的需求。 1. 安企神软件 特点与优势:安企神软件以其全面的数据保护功能见长…

C语言从入门到进阶(15万字总结)

前言: 《C语言从入门到进阶》这本书可是作者呕心沥血之作,建议零售价1元,当然这里开个玩笑。 本篇博客可是作者之前写的所有C语言笔记博客的集结,本篇博客不止有知识点,还有一部分代码练习。 有人可能会问&#xff…

基于STM32的简易智能家居设计

一、项目功能概述 1、OLED显示温湿度、空气质量,并可以设置报警阈值 2、设置4个继电器开关,分别控制灯、空调、开关、风扇 3、设计一个离线语音识别系统,可以语音控制打开指定开关、并且可以显示识别命令词到OLED屏上 4、OLED实时显示&#…

idea启用多个环境

背景 在平常的后端开发中,需要与前端联调,比较方便的是让前端直接连自己的本地环境(毕竟每次都要打包部署到测试环境实在是太麻烦了)。但是这样子也有点不好,就是自己功能还没写好呢,结果前端连着自己的环…

微信小程序template模板引入

如图:temp.wxml是template引入的模板 在two.wxml中: import:是引入temp的页面让template中的内容显示出来在two页面中; include:是显示temp页面内容不在template包裹,template以外的view标签文字和不在view的文字让…

【Linux】进程信号_2

文章目录 八、进程信号1. 信号 未完待续 八、进程信号 1. 信号 除了可以使用 kill 命令和键盘来生成信号,我们也可以使用系统调用来生成信号。 kill函数可以对指定进程发送指定信号。 使用方法: int main(int argc, char *argv[]) {if (argc ! 3) {c…

6-14题连接 - 高频 SQL 50 题基础版

目录 1. 相关知识点2. 例子2.6. 使用唯一标识码替换员工ID2.7- 产品销售分析 I2.8 - 进店却未进行过交易的顾客2.9 - 上升的温度2.10 - 每台机器的进程平均运行时间2.11- 员工奖金2.12-学生们参加各科测试的次数2.13-至少有5名直接下属的经理2.14 - 确认率 1. 相关知识点 left …

美国服务器租用详细介绍与租用流程

在数字化时代,服务器租用已成为许多企业和个人拓展业务、存储数据的重要选择。美国作为全球科技发展的前沿阵地,其服务器租用服务也备受瞩目。下面,我们将详细介绍美国服务器租用的相关知识及租用流程。 一、美国服务器租用简介 美国服务器租…

【K8s】专题六(3):Kubernetes 稳定性之自动扩缩容

以下内容均来自个人笔记并重新梳理,如有错误欢迎指正!如果对您有帮助,烦请点赞、关注、转发!欢迎扫码关注个人公众号! 一、基本介绍 在 Kubernetes 中,自动扩缩容是一种动态调整集群资源,以灵活…

前端vue项目升级nodejs后无法运行了

问题描述: 运行、打包都正常的vue项目,在将nodejs升级到v20.14.0后,均报错了: Error: error:0308010C:digital envelope routines::unsupported opensslErrorStack: [ error:03000086:digital envelope routines::initializ…

Java高级重点知识点-17-异常

文章目录 异常异常处理自定义异常 异常 指的是程序在执行过程中,出现的非正常的情况,最终会导致JVM的非正常停止。Java处 理异常的方式是中断处理。 异常体系 异常的根类是 java.lang.Throwable,,其下有两个子类:ja…

# Kafka_深入探秘者(5):kafka 分区

Kafka_深入探秘者(5):kafka 分区 一、kafka 副本机制 1、Kafka 可以将主题划分为多个分区(Partition),会根据分区规则选择把消息存储到哪个分区中,只要如果分区规则设置的合理,那么所有的消息将会被均匀的…

FastDFS部署

版本介绍 安装fastdfs共需要俩个安装包 fastdfs-5.05.tar.gz libfastcommon-1.0.7.tar.gz编译安装 libfastcommon tar -xvf libfastcommon-1.0.7.tar.gz cd libfastcommon-1.0.7 make.sh make.sh install 3. 设置软链接 libfastcommon.so默认安装到了/usr/lib64/libfastcommon.…

笔记-Python文件: .py、.ipynb、.pyi、.pyc、​.pyd

.py 最常见的Python代码文件后缀名,官方称Python源代码文件。 不用过多解释了~ .ipynb 这个还是比较常见的,.ipynb是Jupyter Notebook文件的扩展名,它代表"IPython Notebook"。 学过数据分析,机器学习,深度…

暑假假期规划 离不开宝藏待办计划管理工具

暑假来临,两个月的自由时间,如何过得充实而有意义,成了我最近思考的问题。毕竟,一个合理的假期规划,不仅能让我的假期生活更加丰富多彩,还能为新学期的到来做好充分的准备。 我幻想着在这个暑假里&#xf…

CSS|04 复合选择器伪类选择器属性选择器美化超链接

基本选择器:见上篇基本选择器 复合选择器选择器1,选择器2{属性:值;} 多元素选择器,同时匹配选择器1和选择器2,多个选择器之间用逗号分隔举例: p,h1,h2{margin:0px;}E F{属性:值;} 后代元素选择器,匹配所有属于E元素后…

塑造卓越企业家IP:多维度视角下的策略解析

在构建和塑造企业家IP的过程中,我们需要从多个维度进行考量,以确保个人品牌能够全面、立体地展现企业家的独特魅力和价值。以下是从不同角度探讨如何做好一个企业家IP的策略。 一、从个人特质出发 深入了解自我:企业家需要清晰地认识到自己的…

Laravel 谨慎使用Storage::append()

在 driver 为 local 时,Storage::append()在高并发下,会存在丢失数据问题,文件被覆写,而非尾部添加,如果明确是本地文件操作,像日志写入,建议使用 Illuminate\Filesystem\Filesystem或者php原生…