前端系列——nodejs环境下http2初尝试

in 编程
关注公众号【好便宜】( ID:haopianyi222 ),领红包啦~
阿里云,国内最大的云服务商,注册就送数千元优惠券:https://t.cn/AiQe5A0g
腾讯云,良心云,价格优惠: https://t.cn/AieHwwKl
搬瓦工,CN2 GIA 优质线路,搭梯子、海外建站推荐: https://t.cn/AieHwfX9

目的

http2出来也有段时间了,很多网站都已经实际应用了它,而我还活在http1.1的时代,趁着还年轻,记性还行,花点时间研究了http2在nodejs中的使用。

http2基础理论

http2使用现状

案例1:淘宝

clipboard.png

案例2:京东

clipboard.png

案例3:知乎

clipboard.png

案例4:二月的公司
不好意思,我们还没用上这么牛逼的协议。
clipboard.png

nodejs应用HTTP2协议

我参考了一个外国程序员和一个中国程序员的http2方案,然后对源码进行了调整,主要目的在于体验一把http2,没有很深的知识。如果你想深入了解node中http2的使用,请看这里:nodejs之http2大全

开发环境

mac: 10.12.6
node: v8.9.4

项目结构

├── index.js // 入口文件
├── package-lock.json 
├── package.json //配置
├── public // 前端资源文件
│   ├── bundle1.js
│   ├── bundle2.js
│   ├── index.html
│   └── network.png
├── src //服务端文件
│   ├── helper.js
│   └── server.js
└── ssl //证书
    ├── cert.pem
    └── key.pem

步骤

1、你必须要安装http2

npm i --save http2

2、生成ssl证书

我比较懒,就没有自己生成,用别人生成好的证书来测试。

3、项目中最核心的就是server文件

可以看到代码中用到了fs读取文件,helper也是获取文件的插件。和使用http1.1不同的是,这里导入的是http2,然后用http2.createSecureServer()创建一个服务器。注意它的语法: http2.createSecureServer(options, callback),options表示你的证书或者其他有关的配置选项,但是证书是必备的。

'use strict'
const fs = require('fs')
const path = require('path')
const http2 = require('http2')
const helper = require('./helper')

const PORT = process.env.PORT || 8080
const PUBLIC_PATH = path.join(__dirname, '../public')
const publicFiles = helper.getFiles(PUBLIC_PATH)

//创建HTTP2服务器
const server = http2.createSecureServer({
  cert: fs.readFileSync(path.join(__dirname, '../ssl/cert.pem')),
  key: fs.readFileSync(path.join(__dirname, '../ssl/key.pem'))
}, onRequest)

// Request 事件
function onRequest (req, res) {
    // 路径指向 index.html
  const reqPath = req.url === '/' ? '/index.html' : req.url
    //获取html资源
  const file = publicFiles.get(reqPath)
  // 文件不存在
  if (!file) {
    res.statusCode = 404
    res.end()
    return
  }
  
  res.stream.respondWithFD(file.fileDescriptor, file.headers)
}
server.listen(PORT)

4、写好服务端代码,剩下的事情就是启动项目,然后交给浏览器渲染html和加载资源。

5、关键点2 html文件
确保你的浏览器支持fetch,因为我没有用第三方支持库,for循环的作用是客户端向服务器发起100个请求,让我们更加直观的看到http2请求多个资源的情况。

<html>
<head>
  <meta charset="UTF-8">
</head>
<body>
  <h1>体验一把HTTP2</h1>
</body>
  <script src="https://segmentfault.com/a/1190000013184607/bundle1.js"></script>
  <script src="https://segmentfault.com/a/1190000013184607/bundle2.js"></script>
<script>
        for(var i=0;i<100;i++) {
            fetch('//localhost:8080/network.png');
        }
</script>
</html>

6、渲染结果

clipboard.png

clipboard.png

源码

http2-test

总结

从测试结果来看,可以回顾一下http2的知识,非常明显的一点是:同个域名只需要占用一个 TCP 连接,头部压缩需要抓包才能分析出来,还有服务端推送等功能,在这里没有做测试,如果你也想体验一把http2,下载源码安装好插件就能用了,同时也得注意你的开发环境是否支持。

本文内容很浅,想要了解更多http2的知识,可以去知乎搜相关文章和回答。

关注公众号【好便宜】( ID:haopianyi222 ),领红包啦~
阿里云,国内最大的云服务商,注册就送数千元优惠券:https://t.cn/AiQe5A0g
腾讯云,良心云,价格优惠: https://t.cn/AieHwwKl
搬瓦工,CN2 GIA 优质线路,搭梯子、海外建站推荐: https://t.cn/AieHwfX9
扫一扫关注公众号添加购物返利助手,领红包
Comments are closed.

推荐使用阿里云服务器

超多优惠券

服务器最低一折,一年不到100!

朕已阅去看看