HTTP进化史:从HTTP1的简单到HTTP3的强大

news2024/11/25 22:57:14

在这里插入图片描述

文章目录

  • 📈I. HTTP1
    • ⚡A. 基本特点
    • ⚡B. 特点
    • ⚡C. 优缺点
  • 📈II. HTTP2
    • ⚡A. 基本特点
    • ⚡B. 特点
    • ⚡C. 优缺点
  • 📈III. HTTP3
    • ⚡A. 基本特点
    • ⚡B. 特点
    • ⚡C. 优缺点
  • 📈IV. 总结
  • 📈附录:「简历必备」前后端实战项目(推荐:⭐️⭐️⭐️⭐️⭐️)

📈「作者简介」:前端开发工程师 | 蓝桥云课签约作者 | 技术日更博主 | 已过四六级
📚「个人主页」:阿珊和她的猫
🕐「简历必备」前后端实战项目(推荐:⭐️⭐️⭐️⭐️⭐️)

  • Vue.js 和 Egg.js 开发企业级健康管理项目
  • 带你从入门到实战全面掌握 uni-app

📈I. HTTP1

⚡A. 基本特点

  1. 请求-响应模型
  2. 无状态协议
  3. 明文传输

⚡B. 特点

  1. 使用明文传输,不加密
  2. 阻塞式连接,每次请求需要建立和关闭连接
  3. 每个请求使用一个独立的 TCP 连接
  4. 不支持请求和响应的多路复用
  5. 头部信息冗余,每个请求都包含完整的头部

⚡C. 优缺点

  1. 优点:简单、易于理解和实现
  2. 缺点:性能较差,不适合处理大量并发请求和高负载情况

以下是一个使用HTTP/1的简单案例:

假设你有一个网站,想要在用户请求时返回一段文本内容。你可以通过HTTP/1协议来实现。

首先,你需要一个能够监听HTTP请求的服务器。可以使用Python中的http.server模块来创建一个简单的HTTP服务器。

# server.py

from http.server import BaseHTTPRequestHandler, HTTPServer

class MyHTTPRequestHandler(BaseHTTPRequestHandler):
    def do_GET(self):
        self.send_response(200)  # 设置响应状态码为200
        self.send_header('Content-type', 'text/plain')  # 设置响应头部的Content-type字段
        self.end_headers()
        response = "Hello, World!"  # 定义要返回的文本内容
        self.wfile.write(response.encode())  # 将文本内容作为响应发送给客户端

def run():
    server_address = ('', 8000)  # 服务器监听的地址和端口
    httpd = HTTPServer(server_address, MyHTTPRequestHandler)
    print('Starting server...')
    httpd.serve_forever()

if __name__ == '__main__':
    run()

保存上述代码为server.py,然后运行该文件启动服务器。

接下来,打开浏览器,在地址栏中输入http://localhost:8000,并发送GET请求。服务器将返回一段文本内容"Hello, World!"作为响应。

这个例子中,我们创建了一个自定义的MyHTTPRequestHandler类,继承自BaseHTTPRequestHandler,用于处理HTTP请求。在do_GET方法中,我们设置了响应状态码为200,添加了Content-type响应头部字段,并发送了文本内容作为响应。最后,我们使用http.server.HTTPServer来创建服务器并持续监听请求。

注意:这只是一个简单的HTTP/1案例,实际应用中可能需要处理更多复杂的请求和响应操作。

📈II. HTTP2

⚡A. 基本特点

  1. 二进制传输
  2. 多路复用
  3. 请求优先级

⚡B. 特点

  1. 使用二进制格式传输,减少了数据大小
  2. 引入了多路复用,通过一个 TCP 连接并发处理多个请求
  3. 支持请求和响应的优先级设置
  4. 头部压缩,减少了请求头部的冗余数据
  5. 支持服务器推送,提前发送客户端可能需要的资源

⚡C. 优缺点

  1. 优点:性能提升,减少了延迟和带宽消耗
  2. 缺点:复杂度较高,对服务器资源要求较高

以下是一个使用HTTP/2的简单案例:

假设你有一个网站,你想要在用户请求时返回一张图片。你可以使用HTTP/2协议来实现。

