【八股文】网络基础

news2025/1/21 0:58:00

1.简述一下TCP和UDP的区别?

特性TCP(Transmission Control Protocol)UDP(User Datagram Protocol)
连接类型面向连接,需要建立三次握手连接无连接,发送数据无需建立连接
数据传输提供可靠的数据传输,保证数据顺序和完整性不保证数据传输的可靠性,不保证数据顺序
错误校验通过确认和重传机制进行错误检测和纠正提供基本的错误检测,但不进行重传
流控制使用滑动窗口机制进行流量控制无流控制机制
拥塞控制包含慢启动、拥塞避免等机制以控制网络拥塞不包含拥塞控制机制
效率相对较低,因为需要确认和重传等额外开销较高,因为没有确认和重传机制的开销
数据单元传输的数据单元称为段(Segment)传输的数据单元称为数据报(Datagram)
应用场景文件传输、网页浏览、电子邮件等需要可靠传输的场景实时音频/视频、在线游戏等对延迟敏感的场景
安全性更高的安全性,因为数据传输过程可控较低安全性,数据传输过程不受控
多播和广播不支持多播和广播支持多播和广播,适合一对多的通信模式

2.TCP为什么要三次握手,两次不行吗?为什么?

  • 三次握手的含义:
    • 第一次握手(SYN):客户端向服务器发送一个带有SYN标志的TCP报文段,请求建立连接。这一步确认客户端的存在及其发送的能力。
    • 第二次握手(SYN-ACK):服务器收到SYN报文后,发送一个带有SYN和ACK标志的TCP报文段作为响应。这一步不仅确认了服务器的存在和接收能力,同时也确认了客户端的接收能力。
    • 第三次握手(ACK):客户端接收到SYN-ACK报文后,发送一个ACK标志的TCP报文段,确认收到了服务器的SYN-ACK报文。这一步最终确认了服务器的发送能力和客户端的接收能力。在这里插入图片描述
  • 为什么两次握手不行?
    客户端发送一个连接的请求报文,但由于网络不好,这个请求没有及时到达服务端,而是在某个网络节点滞留了,直到某个时间才到达服务端,本来这已经是一个失效的报文,但服务端接收到这个请求报文后,还是会向客户端发出确认的报文,表示同意连接。假如不采用三次握手,那么只要服务端发出确认,新的建立就连接了,但其实这个请求是失效的,客户端是不会理睬服务端的确认信息,也不会向服务端发送确认请求,但服务端认为新的连接已经建立,并一直等待客户端发来的数据,这样服务端的很多资源会白白浪费掉

3.TCP为什么要四次挥手?

四次挥手是指在TCP协议中,当一端完成其数据发送任务后,双方释放连接的过程,通过发送和确认四个不同的控制报文来完成TCP连接的终止。

  • 第一次挥手(主动关闭方发送FIN):
    主动关闭方(通常是客户端)发送一个FIN(Finish)标志位设置为1的TCP报文段,告诉接收方(通常是服务器)它已经没有数据要发送 了,但此时它仍可以接收数据。
  • 第二次挥手(被动关闭方发送ACK):接收方收到FIN报文后,会发送一个ACK报文作为回应,确认序号是收到 的序列号+1,同时接收方进入CLOSE_WAIT(关闭等待)状态。此时,接收方若发送数据,继续发送,直到发送完毕。
  • 第三次挥手(被动关闭方发送FIN):当接收方没有数据要发送时,它会发送自己的FIN报文,这时,接收方变为主动关闭方。这一报文也作为一个结束数据发送的信号。
  • 第四次挥手(主动关闭方发送ACK) :主动关闭方收到FIN报文后,同意发送一个ACK报文作为回应,确认序号是收到的序列号+1,此时,主动关闭进入TIME_WAIT(时间等待)状态。需要经过时间等待计时器设置的时间2MSL后,才能回到CLOSED状态。2MSL的时间长度是为了确保被动关闭方能够收到ACK报文,从而正确关闭连接。在这里插入图片描述
    为什么要四次挥手:
  • 因为当服务端收到客户端的SYN连接请求报文后,可以直接发送SYN+ACK报文。其中ACK报文是用来应答的,SYN报文是用来同步的。但是关闭连接时,当服务端收到FIN报文时,很可能并不会立即关闭SOCKET,所以只能先回复一个ACK报文,告诉客户端,“你发的FIN报文我收到了”。只有等到我服务端所有的报文都发送完了,我才能发送FIN报文,因此不能一起发送。故需要四次挥手。

