Node.js学习教程之HTTP/2服务器推送【译】


Posted in Javascript onOctober 31, 2017

前言

最近Node.js v8.4+版本发布带来了体验版的HTTP/2,你可以自己通过设置参数--expose-http2启动。

这篇文章,我将介绍HTTP/2最重要的一方面服务器推送并且创建一个小的Node.js程序案例来使用它。下面话不多说了,来一起看看详细的介绍吧。

关于HTTP/2

HTTP/2 的目的是通过支持完整的请求与响应复用来减少延迟,通过有效压缩 HTTP 标头字段将协议开销降至最低,同时增加对请求优先级和服务器推送的支持。

更多关于HTTP/2内容,请查看文章HTTP/2。

服务器推送

HTTP/2 服务器推送(Server Push)允许服务器在浏览器请求之前将资源发送到浏览器。

在我们转到HTTP/2之前,我们来看看它如何与HTTP/1配合使用:

在HTTP/1中,客户端向服务器发送一个请求,服务器返回一个包含许多外部资源(.js,.css等文件)链接的HTML文件。当浏览器处理这个初始HTML文件时,它开始解析这些链接,并分别加载它们。

查看下面的demo加载过程的图像。 请注意时间表上的独立请求以及这些请求的启动:

Node.js学习教程之HTTP/2服务器推送【译】

HTTP/1资源加载

这是HTTP/1的工作原理,这就是我们如何开发这么多年的应用程序。为什么要改变它呢?

当前方法的问题是用户必须等待浏览器解析响应,发现链接并获取资源。 这会延迟渲染并增加加载时间。 有一些解决方案,如内联一些资源,但也使得初始响应越来越大。

这是HTTP/2服务器推送功能进入视线的地方,因为服务器可以在浏览器请求之前将资源发送到浏览器。
看看下面的图片,通过HTTP/2提供相同服务的网站。查看时间轴和启动器。 你可以看到HTTP/2复用减少了请求数量,并且资源与初始请求一起立即发送。

Node.js学习教程之HTTP/2服务器推送【译】

HTTP/2服务器推送

让我们看看今天如何在Node.js中使用HTTP/2服务器推送,来加快客户端的加载时间。

一个Node.js HTTP/2服务器推送案例

通过加载内置的http2模块,我们可以创建我们的服务器,就像我们使用https模块一样。

有趣的部分是在请求index.html时推送其他资源:

const http2 = require('http2') 
const server = http2.createSecureServer( 
 { cert, key },
 onRequest
)

function push (stream, filePath) { 
 const { file, headers } = getFile(filePath)
 const pushHeaders = { [HTTP2_HEADER_PATH]: filePath }

 stream.pushStream(pushHeaders, (pushStream) => {
 pushStream.respondWithFD(file, headers)
 })
}

function onRequest (req, res) { 
 // Push files with index.html
 if (reqPath === '/index.html') {
 push(res.stream, 'bundle1.js')
 push(res.stream, 'bundle2.js')
 }

 // Serve file
 res.stream.respondWithFD(file.fileDescriptor, file.headers)
}

这样bundle1.js和bundle2.js资源即使在它要求它们之前也会被发送到浏览器。

你可以查看完整的案例:https://github.com/RisingStack/http2-push-example

HTTP/2 & Node

HTTP/2可以帮助我们在很多方面优化我们的客户端与服务器之间的通信。

通过服务器推送,我们可以将资源发送到浏览器,减少用户的初始加载时间。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

原文:https://blog.risingstack.com/node-js-http-2-push/

译者:Jin

作者:Péter Márton

