计算机网络-HTTP常见面试题
目录
- 1. HTTP是什么?
- 2. HTTP常见的状态码?
- 3. HTTP 常见的字段有哪些?
- 4. GET和POST有什么区别:
- 5. GET 和POST方法都是安全和幂等的吗?
- 6. HTTP缓存技术
- 7. HTTP/1.1相比HTTP/1.0提高了什么性能?
- 8. HTTP/2做了什么优化?
- 9. HTTP3做了哪些优化
- 10. SSL/TLS的握手过程
1. HTTP是什么?
超文本传输协议
- 协议:HTTP是一个用在计算机世界里面的协议,使用计算机能够理解的语言确立了一种计算机之间交流通信的规范以及错误的处理方式(两者参与)
- 传输:HTTP是一个在计算机世界里面专门用来在两点之间传输数据的约定和规范
- 超文本:文字、图片、视频等的混合体,能够从一个超文本跳转到另外一个超文本
总结:HTTP是一个在计算机世界里面专门用于两点之间传输文字、图片、视频等数据的规范和约定(服务器与服务器之间、服务器与客户端之间)
2. HTTP常见的状态码?
-
1xx 提示信息,协议处理的中间状态
-
2xx 服务器成功处理了客户端的请求
- 200 成功状态码 如果是非head请求,服务器返回的响应头会没有body数据
- 204 成功状态码 响应头没有body数据
- 206 成功状态码 分块下载或者断点续传的标识 标识服务器只返回了部分的body数据
-
3xx 资源位置发生了变动,需要重新发送请求获取资源(重定向)
- 301 永久重定向 请求资源不存在,需要改用新的URL进行访问(location字段标识指明要跳转的url)
- 302 临时重定向 暂时需要另外的URL来进行资源访问(location字段标识指明要跳转的url)
- 304 缓存重定向 重定向到已经存在的缓存文件,不会进行跳转
-
4xx 客户端发送的请求报文有误 服务器无法处理
- 400 整体概括客户端的请求报文有误
- 403 服务器禁止访问资源与客户端无关
- 404 请求资源服务器无法提供,找不到
-
5xx 服务器处理请求时内部发生的错误
- 500 整体概括服务器的错误
- 501 客户端请求的功能暂不支持,敬请期待
- 502 服务器作为网关或者代理时,服务器正常工作但是后端的服务发生了错误
- 503 服务器繁忙(大学抢课常态)
3. HTTP 常见的字段有哪些?
- Host:客户端发送请求时用来指定服务器的域名
- Content-Length:服务器本次响应的数据长度 解决TCP的粘包问题
- Connection:客户端要求服务器使用 HTTP长连接机制方便其他请求复用
- Content-Type:告诉客户端本次响应的数据是什么格式 (可以用Accept来声明你必须返回什么格式的数据)
- Content-Encoding:服务器返回的数据使用了什么压缩格式 (可以使用Accept-Encoding声明必须返回什么压缩格式)
4. GET和POST有什么区别:
- GET:
- 从服务器获取指定的资源(静态的文本、图片、音视频等)
- 请求参数在URL中,只能支持ASCLL字符,浏览器对URL的长度有限制
- POST:
- 根据请求体body对指定的资源做出处理
- body的数据格式可以是任意的,只要与服务端协商好就行
- 浏览器不会对body大小做出限制
5. GET 和POST方法都是安全和幂等的吗?
- 前置知识:
- 安全:请求方法不会对服务器上的资源造成不好的影响
- 幂等:多次执行相同的操作,结果都是相同的
- get方法是安全且幂等的,数据可以缓存到浏览器上且可以将get请求保存为书签;post方法相反
- HTTP传输的内容都是明文的,想要避免传输过程中数据被窃取就要使用HTTPS协议,这样所有的HTTP数据就会被加密传输
- 任何请求都是可以带body的,并不是说get请求不能带body,只能post请求带body
- url中的查询参数不是get所独有的,post请求的url中也可以有参数
6. HTTP缓存技术
两种实现方式:强制缓存 协商缓存
- 强制
- 利用响应头里面的Cache-control字段和Expires字段来实现的
- 浏览器第一次请求服务器资源是,服务器返回资源同时会在响应头上加上Cache-Control(设置过期时间);浏览器再次请求时会先通过请求资源的时间与Cache-control的时间进行比较计算是否过期,如果没有则使用缓存相反就重新请求服务器;服务器再次收到请求后,会再次更新响应头里面的Cache-Control的值
- 协商(未命中强制缓存的结果后才执行)
- 通过服务端告知客户端是否可以使用本地缓存的方式
- 实现方式有两种:第一种基于时间实现,但容易发生由于时间篡改导致的不可靠的问题;第二种基于一个唯一标识实现
- ETag的优先级更高:
- 没有修改文件内容的情况下文件最后的修改时间可能改变,导致客户端以为文件被改动了
- 有些文件是在秒级以内修改的,ETag能够保证这种需求下客户端在1秒内能刷新多次
- 有些服务器不能精确获取文件的最后修改时间
- ETag字段实现协商缓存的过程:
- 第一次请求服务器,会在响应头加上一个ETag唯一标识
- 再次请求首先检查是否过期,过期之后会在请求头加上一个IF-NONE-MATCH字段值就是ETag唯一标识
- 服务器再次收到请求之后,会根据请求头中的ETag唯一标识和当前资源的唯一标识进行比较;值相等返回304,使用缓存;不相等返回200与资源,并在响应头加上一个ETag唯一标识
- 客户端收到304的请求响应状态码从本地缓存加载资源,否则就更新资源
7. HTTP/1.1相比HTTP/1.0提高了什么性能?
- 提高:
- 使用长连接的方式改善了1.0短连接造成的性能开销
- 支持管道网络传输,可以同时发送多个请求,减少整体的响应时间
- 不足:
- 请求头响应头未经过压缩就发送,如果首部信息越多延迟就会越大(只能够压缩请求体的数据)
- 发送冗长的首部,频繁的返送相同的首部造成的浪费较多
- 服务器是按照请求的顺序响应的,如果服务器响应慢就会产生客户端队头阻塞的现象 【HTTP层的队头阻塞】
- 没有请求优先级的控制
- 请求只能从客户端开始,服务器只能被动响应
8. HTTP/2做了什么优化?
- 基于HTTPS的,所以他的安全性是有保障的
- 头部压缩
- 使用HPACK算法,在服务端和客户端同时维护一张头部信息表,所有字段都会存入这个表,生成一个索引号,如果有相同的字段直接发送索引号提高速度
- 如果你发送的头是一样的或者相似的,协议会帮助消除重复的部分
- 二进制格式
- 所有的报文都是二进制格式分为头部帧和数据帧,不在需要像1版本那样还要将其转为二进制,可以直接解析二进制报文,增加了数据传输的效率
- 并发传输
- 解决了1版本中的队头阻塞的问题
- 一个TCP连接里面可以有多个流,并且一个流里面可以有多个数据帧
- 针对不同的HTTP请求用唯一的流ID来进行区分,接收端根据这个ID有序组装HTTP的消息并且可以并行交错地发送请求和响应(乱序发送)
- 服务器主动推送资源
- 客户端和服务端都可以建立起Stream流,客户端建立的流必须是奇数,服务端必须是偶数(主动推送的)
- 客户端请求发送获取html,1版本还需要再次请求css文件,而当前版本服务端会主动的推送css文件减少了消息传递的次数
- 不足:
- 2版本是基于TCP协议来传输数据的,TCP是字节流协议,必须保证收到的字节数据是完整且连续的,这样内核才会将缓冲区里面的数据返回给HTTP应用(当前一个字节数据没有到达时 丢包,后面到达的字节数据只能存在缓冲区中等到这一个字节重传且到达之后,应用层才能够从缓冲区拿到数据) 【TCP层的队头阻塞】
9. HTTP3做了哪些优化
- 将TCP传输改为了UDP传输并配合QUIC协议实现TCP的可靠性传输
- QUIC协议特点
- 无队头阻塞
- 也是跟2版本的多路复用的概念类似,在同一个连接上并发传输多个流,当某个流发生丢包的时候只会阻塞这一个流,其他的流不会收到影响与2相反,多个流之间相互独立 只要数据一到达应用层就可以直接读取
- 更快的连接建立
- 1版本和2版本中的TCP和TLS没有结合在一起,所以在连接的时候需要分别进行握手,可能会存在3次的RTT或者2次的RTT
- QUIC协议里面握手过程只需要1RTT来确认双方的连接ID,3版本的QUIC协议不是与TLS分层的,包含了它在里面并且使用的时TLS1.3因此只需要1个RTT就可以完成连接的建立和密钥的协商 会话恢复的时候有效负载数据与第一个数据包一起发送可以实现0RTT的效果
- 连接迁移(基于连接ID实现)
- 当移动网络切换的时候必须进行断开重新建立连接,建立连接的过程2版本需要进行TCP三次握手和TLS四次握手的过程并且还要考虑TCP慢启动的减速过程这里就会产生较高的连接迁移成本
- QUIC协议没有使用四元组的方式来绑定连接,而是通过连接ID来标记通信两端的,因此网络变化之后只要互相保留了这个连接ID那么就能实现无缝的复用原连接没有丝毫卡顿
- QUIC是新的协议很多设备不知道什么是QUIC只会当作UDP,并且有的网络设备是会丢UDP包的,如果网络设备无法识别这是一个QUIC包那么就会当作UDP包然后被丢弃
- 无队头阻塞
10. SSL/TLS的握手过程
- TLS1.2
- 需要2个RTT往返时延,也就是4次握手
- TLS1.3
- 只需要1个RTT往返时延,也就是3次握手
相关文章:
计算机网络-HTTP常见面试题
目录 1. HTTP是什么?2. HTTP常见的状态码?3. HTTP 常见的字段有哪些?4. GET和POST有什么区别:5. GET 和POST方法都是安全和幂等的吗?6. HTTP缓存技术7. HTTP/1.1相比HTTP/1.0提高了什么性能?8. HTTP/2做了什…...

