NGINX HTTP/3 实验指南安装、配置与调优

一、HTTP/3 简介

  • 基于 QUIC:在 UDP 之上实现的多路复用传输,内置拥塞控制与前向纠错,无需三次握手即可恢复连接。
  • 零 RTT 重连:借助 TLS 1.3,实现连接恢复时的 0-RTT 数据发送(视底层库支持)。
  • 多路复用无队头阻塞:每个流独立拥塞控制,单流丢包不影响其他流。
  • 内置安全:QUIC 自带加密,TLS 与传输层紧密集成。

注意:当前模块为实验性功能(>=1.25.0),需自行评估风险。

二、环境与依赖

  1. NGINX ≥ 1.25.0 ,编译时加上 --with-http_v3_module
  2. QUIC 库:推荐 BoringSSL、LibreSSL 或 QuicTLS;若用 OpenSSL,则走兼容层,不支持早期数据(0-RTT)。
  3. 内核要求:Linux 5.7+(使用 eBPF 路由或 GSO 优化时)。

三、示例配置

nginx 复制代码
http {
    log_format quic '$remote_addr - $remote_user [$time_local] '
                    '"$request" $status $body_bytes_sent '
                    '"$http_referer" "$http_user_agent" "$http3"';

    access_log /var/log/nginx/quic_access.log quic;

    server {
        # 同端口同时监听 HTTP/3(UDP)和 HTTPS(TCP)
        listen 8443 quic reuseport;
        listen 8443 ssl;

        ssl_certificate     /etc/ssl/example.crt;
        ssl_certificate_key /etc/ssl/example.key;
        ssl_protocols       TLSv1.3;

        # 通知客户端支持 HTTP/3
        add_header Alt-Svc 'h3=":8443"; ma=86400';

        location / {
            root /var/www/html;
            index index.html;
        }
    }
}
  • listen ... quic:开启 QUIC(UDP)监听
  • add_header Alt-Svc:通过 Alt-Svc 通告浏览器可走 HTTP/3

四、核心指令详解

指令 默认值 作用
`http3 on off` on 全局/Server 级启用或关闭 HTTP/3 协商
`http3_hq on off` off 启用 HTTP/0.9 over QUIC,用于兼容性测试
http3_max_concurrent_streams 128
相关推荐
亿牛云爬虫专家1 天前
生产级Go高并发爬虫实战:突破 net_http 长连接与隧道代理IP切换陷阱
爬虫·http·golang·代理ip·keepalive·隧道代理·https connect
Crazy CodeCrafter1 天前
服装实体店现在还适合转电商吗?
大数据·运维·人工智能·经验分享·自动化·开源软件
西西弟1 天前
网络编程基础之TCP循环服务器
运维·服务器·网络·网络协议·tcp/ip
sanshanjianke1 天前
一种零成本的服务器磁盘空间扩展方法——内网磁盘映射到公网服务器的两种方案
运维·服务器
Mark White1 天前
深入理解 Linux 打印体系:CUPS、驱动、ULD 与 Docker 容器化
linux·运维·docker
我命由我123451 天前
U 盘里出现的文件 BOOTEX.LOG
运维·服务器·经验分享·笔记·学习·硬件工程·学习方法
舒一笑1 天前
我把前端从 /ais 改到 /kb 后,连续踩了 7 个 Nginx 坑(含 405/413/502/404 终极解法)
运维·nginx·程序员
IMPYLH1 天前
Linux 的 paste 命令
linux·运维·服务器·bash
Kk.08021 天前
Linux(十三)fork + exec进程创建
linux·运维·服务器
墨着染霜华1 天前
Linux 下查看 Java 服务进程占用(CPU / 内存)并定位具体服务
java·linux·运维