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 相关文章推荐
js对象基础实例分析
Jan 13 Javascript
微信浏览器内置JavaScript对象WeixinJSBridge使用实例
May 25 Javascript
js拖拽的原型声明和用法总结
Apr 04 Javascript
浅谈JavaScript中的this指针和引用知识
Aug 05 Javascript
Seajs是什么及sea.js 由来,特点以及优势
Oct 13 Javascript
js封装tab标签页实例分享
Dec 19 Javascript
xmlplus组件设计系列之树(Tree)(9)
May 02 Javascript
微信小程序自定义组件之可清除的input组件
Jul 17 Javascript
关于微信公众号开发无法支付的问题解决
Dec 28 Javascript
详解vue配置后台接口方式
Mar 29 Javascript
浅析Vue中拆分视图层代码的5点建议
Aug 15 Javascript
vue中touch和click共存的解决方式
Jul 28 Javascript
详解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
为查询结果建立向后/向前按钮
2006/10/09 PHP
JoshChen_web格式编码UTF8-无BOM的小细节分析
2013/08/16 PHP
php实现可以设置中奖概率的抽奖程序代码分享
2014/01/19 PHP
php提交表单时保留多个空格及换行的文本样式的方法
2017/06/20 PHP
php实现通过stomp协议连接ActiveMQ操作示例
2020/02/23 PHP
javascript 得到变量类型的函数
2010/05/19 Javascript
jquery获取tr中控件值并操作tr实现思路
2013/03/27 Javascript
js jquery获取随机生成id的服务器控件的三种方法
2013/07/11 Javascript
AngularJS的一些基本样式初窥
2015/07/27 Javascript
jQuery EasyUI学习教程之datagrid点击列表头排序
2016/07/09 Javascript
Node.js实现文件上传的示例
2017/06/28 Javascript
JS按条件 serialize() 对应标签的使用方法
2017/07/24 Javascript
基于$.ajax()方法从服务器获取json数据的几种方式总结
2018/01/31 Javascript
vue的全局变量和全局拦截请求器的示例代码
2018/09/13 Javascript
javascript实现移动端上传图片功能
2020/08/18 Javascript
jQuery实现简单评论区功能
2020/10/26 jQuery
原生JS实现pc端轮播图效果
2020/12/21 Javascript
python cookielib 登录人人网的实现代码
2012/12/19 Python
使用PDB模式调试Python程序介绍
2015/04/05 Python
python 写入csv乱码问题解决方法
2016/10/23 Python
Python爬虫代理IP池实现方法
2017/01/05 Python
详解flask表单提交的两种方式
2018/07/21 Python
Python企业编码生成系统之主程序模块设计详解
2019/07/26 Python
Django中提示消息messages的设置方式
2019/11/15 Python
利用python实现.dcm格式图像转为.jpg格式
2020/01/13 Python
Python GUI编程学习笔记之tkinter界面布局显示详解
2020/03/30 Python
Python日志处理模块logging用法解析
2020/05/19 Python
html5的canvas方法使用指南
2014/12/15 HTML / CSS
Microsoft新加坡官方网站:购买微软最新软件和技术产品
2016/10/28 全球购物
法国和欧洲海边和滑雪度假:Pierre & Vacances
2017/01/04 全球购物
中学生自我鉴定
2014/02/04 职场文书
店面销售职位的职责
2014/03/09 职场文书
入股协议书
2014/04/14 职场文书
单位介绍信格式范文
2015/05/04 职场文书
社区干部培训心得体会
2016/01/06 职场文书
Python 中 Shutil 模块详情
2021/11/11 Python