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根据给定的日期计算当月有多少天实现思路及代码
Feb 25 Javascript
一个CSS+jQuery实现的放大缩小动画效果
Feb 19 Javascript
jquery实现导航固定顶部的效果仿蘑菇街
Oct 22 Javascript
深入剖析JavaScript编程中的对象概念
Oct 21 Javascript
Javascript表单特效之十大常用原理性样例代码大总结
Jul 12 Javascript
jQuery图片轮播(二)利用构造函数和原型创建对象以实现继承
Dec 06 Javascript
ReactNative短信验证码倒计时控件的实现代码
Jul 20 Javascript
JavaScript函数中的this四种绑定形式
Aug 15 Javascript
p5.js入门教程之鼠标交互的示例
Mar 16 Javascript
基于vue-element组件实现音乐播放器功能
May 06 Javascript
vue实现淘宝购物车功能
Apr 20 Javascript
vant 中van-list的用法说明
Nov 11 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
PHP面向对象编程快速入门
2006/10/09 PHP
PHP制作图型计数器的例子
2006/10/09 PHP
openPNE常用方法分享
2011/11/29 PHP
php自动加载机制的深入分析
2013/06/08 PHP
php通过排列组合实现1到9数字相加都等于20的方法
2015/08/03 PHP
PHP中如何使用Redis接管文件存储Session详解
2018/11/28 PHP
用javascript实现在小方框中浏览大图的代码
2007/08/14 Javascript
JavaScript下通过的XMLHttpRequest发送请求的代码
2011/06/28 Javascript
JS 实现获取打开一个界面中输入的值
2013/03/19 Javascript
使用jQuery和Bootstrap实现多层、自适应模态窗口
2014/12/22 Javascript
javascript 数组的定义和数组的长度
2016/06/07 Javascript
Bootstrap的Carousel配合dropload.js实现移动端滑动切换图片
2017/03/10 Javascript
Vue中保存用户登录状态实例代码
2017/06/07 Javascript
微信小程序template模板实例详解
2017/10/27 Javascript
Javascript中从学习bind到实现bind的过程
2018/01/05 Javascript
JavaScript设计模式之构造函数模式实例教程
2018/07/02 Javascript
微信小程序swiper左右扩展各显示一半代码实例
2019/12/05 Javascript
[01:35]辉夜杯战队访谈宣传片—LGD
2015/12/25 DOTA
[01:10:30]DOTA2-DPC中国联赛正赛 Dragon vs Dynasty BO3 第一场 3月4日
2021/03/11 DOTA
实例说明Python中比较运算符的使用
2015/05/13 Python
python中numpy基础学习及进行数组和矢量计算
2017/02/12 Python
Python 正则表达式实现计算器功能
2017/04/29 Python
浅谈python在提示符下使用open打开文件失败的原因及解决方法
2018/11/30 Python
Python 在局部变量域中执行代码
2020/08/07 Python
python GUI计算器的实现
2020/10/09 Python
HTML5 中新的全局属性(整理)
2013/07/31 HTML / CSS
瑞士最大的图书贸易公司:Orell Füssli
2019/12/28 全球购物
Made in Design意大利:现代家具、名家灯具和装饰
2020/10/27 全球购物
打造完美自荐信
2014/01/24 职场文书
京剧自荐信
2014/01/26 职场文书
大学生创业策划书
2014/02/02 职场文书
闪闪的红星观后感
2015/06/08 职场文书
初中体育教学随笔
2015/08/15 职场文书
python开发实时可视化仪表盘的示例
2021/05/07 Python
SQL Server代理:理解SQL代理错误日志处理方法
2021/06/30 SQL Server
Redisson实现Redis分布式锁的几种方式
2021/08/07 Redis