当前位置: 首页 > news >正文

Node.js 中http 和 http/2 是两个不同模块对比

1. 核心模块对比

特性http 模块 (HTTP/1.1)http2 模块 (HTTP/2)
协议版本HTTP/1.1(文本协议)HTTP/2(二进制协议)
多路复用不支持(需多个 TCP 连接)支持(单连接多流)
头部压缩HPACK 压缩算法
服务器推送不支持支持
TLS 依赖可选(但生产环境建议启用)强制要求 TLS(可通过 allowHTTP1 降级)
Node.js 版本所有版本8.4.0+(实验性),10.0.0+(稳定)

2. 使用场景

  • http 模块

    • 传统 HTTP/1.1 服务
    • 简单请求/响应模型
    • 需要兼容旧客户端或代理
    • 无需 HTTP/2 高级特性
  • http2 模块

    • 高并发场景(如 API 服务、实时应用)
    • 需要减少延迟(多路复用)
    • 传输大量重复头部(如 Cookies)
    • 服务器推送资源(如提前发送 CSS/JS)

3. 代码示例

HTTP/1.1 服务器
const http = require('http');const server = http.createServer((req, res) => {res.writeHead(200, { 'Content-Type': 'text/plain' });res.end('Hello HTTP/1.1!');
});server.listen(3000, () => {console.log('HTTP/1.1 server on port 3000');
});
HTTP/2 服务器(需 TLS)
const http2 = require('http2');
const fs = require('fs');const server = http2.createSecureServer({key: fs.readFileSync('localhost-privkey.pem'),cert: fs.readFileSync('localhost-cert.pem'),allowHTTP1: true // 允许 HTTP/1.1 降级
});server.on('stream', (stream, headers) => {stream.respond({'content-type': 'text/html',':status': 200});stream.end('<h1>Hello HTTP/2!</h1>');
});server.listen(3001, () => {console.log('HTTP/2 server on port 3001');
});

4. 关键注意事项

  1. 证书要求

    • HTTP/2 默认需要 TLS,可通过 insecure 选项禁用(仅限开发环境):
      const server = http2.createServer({ insecure: true });
      
  2. 客户端兼容性

    • 使用 http2.connect() 连接 HTTP/2 服务器:
      const client = http2.connect('https://localhost:3001');
      const req = client.request({ ':path': '/' });
      req.on('response', (headers) => {// 处理响应
      });
      
  3. 性能优化

    • 启用 settings 配置优化流控:
      server.on('session', (session) => {session.settings({enablePush: true,initialWindowSize: 65535});
      });
      

5. 迁移建议

  1. 渐进式迁移

    • 使用 allowHTTP1: true 让服务器同时支持 HTTP/1.1 和 HTTP/2。
    • 通过 ALPN 协议自动协商版本。
  2. 工具链支持

    • 使用 curl --http2 或 Postman 测试 HTTP/2。
    • 监控工具:Wireshark 或 nghttp2 -v

官方文档

  • Node.js HTTP 模块
  • Node.js HTTP/2 模块

如果需要更具体的场景实现(如双向流、动态推送),请提供详细需求!

http://www.lryc.cn/news/588657.html

相关文章:

  • AutoGPT vs BabyAGI:自主任务执行框架对比与选型深度分析
  • python的形成性考核管理系统
  • 1.easypan-登录注册
  • P3842 [TJOI2007] 线段
  • 基于多智能体强化学习的医疗检索增强生成系统研究—MMOA-RAG架构设计与实现
  • 编程技能:多文件编译
  • c++图形题练习程序
  • LVS三种模式实战
  • 图机器学习(6)——图自编码器
  • 【电脑】显卡(GPU)的基础知识
  • 【轨物方案】当补贴退潮,光伏电站如何回归价值本质?
  • MySQL数据库----函数
  • 【PTA数据结构 | C语言版】二叉树前序序列化
  • 跨平台游戏引擎 Axmol-2.7.1 发布
  • git起步
  • 微信小程序翻书效果
  • 《汇编语言:基于X86处理器》第8章 高级过程(1)
  • 基于UDP/IP网络游戏加速高级拥塞控制算法(示意:一)
  • 力扣-使用双指针的方法的题们(持续更新中。。。
  • 一、CV_图像分类简介
  • Typecho插件开发:优化文章摘要处理短代码问题
  • 基于redis的分布式锁 lua脚本解决原子性
  • 银河麒麟服务器版挂载镜像文件
  • sqli-labs靶场通关笔记:第18-19关 HTTP头部注入
  • exe直接传输会导致文件损坏
  • 【html常见页面布局】
  • AI应用服务
  • Axios 完整功能介绍和完整示例演示
  • 分布式全局唯一ID生成:雪花算法 vs Redis Increment,怎么选?
  • gRPC实战指南:像国际快递一样调用跨语言服务 —— 解密Protocol Buffer与HTTP/2的完美结合