首先,你需要一个支持HTTP/2的服务器。Nginx是一个常用的Web服务器,它可以配置为支持HTTP/2。

  1. 首先,安装并启动Nginx。具体的安装方法可以参考Nginx的官方文档。

  2. 配置Nginx以支持HTTP/2。打开Nginx的配置文件,一般位于/etc/nginx/nginx.conf。找到http块,并添加以下内容:

    http {
        # 其他配置项...
    
        server {
            listen 443 ssl http2;  # 监听443端口并启用HTTP/2
    
            ssl_certificate /path/to/certificate.crt;  # SSL证书路径
            ssl_certificate_key /path/to/private.key;  # SSL私钥路径
    
            location / {
                root /path/to/website;  # 网站根目录
                index index.html;
            }
        }
    
        # 其他配置项...
    }
    

    注意替换/path/to/certificate.crt/path/to/private.key为你的SSL证书和私钥的实际路径。同时,将/path/to/website替换为你的网站文件的实际路径。

  3. 保存并关闭Nginx的配置文件。

  4. 启动或重新加载Nginx服务,使配置生效。

  5. 在网站根目录下创建一个名为index.html的文件,并在其中插入一张图片的标签。

    <html>
    <head>
        <title>HTTP/2 Demo</title>
    </head>
    <body>
        <img src="path/to/image.jpg" alt="Image">
    </body>
    </html>
    

    path/to/image.jpg替换为你的图片文件的实际路径。

  6. 打开浏览器,输入你的网站地址(使用HTTPS协议),例如https://example.com。浏览器将使用HTTP/2协议请求你的网站,并将返回的数据进行解析和渲染。图片将在浏览器中显示出来。

这个例子中,我们使用Nginx作为服务器,并配置其支持HTTP/2。然后,在网站根目录下创建了一个HTML文件,其中包含了一张图片。当浏览器访问网站时,它会使用HTTP/2协议请求图片并渲染到页面上。

注意:这只是一个简单的HTTP/2案例,实际应用中可能需要处理更多复杂的请求和响应操作,以及其他HTTP/2提供的特性。

📈III. HTTP3

⚡A. 基本特点

  1. 使用 QUIC 协议
  2. 数据加密传输
  3. 完善的拥塞控制机制

⚡B. 特点

  1. 使用 QUIC(Quick UDP Internet Connections)协议取代 TCP
  2. 引入了数据加密,增强了安全性
  3. 改进的拥塞控制机制,提高网络传输性能
  4. 提供更好的流量多路复用和请求优先级管理

⚡C. 优缺点

  1. 优点:低延迟、更好的可靠性和安全性
  2. 缺点:较新的协议,兼容性和部署仍在发展中

📈IV. 总结

HTTP1、HTTP2 和 HTTP3 在性能、功能和安全性方面有明显的区别。

HTTP1 简单易用,但性能较差;
HTTP2 引入多路复用等机制提升了性能,但复杂度较高;
HTTP3 使用 QUIC 协议,提供更低延迟和更好的安全性,但兼容性仍在发展中。

以下是对HTTP/1.1、HTTP/2和HTTP/3的比较总结:

特点HTTP/1.1HTTP/2HTTP/3
协议类型文本协议二进制协议二进制协议
连接复用不支持支持支持
多路复用不支持支持支持
传输效率较低,由于串行传输较高,通过并行传输提升性能较高,通过并行传输提升性能
请求优先级不支持支持支持
首部压缩不支持支持支持
安全性无默认加密无默认加密默认加密(基于QUIC)
错误处理阻塞式非阻塞式,能在一个帧出错时继续解析后续帧非阻塞式,能在一个帧出错时继续解析后续帧

需要注意的是,HTTP/3是基于QUIC协议的,并且仍然处于实验阶段。此表格总结的是这三个版本的一般特性,实际应用中还可能有其他方面的差异和特点。

选择适合的协议取决于应用场景和需求。

📈附录:「简历必备」前后端实战项目(推荐:⭐️⭐️⭐️⭐️⭐️)