4.UDP如何实现可靠传输

  • 应用层确认机制:在应用层上,可以实现自定义的确认机制。发送方在发送数据后等待接收方的确认信息,如果在一定时间内未收到确认,则重新发送数据。这样可以确保数据的可靠传输。
  • 超时重传:发送方可以设置一个超时计时器,如果在指定时间内未收到确认信息,则认为数据丢失,触发重传操作。
  • 数据校验和重传:在UDP数据包中添加校验和字段,接收方在接收数据时计算校验和并与发送方的校验进行比较。如果不匹配,则要求发送方重新发送数据。
  • 流量控制和拥塞控制:通过控制发送数据的速率和接收数据的处理速度,可以避免网络拥塞和数据丢失。这可以通过动态调整发送速率、使用滑动窗口等方法来实现。

5.OSI的七层模型都有哪些?每层的作用是什么?

  • 第七层:应用层
    • 功能:为应用程序提供网络服务,如文件传输、电子邮件等。它还负责处理与应用程序相关的数据格式和编码。
    • 协议:HTTP、FTP、SMTP等。
  • 第六层:表示层
    • 功能:处理数据的表示形式,如数据加密解密和压缩,确保数据在发送和接收端的表示一致。
    • 协议:JPEG、ASCII等。
  • 第五层:会话层
    • 功能:管理绘画的建立、维护和终止,包括同步会话和恢复会话数据
    • 协议:SQL等
  • 第四层:传输层
    • 功能:提供端到端的数据传输服务,确保数据的可靠、顺序传输,以及错误检测和恢复。
    • 协议:TCP和UDP
  • 第三层:网络层
    • 功能:负责数据包的路由选择,将数据从源网络传输到目的网络,处理逻辑寻址和路径选择。
    • 协议:IP、ICMP等
  • 第二层:数据链路层
    • 功能:提供物理链路上无差错的数据传输,处理数据帧的封装和解封装,实现介质访问控制和错误检测。
  • 第一层:物理层
    • 功能:负责比特流的传输,定义了网络的物理接口、电气特性、机械特性、功能特性和过程特性。

OSI模型的每层都与相邻的上层和下层进行通信,每层都提供了一定程度的抽象,使得上层不必关心下层的具体实现细节。

6.forward和redirect的区别?

在Web开发中,特别是适用Servlet或类似的Web框架时,forward和redirect是两种常用的方法来控制浏览器的行为,它们用于将请求从一个资源转发到另一个资源。
forward(请求转发)

  • 服务器端处理:forward是服务器端的内部操作,由Servlet容器执行,当一个Servlet调用RequestDispatcher.forward()方法时,当前请求会被转发到另一个请求,但整个过程中浏览器的地址栏不会发生变化。
  • 会话数据保持:在请求转发过程中,原始请求的所有数据都会被保持并传递到转发的目标资源。这就意味着在目标资源中可以直接访问原始请求的参数和会话数据。
  • 性能: forward通常比redirect更高效,因为它不需要重新发起HTTP请求,所有处理都在服务器端完成,减少网络开销。

redirect(重定向)

  • 客户端处理:redirect是通过发送一个HTTP 302状态码和一个Location头来指示浏览器重新发送一个请求到新的URL。这意味着浏览器地址栏会更新为目标资源的URL。
  • 会话数据:redirect不会自动携带原始请求的数据,这意味着原始请求的参数和会话数据不会自动传递到重定向的目标资源。如果需要传递数据,通常需要通过URL参数或使用会话管理机制。
    • 性能:redirect需要向浏览器发起一个新的HTTP请求,因此可能比forward慢,因为涉及额外的网络往返。

总结:

  • forward和redirect的主要区别在于处理的位置(服务端和客户端)、URL地址栏的变化、以及会话数据的传递。
  • 选择使用forward还是redirect取决于具体的应用场景。例如,如果需要保持请求的上下文和会话数据,同时优化性能,通常会选择forward。而如果需要改变浏览器的URL地址,或者需要用户看到一个新的页面URL,或者在不同域之间跳转,redirect则更为合适。

7.HTTP响应码301和302代表的是什么有什么区别?

