0
点赞
收藏
分享

微信扫一扫

使用Pycharm

一点读书 2023-07-14 阅读 71

在这里插入图片描述

文章目录

📈I. HTTP1

⚡A. 基本特点

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

⚡B. 特点

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

⚡C. 优缺点

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

假设你有一个网站,想要在用户请求时返回一段文本内容。你可以通过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的服务器。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 使用 QUIC 协议,提供更低延迟和更好的安全性,但兼容性仍在发展中。

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

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

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

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

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

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

举报

相关推荐

0 条评论