LNMP搭建Discuz和Wordpress
1、LNMP L:linux操作系统 N:nginx展示前端页面web服务 M:mysql数据库,保存用户和密码,以及论坛相关的内容 P:php动态请求转发的中间件 数据库的作用: 登录时验证用户名和密码 创建用户和密码 发布和…...
java中的构造器
Java 中的构造器(也称为构造方法)是一种特殊的方法,用于初始化对象的状态。在创建 Java 类的实例时,构造器会被自动调用。 构造器的定义: 构造器的名称必须与类名完全相同。构造器没有返回值类型,甚至不包括…...

机器学习筑基篇,Ubuntu 24.04 快速安装 PyCharm IDE 工具,无需激活!
[ 知识是人生的灯塔,只有不断学习,才能照亮前行的道路 ] Ubuntu 24.04 快速安装 PyCharm IDE 工具 描述:虽然在之前我们安装了VScode,但是其对于使用Python来写大型项目以及各类配置还是比较复杂的,所以这里我们还是推…...

从0开始基于transformer进行股价预测(pytorch版本)
目录 数据阶段两个问题开始利用我们的代码进行切分 backbone网络训练效果 感觉还行,没有调参数。源码比较长,如果需要我后续会发(因为太长了!!) 数据阶段 !!!注意&#…...