HTTP响应状态码301和302都是用来指示客户端(通常是浏览器)重定向到另一个资源的。但是有一些重定向的持久性和缓存行为上的区别。

  • HTTP 301 Moved Permanently
    • 含义:301状态码表示请求的资源已被永久移动到新的URI,未来的请求应该使用响应中的新URI。
    • 持久性:301重定向是永久性的,这意味着搜索引擎和其他客户端会更新他们的链接数据库,指向新的URI。
    • 缓存:301重定向可以被缓存,这意味着如果客户端之前缓存了这个响应,它会记住新的URI,以后直接使用而不需要再次重定向。
  • HTTP 302 Found(临时重定向)
    • 含义:302状态码表示请求的资源现在临时位于不同的URI。客户端应使用响应中的新URI来获取请求的资源,但是未来的请求应该仍然使用原来的URI
    • 持久性:302重定向是临时的,搜索引擎和其他客户端不会更新它们的链接数据库,而是继续使用原始的URI
    • 缓存:302重定向通常不被缓存,或者如果缓存,有效期很短,这意味着每次请求可能都需要进行重定向检查。

8.get和post请求有什么区别?

特性GET请求POST请求
数据传输位置参数包含在URL中参数放在请求体中
数据可见性数据在URL可见数据在请求体中,不可见
安全性较低,不适合传输敏感信息较高,适合传输敏感信息
缓存可以被缓存通常不被缓存
幂等性应该是幂等的,即多次请求结果相同不一定是幂等的
URL长度限制URL长度有限制,通常不超过2048个字符没有固定长度限制,但可能受服务器限制
收藏URL可以被收藏请求体重的数据无法通过URL直接访问,不适合收藏
用途用于获取资源,查询信息用户提交数据,修改和创建资源
重发行为可以安全地重发,如刷新页面重发可能会导致数据重复提交,如表单重复提交

总结:GET和POST是HTTP协议中最常用的两种请求方法,它们在数据传输、安全性、缓存和幂等性上有显著区别。GET请求将参数嵌入URL中,适用于获取信息,数据可见,可以被缓存,且应该是幂等的。然而,它不适合传输敏感信息,因为数据可能被保存在历史记录或日志中。相比之下,POST请求将参数放在请求体中,更加安全,适合传输大量数据和敏感信息,但通常不会被缓存,且不一定幂等。此外,GET请求的URL可以被书签收藏,而POST请求的URL通常不被收藏,因为请求体中的数据无法直接通过URL访问。

9.如何实现跨域?

跨域:在前端领域中,跨域是指浏览器允许向服务器发送跨域请求,从而克服Ajax只能同源使用的限制。
解决办法:

  • JSONP(JSON with Padding)
    • 原理:利用script标签不受同源策略限制的特性,通过动态插入script标签来实现跨域请求。JSONP请求通常通过在URL中附加一个回调函数名作为参数,服务器响应时会将数据包裹在这个函数调用中返回。
    • 限制:仅支持GET请求,不适合POST等其他HTTP方法
  • CORS(Cross-Origin Resource Sharing)
    • 服务器配置:在服务器端响应头中添加Access-Control-Allow-Origin字段,指定允许访问的源,可以是具体的域名,也可以是通配符*表示所有源。
    • 预检请求:对于某些HTTP请求(如PUT、DELETE等),浏览器会先发送一个预检请求来确认跨域请求是否安全。服务器需要再预检请求的响应中包含Access-Control-Allow-Methods和Access-Control-Allow-Headers信息。
  • 代理服务器
    • 原理:在服务器端或本地搭建一个代理服务器,所有跨域请求先发送到代理服务器,由代理服务器转发请求到目标服务器,获取响应后再返回给前端。这样前端请求看起来像是同源请求。
    • 实现:可以使用Node.js的Express框架配合相关中间件(如http-proxy-middleware),或Apache、Nginx等反向代理服务器来实现。
  • 使用WebSocket
    • 原理:WebSocket协议本身不受同源策略限制,可以用于实现跨域的实时通信
    • 实现:客户端与服务器建立WebSocket连接,之后的数据传输不受同源策略约束。

总结:(面试回答)

  • 跨域问题源于浏览器的同源策略,限制了不同源之间JavaScript的交互。为了解决这个问题,有多种方法可以实现跨域请求。其中,JSONP利用script标签的特性实现GET请求的跨域,但不支持其他HTTP方法。CORS通过在服务器端响应头中添加特定字段,允许指定源的跨域请求,对于PUT、DELETE等方法的跨域请求,CORS还支持预检请求机制,确保安全。代理服务器方案通过搭建一个中间服务器,将跨域请求转换为同源请求,适用于复杂场景。WebSocket和Server-Sent Events则提供了不受同源策略限制的实时通信渠道。在实际应用中,CORS因其灵活性和安全性,成为首选的跨域解决方案。