Javascript 相关文章推荐
自己开发Dojo的建议框架
Sep 24 Javascript
jquery 锁定弹出层实现代码
Feb 23 Javascript
基于jquery的回到页面顶部按钮
Jun 27 Javascript
JQuery中DOM事件绑定用法详解
Jun 13 Javascript
javascript实现相同事件名称,不同命名空间的调用方法
Jun 26 Javascript
jQuery实现高亮显示网页关键词的方法
Aug 07 Javascript
js将json格式的对象拼接成复杂的url参数方法
May 25 Javascript
如何防止INPUT按回车自动提交表单FORM
Dec 06 Javascript
详解vue.js全局组件和局部组件
Apr 10 Javascript
详解bootstrap用dropdown-menu实现上下文菜单
Sep 22 Javascript
js原生日历的实例(推荐)
Oct 31 Javascript
layui中使用jquery控制radio选中事件的示例代码
Aug 15 jQuery
详解Vue用自定义指令完成一个下拉菜单(select组件)
Oct 31 #Javascript
原生js实现仿window10系统日历效果的实例
Oct 31 #Javascript
ES6使用Set数据结构实现数组的交集、并集、差集功能示例
Oct 31 #Javascript
Vue实战之vue登录验证的实现代码
Oct 31 #Javascript
jQuery ajax读取本地json文件的实例
Oct 31 #jQuery
ES6解构赋值的功能与用途实例分析
Oct 31 #Javascript
js原生日历的实例(推荐)
Oct 31 #Javascript
You might like
微信公众号开发之微信公共平台消息回复类实例
2014/11/14 PHP
WordPress中用于获取搜索表单的PHP函数使用解析
2016/01/05 PHP
详解WordPress开发中用于获取分类及子页面的函数用法
2016/01/08 PHP
PHP分页初探 一个最简单的PHP分页代码的简单实现
2016/06/21 PHP
PHP中“=>
2019/03/01 PHP
PHP中有关长整数的一些操作教程
2019/09/11 PHP
JavaScript中的Document文档对象
2008/01/16 Javascript
遨游,飞飞,IE,空中网 浏览器无提示关闭方法
2011/07/11 Javascript
json数据的列循环示例
2013/09/06 Javascript
鼠标选择动态改变网页背景颜色的JS代码
2013/12/10 Javascript
将json对象转换为字符串的方法
2014/02/20 Javascript
自己使用js/jquery写的一个定制对话框控件
2014/05/02 Javascript
javascript实现鼠标放上后下边对应内容变换的效果
2015/08/06 Javascript
jQuery插件EasyUI校验规则 validatebox验证框
2015/11/29 Javascript
详解Webwork中Action 调用的方法
2016/02/02 Javascript
jquery中取消和绑定hover事件的实现代码
2016/06/02 Javascript
微信小程序 在Chrome浏览器上运行以及WebStorm的使用
2016/09/27 Javascript
Ionic 2 实现列表滑动删除按钮的方法
2017/01/22 Javascript
jQuery排序插件tableSorter使用方法
2017/02/10 Javascript
关于jquery form表单序列化的注意事项详解
2017/08/01 jQuery
vue动态绑定组件子父组件多表单验证功能的实现代码
2018/05/14 Javascript
以v-model与promise两种方式实现vue弹窗组件
2018/05/21 Javascript
Vue实现点击显示不同图片的效果
2019/08/10 Javascript
python批量生成本地ip地址的方法
2015/03/23 Python
opencv python 2D直方图的示例代码
2018/07/20 Python
Pycharm以root权限运行脚本的方法
2019/01/19 Python
pywinauto自动化操作记事本
2019/08/26 Python
关于PySnooper 永远不要使用print进行调试的问题
2021/03/04 Python
美国领先的汽车轮胎和轮毂供应商:TireBuyer
2016/07/21 全球购物
英国经典球衣网站:Classic Football Shirts
2017/05/20 全球购物
函授本科毕业自我鉴定
2013/10/09 职场文书
《小动物过冬》教学反思
2014/04/17 职场文书
公司副总经理任命书
2014/06/05 职场文书
兽医医药专业求职信
2014/07/27 职场文书
python爬取企查查企业信息之selenium自动模拟登录企查查
2021/04/08 Python
java开发双人五子棋游戏
2022/05/06 Java/Android