Vue.js 和 Egg.js 开发企业级健康管理项目
带你从入门到实战全面掌握 uni-app

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

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

相关文章

资深测试整理,APP专项测试方法总结,看这篇就够了...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 APP专项测试 1、…

我们建议您关注另外两个趋势性漏洞。

即 Windows 错误报告服务 (CVE-2023-36874) 和 Windows MSHTML 平台 (CVE-2023-32046) 中的权限提升漏洞。现实生活中就有利用这两个漏洞的案例。 危险之处 要利用 CVE-2023-36874&#xff0c;攻击者需要访问目标计算机&#xff0c;并能够在普通用户默认具有有限权限的计算机上…

ESP32 LVGL:使用图标解决图片过大存不下的问题

背景 在LVGL中&#xff0c;用将图片转为C语言数组的方式储存的时候&#xff0c;图片转换的数组过大&#xff0c;当图片过多时会出现存不下的问题。 因此&#xff0c;可以使用字库图标解决该问题。 方法 将PNG图片转为字库文件 首先&#xff0c;我们将图片通过PS转为SVG矢量…

鸟类识别系统python+TensorFlow+Django网页界面+卷积网络算法+深度学习模型

一、介绍 鸟类识别系统&#xff0c;使用Python作为主要开发语言&#xff0c;基于深度学习TensorFlow框架&#xff0c;搭建卷积神经网络算法。并通过对数据集进行训练&#xff0c;最后得到一个识别精度较高的模型。并基于Django框架&#xff0c;开发网页端操作平台&#xff0c;…

XPath 的基本概念

XPath 的基本概念 引言 1. XPath 的基本概念 1.1 节点 1.2 路径表达式 1.3 轴 2. XPath 的语法和使用方法 2.1 标签定位 2.2 属性定位 2.3 文本定位 2.4 谓语和运算符 3. 示例演示 3.1 示例 1 &#xff1a; Web 自动化测试 3.2 示例 2 &#xff1a;数据提取和处理 3.3 示例 3 &…

pdsh 2.29 安装

下载&#xff1a; wget https://storage.googleapis.com/google-code-archive-downloads/v2/code.google.com/pdsh/pdsh-2.29.tar.bz2解包&#xff1a; tar jxvf pdsh-2.29.tar.bz2 cd pdsh-2.29/安装&#xff1a; ./configure --prefix/u01/isi/pdsh-2.29/ --with-timeout6…

Spark编程-共享变量(广播变量和累加器)

共享变量是什么 Spark中的两个重要抽象一个是RDD&#xff0c;另一个就是共享变量。 在默认情况下&#xff0c;当Spark在集群的多个不同节点的多个任务上并行运行一个函数时&#xff0c;它会把函数中涉及到的每个变量&#xff0c;在每个任务上都生成一个副本。 但是&…

基于STM32 ARM+FPGA伺服控制系统总体设计方案(一)

设计需求 一套完整的伺服控制方案包括了上位机、驱控一体控制器和功率板三者。操作人员 通过上位机发送各种不同指令&#xff0c;然后控制器解析指令后执行相应的伺服功能&#xff0c;其次控 制器将驱动信号传输至功率板驱动电机&#xff0c;最后控制器采集反馈信息进行闭环…

为你带来全新的UGC体验!

当我们开始向更多 UGC 开放元宇宙&#xff0c;你们将有机会发现我们社区在 The Sandbox 中创造的一些令人惊叹的体验。 需要从你们自己的体验中获得灵感&#xff0c;或者只是想玩一些新东西&#xff1f;以下是我们的一些建造者几个月来的工作成果——现在就可以玩&#xff01; …

JVM学习

文章目录 1 JVM与Java体系结构1.0 Java发展重大事件1.1 虚拟机和Java虚拟机1.3 JVM整体结构1.4 Java代码执行流程1.5 JVM架构模型1.6 JVM的生命周期1.7 JVM发展历程 2 类加载子系统2.1 ClassLoader2.2 用户自定义类加载器2.2.1 为什么需要自定义类加载器2.2.2 自定义类加载器的…

Kong 服务和路由的添加