10.TCP流量控制,拥塞控制

  • 流量控制:是TCP协议中的一项重要功能,它通过滑动窗口机制确保数据的平稳流动。发送方根据接收方的反馈(即ACK确认应答)和窗口大小来调整数据发送的速率,以防止数据积压和缓冲区溢出。
  • 拥塞控制:是TCP协议中的另一项核心功能,它通过慢启动、拥塞避免、快速重传和快速恢复等机制来监测和调整网络中的数据流量,以防止网络拥塞。慢启动算法帮助网络逐步适应数据流量,而拥塞避免则确保在达到一定阈值后,流量的增长更加平缓。快速重传和快速恢复机制则允许在检测到网络拥塞时快速响应,通过减少发送窗口大小和智能重传来恢复正常的流量水平。

11.ip协议,icmp协议,arp协议的作用

  • IP协议是互联网的核心,它负责数据包的封装、寻址和路由,使数据能够跨越不同的网络到达目的地
  • ICMP协议则作为IP协议的补充,用于错误报告和网络监控,帮助我们诊断网络问题并进行网络管理。
  • ARP协议(Address Resolution Protocol 地址解析协议)则在局域网环境中起着关键作用,它将IP地址转换为MAC地址,确保数据包能够在物理网络中正确传输。

12.http的不同版本和https的理解

  • HTTP的发展经历了从HTTP/1.0到HTTP/2等多个版本,每个版本都在不断提高网络通信的效率和性能。HTTP/1.1引入了持久连接和管道化请求,大大提升了多请求的处理效率。而HTTP/2通过二进制分帧、多路复用和头部压缩等技术,进一步提高了资源加载的速度,特别是在移动网络和高延迟网络环境下表现更佳。
  • HTTPS则是HTTP协议的安全版本,它通过SSL/TLS协议为HTTP通信提供了加密保护。HTTPS不仅可以保护数据免遭窃听和篡改,还可以通过数字证书验证服务器的身份,建立用户对网站的信任。HTTPS已经成为现代Web应用的标配,尤其是在涉及敏感信息传输的场景下,如在线支付、个人信息提交等。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

5款免费写作神器,高效率自动生成文章

在当今数字化的时代,写作变得越来越重要,而各种免费的写作神器也应运而生,为创作者们提供了极大的便利。以下是本文为大家详细介绍5个免费写作神器,帮助大家提高写作效率,让创作不再烦恼。 1、火呱ai写作 这是一款综合…

MySQL事务,锁,MVCC总结

mysql中最重要的就是事务,其四大特性让我们维持了数据的平衡,一致。那么事务究竟是什么,与什么相关,他的使用步骤,以及使用过程中我们会遇到什么问题呢?下面我们一起学习交流! 1.MySQL的存储引擎&#xff…

Redis学习[7] ——如何使用Redis实现分布式锁?

如何用Redis实现分布式锁? 9.5.1 为什么Redis能用来实现分布式锁? 分布式锁是用于分布式环境下并发控制的一种机制,用于控制某个资源在同一时刻只能被一个应用所使用。如下图所示: Redis可以被多个客户端共享访问,可…

jenkins自动化构建docker镜像并上传至harbor仓库

1、插件下载 首先进入jenkins之后需要现在“Maven”、“GitLab”、“Jdk”、“SSH”、“Git”的相关插件,这里不再赘述,需要什么插件直接安装即可 搜索对应插件后选择直接安装即可 2、系统全局配置 2.1 Maven配置 配置maven安装的相应的setting文件 …

How does age change how you learn?(2)年龄如何影响学习能力?(二)

Do different people experience decline differently? 不同人经历的认知衰退会有不同吗? Do all people experience cognitive decline uniformly?Or do some people’s minds slip while others stay sharp much longer? 所有人经历的认知衰退都是一样的吗?还是有些人…

计时器(Python)

代码 import time from tkinter import ttk import threading from tkinter import scrolledtext import tkinter as tkclass TimerApp:def __init__(self, root):self.root rootself.root.title("计时器")self.screen_w, self.screen_h self.root.winfo_screenwi…

Conditional Detr

encoder和detr相同,只修改了decoder部分。

(STM32笔记)九、RCC时钟树与时钟 第一部分

我用的是正点的STM32F103来进行学习,板子和教程是野火的指南者。 之后的这个系列笔记开头未标明的话,用的也是这个板子和教程。 九、RCC时钟树与时钟 九、RCC时钟树与时钟1、时钟树HSE时钟HSI时钟锁相环时钟系统时钟HCLK时钟PCLK1时钟PCLK2时钟RTC时钟独…

iPhone苹果手机Safari浏览器怎么收藏网页?