【多GPU训练方法】
一、数据并行 这是最常用的方法。整个模型复制到每个GPU上。训练数据被均匀分割,每个GPU处理一部分数据。所有GPU上的梯度被收集并求平均。通常使用NCCL(NVIDIA Collective Communications Library)等通信库实现。参数更新 使用同步后的梯度…...

2024年PMP考试备考经验分享
PMP是项目管理领域最重要的认证之一,本身是IT行业比较流行的证书,近几年在临床试验领域也渐渐流行起来,是我周围临床项PM几乎人手一个的证书。 考试时间:PMP认证考试形式为180道选择题,考试时间为3小时50分。 考试计划ÿ…...

MT3046 愤怒的象棚
思路: a[]存愤怒值;b[i]存以i结尾的,窗口里的最大值;c[i]存以i结尾的,窗口里面包含✳的最大值。 (✳为新大象的位置) 例:1 2 3 4 ✳ 5 6 7 8 9 则ans的计算公式b3b4c4c5c6b7b8b9…...

深入了解代理IP常见协议:区别与选择
代理服务器在网络使用中扮演着重要的角色,是您设备和互联网之间的中间层。它不仅可以增强网络访问的安全性和隐私保护,还可以提供许多灵活的应用。使用代理时,不同的协议类型对数据交换具有不同的规则和特征。常见的代理协议包括HTTP代理、HT…...