管理服务 这里参考DB-less-Mode&#xff0c;因为使用的是yaml配置文件的形式&#xff0c;所以所有的相关配置只需要往初始化的kong.yml文件中添加就可以了&#xff0c;就像nginx的配置文件 DB-less-Mode 创建服务 vim /etc/kong/kong.yml services: - name: my-service #…

排查思路----CPU占用过高

1、top查看cpu占用情况 %Cpu(s): 29.4 us, 24.1 sy, 0.0 ni, 10.1 id, 20.4 wa, 0.0 hi, 16.0 si, 0.0 st 发现wa和si都比较高 2、查wa高的问题 iostat -x 1 10%util 接近 100%&#xff0c;说明产生的I/O请求太多&#xff0c;I/O系统已经满负荷&#xff0c;该磁盘存在瓶颈。…

数据库性能优化中的表结构优化

数据库性能优化中的表结构优化 在数据库应用中&#xff0c;表结构的设计直接影响着数据库的性能。合理的表结构设计可以提高数据库的查询效率和性能&#xff0c;而不合理的表结构设计则可能导致查询效率低下、数据冗余、数据不一致等问题。因此&#xff0c;表结构优化是数据库…

智慧园区如何搭乘数字孪生这列快车?

无论是2022年的火爆的元宇宙还是今年出圈的ChatGPT&#xff0c;都体现着数字技术嵌入社会生活是大趋势&#xff0c;数字孪生作为智能技术的一大亮点&#xff0c;它在智慧园区中的应用会是怎样呢&#xff1f;今天我们就来聊一聊&#xff01; &#xff08;全文3000字&#xff0c;…

Star CCM+ 202206 (17.04) 详细安装步骤

首先下载win系统的安装包 阿里云盘&#xff1a; https://www.aliyundrive.com/s/WFfyvFhGxwK 提取码: x57w 百度云盘&#xff1a;https://pan.baidu.com/s/1qKgxYf2DGURCTW0rga8Xkw?pwdeiqi 提取码&#xff1a;eiqi &#xff08;资源来自网络&#xff0c;仅供个人学习交流&…

电脑提示找不到MSVCR120.dll 简单解决方法,亲测有效!

msvcr120.dll是windows系统的一部分&#xff0c;它是Windows操作系统中的一个动态链接库文件。该文件包含了一些在运行使用了C语言编写的程序时所需的函数和资源。当系统无法找到或加载msvcr120.dll文件时&#xff0c;会导致相关程序无法正常运行。 msvcr120.dll文件它提供了一…

25个高级SQL查询-基于特定排序标准对行进行排序

本专栏中的许多示例将基于以下员工表(employee)。只有少数例子将以其他表格为基础;在这些情况下,表格将与示例一起进行说明。 一、RANK 函数 RANK()函数是SQL中的窗口函数之一。窗口函数查看部分数据并计算该部分的结果。 RANK()函数根据提供的列为每一行指定一个等级…

C语言自定义类型详解(保姆级教学)

目录 1.结构体 1.1结构体的介绍 1.2结构体的声明 1.3特殊声明&#xff08;匿名结构体类型&#xff09; 1.4结构体自引用 1.5结构体变量的定义和初始化 1.6结构体内存对齐 1.7修改默认对其数 2.位段 2.1什么是位段 2.2位段的内存分配 3.枚举 3.1枚举的定义 3.2枚举…

第G1周:生成对抗网络(GAN)入门

目录 一、课题背景和开发环境二、理论基础1.生成器2. 判别器3. 基本原理 三、前期准备工作1. 定义超参数2.下载数据3. 配置数据 四、定义模型1. 定义鉴别器2. 定义生成器 五、训练模型1. 创建实例2. 训练模型3. 保存模型 &#x1f368; 本文为&#x1f517;365天深度学习训练营…

检测到目标Content-Security-Policy响应头缺失

详细描述 HTTP 响应头Content-Security-Policy允许站点管理者控制用户代理能够为指定的页面加载哪些资源。除了少数例外情况&#xff0c;设置的政策主要涉及指定服务器的源和脚本结束点。 Content-Security-Policy响应头的缺失使得目标URL更易遭受跨站脚本攻击。 解决办法 …