iPhone苹果手机Safari浏览器怎么收藏网页? 1、iPhone苹果手机上找到并打开Safari浏览器,并访问要收藏的网页; 2、打开网页后,点击导航上的更多功能; 3、在更多里,找到并点击添加到个人收藏,完成储存即可添…

2023华为od机试C卷【分配土地】Python实现

思路: 我们可以用哈希结构,此题适合用字典,键为出现的非零数字,值为列表,列表为【minrow,maxrow,minrol,maxrol] import sys def main():m,n map(int,input().split())rects {}for i in range(m):nums [int(i) f…

EFK之filebeat用法进阶

接上一章节:https://blog.csdn.net/weixin_46546303/article/details/140279197?spm1001.2014.3001.5501 一、filebeat module 输入流 1.filebeat module作用 Filebeat 模块的主要作用是简化日志数据的收集和处理过程。通过使用模块,你可以快速地配置…

java计算机毕设课设—网上招聘系统(附源码、文章、相关截图、部署视频)

这是什么系统? java计算机毕设课设—网上招聘系统(附源码、文章、相关截图、部署视频) 网上招聘系统的设计与实现旨在提供一个便捷、高效的在线平台,使个人求职者和公司能够有效地进行职位申请和人才招聘。该系统特别设计了两种…

Golang | Leetcode Golang题解之第318题最大单词长度乘积

题目&#xff1a; 题解&#xff1a; func maxProduct(words []string) (ans int) {masks : map[int]int{}for _, word : range words {mask : 0for _, ch : range word {mask | 1 << (ch - a)}if len(word) > masks[mask] {masks[mask] len(word)}}for x, lenX : ra…

狮子鱼 CMS ApiController.class.php SQL 注入漏洞

本章提供的所有内容仅供学习、交流和分享用途&#xff0c;只供参考。本站资源禁止并谢绝未经本站许可的使用&#xff0c;如若欲转载&#xff0c;请署名以及注明出处&#xff0c;请务必以文字链接的形式标明或保留文章原始出处和作者的信息。本站(原创)文章、资源、图片等所有内…

嵌入式全栈开发学习笔记---数据结构(顺序表)

目录 顺序结构 顺序表初始化 顺序表插入 顺序表遍历操作 顺序表前驱和后继 顺序表查找操作 顺序表删除操作 顺序表清空销毁 顺序表销毁操作 完整代码 List.c List.h Main.c 顺序表优缺点&#xff08;面试可能会考&#xff09; 上一节我们介绍了数据结构的一般概念…

【ModelSim】仿真问题记录

1、波形出不全&#xff1a; 1、甚至连clk波形都出不来 2、个别波形只有到仿真结束的时候才出现 解决办法&#xff1a; 1、添加波形需要是实例中的net 2、排查是否存在声明与示例的位宽不一致的信号 3、观察是否存在未初始化的变量寄存器 4、缩短整个仿真的步长 2、Instance列…

【HBZ分享】spring启动时自动装配的位置

自动装配流程 springboot启动时&#xff0c;自动装配逻辑在SpringBootApplication这个符合注解中的EnableAutoConfiguration新版springboot3会扫描META-INF的spring文件夹下的org.springframework.boot,autoconfigure,AutoConfiguration.imports文件&#xff0c;会把这里所有写…

FSMC--灵活的静态存储控制器

&#xff08;1&#xff09;在STM32F1系列&#xff08;及F407&#xff09;的芯片上封装了FSMC外设&#xff0c;支持拓展SARM作为RAM。 &#xff08;2&#xff09;SRAM和SDRAM的区别&#xff1a; 存储结构&#xff1a;SRAM使用锁存器、SDRAM使用电容通讯方式&#xff1a;SRAM多…

Leaf分布式ID

文章目录 系统对Id号的要求UUIDsnowflakeLeafLeaf-snowflakeLeaf-segmentMySQL自增主键segment双buffer 系统对Id号的要求 1、业务 1&#xff09;全局唯一性&#xff1a;不能出现重复的ID号&#xff0c;既然是唯一标识&#xff0c;这是最基本的要求 2&#xff09;趋势递增&a…

使用LLM(Large Language Model)进行主题建模

随着互联网技术的快速发展&#xff0c;自然语言处理&#xff08;NLP&#xff09;领域取得了显著的进步。其中&#xff0c;大型语言模型&#xff08;LLM&#xff09;在文本生成任务中表现尤为抢眼。本文旨在探讨LLM在主题建模方面的优势&#xff0c;以及如何将其应用于文本生成任…