【Linux 线程】线程的基本概念、LWP的理解
文章目录 一、ps -L 指令🍎二、线程控制 一、ps -L 指令🍎 🐧 使用 ps -L 命令查看轻量级进程信息;🐧 pthread_self() 用于获取用户态线程的 tid,而并非轻量级进程ID;🐧 getpid() 用…...

Dify中的工具
Dify中的工具分为内置工具(硬编码)和第三方工具(OpenAPI Swagger/ChatGPT Plugin)。工具可被Workflow(工作流)和Agent使用,当然Workflow也可被发布为工具,这样Workflow(工…...

在Visutal Studio 2022中完成D3D12初始化
在Visutal Studio 2022中完成DirectX设备初始化 1 DirectX121.1 DirectX 简介1.2 DirectX SDK安装2 D3D12初始化2.1 创建Windwos桌面项目2.2 修改符合模式2.3 下载d3dx12.h文件2.4 创建一个异常类D3DException,定义抛出异常实例的宏ThrowIfFailed3 D3D12的初始化步骤3.1 初始化…...

MobaXterm工具
MobaXterm 是一个增强型的 Windows 终端。其为 Windows 桌面提供所有重要的远程网络终端工具(如 SSH、X11、RDP、VNC、FTP、SFTP、Telnet、Serial、Mosh、WSL 等),和 Unix 命令(如 bash、ls、cat、sed、grep、awk、rsync 等&#…...

二分图练习
对于二分图我们可以用染色法 #include<bits/stdc.h> using namespace std;#define int long long const int N 2e65; int e[N],ne[N],h[N],idx 0; int colo[N]; int num 0;void add(int x,int y){e[idx] y;ne[idx] h[x];h[x] idx; } void dfs(int nod,int c){colo…...

创新设计策略:提升大屏幕可视化设计效果的关键方法
随着科技的不断发展和数据量的快速增长,数据可视化大屏在各个行业中的应用越来越广泛,可以帮助人们更好地理解和分析数据,可视化大屏设计也因此成了众多企业的需求。但很多设计师对可视化大屏设计并不了解,也不知道如何制作可视化…...

论文 | Chain-of-Thought Prompting Elicits Reasoningin Large Language Models 思维链
这篇论文研究了如何通过生成一系列中间推理步骤(即思维链)来显著提高大型语言模型进行复杂推理的能力。论文展示了一种简单的方法,称为思维链提示,通过在提示中提供几个思维链示例来自然地激发这种推理能力。 主要发现࿱…...

[机器学习]-人工智能对程序员的深远影响——案例分析
机器学习和人工智能对未来程序员的深远影响 目录 机器学习和人工智能对未来程序员的深远影响1. **自动化编码任务**1.1 代码生成1.2 自动调试1.3 测试自动化 2. **提升开发效率**2.1 智能建议2.2 项目管理 3. **改变编程范式**3.1 数据驱动开发 4. **职业发展的新机遇**4.1 AI工…...

AI学习环境 没有更好的替代 - (Google)Drive + Colab
在开始正题前,请容许我做一番回顾,并夹带一点点私货(谷歌扛旗的开源精神还没有死,并且会是未来的举足轻重的力量) 卧龙凤雏,一时瑜亮。一切的缘起应该是世纪初的门户网站乱战。 彼时,谷歌是从…...

【观成科技】Websocket协议代理隧道加密流量分析与检测
Websocket协议代理隧道加密流量简介 攻防场景下,Websocket协议常被用于代理隧道的搭建,攻击者企图通过Websocket协议来绕过网络限制,搭建一个低延迟、双向实时数据传输的隧道。当前,主流的支持Websocket通信代理的工具有…...
DangerWind-RPC-framework---三、服务端下机
当一台机器下线时,面临很多问题:如何将其从注册中心下线?如何清理释放资源?客户端拉取服务列表时也使用了本地缓存,如何及时更新本地缓存? 服务端机器的优雅下线需要使用ShutdownHook,这相当于添…...
R语言AI模型部署方案:精准离线运行详解
R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...
什么是EULA和DPA
文章目录 EULA(End User License Agreement)DPA(Data Protection Agreement)一、定义与背景二、核心内容三、法律效力与责任四、实际应用与意义 EULA(End User License Agreement) 定义: EULA即…...

Android15默认授权浮窗权限
我们经常有那种需求,客户需要定制的apk集成在ROM中,并且默认授予其【显示在其他应用的上层】权限,也就是我们常说的浮窗权限,那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...

使用LangGraph和LangSmith构建多智能体人工智能系统
现在,通过组合几个较小的子智能体来创建一个强大的人工智能智能体正成为一种趋势。但这也带来了一些挑战,比如减少幻觉、管理对话流程、在测试期间留意智能体的工作方式、允许人工介入以及评估其性能。你需要进行大量的反复试验。 在这篇博客〔原作者&a…...

Linux 中如何提取压缩文件 ?
Linux 是一种流行的开源操作系统,它提供了许多工具来管理、压缩和解压缩文件。压缩文件有助于节省存储空间,使数据传输更快。本指南将向您展示如何在 Linux 中提取不同类型的压缩文件。 1. Unpacking ZIP Files ZIP 文件是非常常见的,要在 …...

【UE5 C++】通过文件对话框获取选择文件的路径
目录 效果 步骤 源码 效果 步骤 1. 在“xxx.Build.cs”中添加需要使用的模块 ,这里主要使用“DesktopPlatform”模块 2. 添加后闭UE编辑器,右键点击 .uproject 文件,选择 "Generate Visual Studio project files",重…...
面试高频问题
文章目录 🚀 消息队列核心技术揭秘:从入门到秒杀面试官1️⃣ Kafka为何能"吞云吐雾"?性能背后的秘密1.1 顺序写入与零拷贝:性能的双引擎1.2 分区并行:数据的"八车道高速公路"1.3 页缓存与批量处理…...

Vue3 PC端 UI组件库我更推荐Naive UI
一、Vue3生态现状与UI库选择的重要性 随着Vue3的稳定发布和Composition API的广泛采用,前端开发者面临着UI组件库的重新选择。一个好的UI库不仅能提升开发效率,还能确保项目的长期可维护性。本文将对比三大主流Vue3 UI库(Naive UI、Element …...

rm视觉学习1-自瞄部分
首先先感谢中南大学的开源,提供了很全面的思路,减少了很多基础性的开发研究 我看的阅读的是中南大学FYT战队开源视觉代码 链接:https://github.com/CSU-FYT-Vision/FYT2024_vision.git 1.框架: 代码框架结构:readme有…...
字符串哈希+KMP
P10468 兔子与兔子 #include<bits/stdc.h> using namespace std; typedef unsigned long long ull; const int N 1000010; ull a[N], pw[N]; int n; ull gethash(int l, int r){return a[r] - a[l - 1] * pw[r - l 1]; } signed main(){ios::sync_with_stdio(false), …...