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 相关文章推荐
Prototype 工具函数 学习
Jul 23 Javascript
jquery获取特定name所有选中的checkbox,支持IE9标准模式
Mar 18 Javascript
Javascript基础教程之for循环
Jan 18 Javascript
深入理解JavaScript系列(39):设计模式之适配器模式详解
Mar 04 Javascript
js仿3366小游戏选字游戏
Apr 14 Javascript
jQuery UI制作选项卡(tabs)
Dec 13 Javascript
在iframe中使bootstrap的模态框在父页面弹出问题
Aug 07 Javascript
浅谈vue的踩坑路
Aug 31 Javascript
用vscode开发vue应用的方法步骤
May 06 Javascript
使用Vue实现移动端左滑删除效果附源码
May 16 Javascript
Vue 设置axios请求格式为form-data的操作步骤
Oct 29 Javascript
ant design vue导航菜单与路由配置操作
Oct 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
一个简单的PHP入门源程序
2006/10/09 PHP
帝国cms目录结构分享
2015/07/06 PHP
php简单判断文本编码的方法
2015/07/30 PHP
php实现异步将远程链接上内容(图片或内容)写到本地的方法
2016/11/30 PHP
laravel框架邮箱认证实现方法详解
2019/11/22 PHP
JavaScript中的类继承
2010/11/25 Javascript
jQuery.query.js 取参数的两点问题分析
2012/08/06 Javascript
js事件(Event)知识整理
2012/10/11 Javascript
js为鼠标添加右击事件防止默认的右击菜单弹出
2013/07/29 Javascript
JavaScript判断密码强度(自写代码)
2013/09/06 Javascript
一个JavaScript获取元素当前高度的实例
2014/10/29 Javascript
JavaScript中的数值范围介绍
2014/12/29 Javascript
js识别uc浏览器的代码
2015/11/06 Javascript
js下将金额数字每三位一逗号分隔
2016/02/19 Javascript
nodejs制作爬虫实现批量下载图片
2017/05/19 NodeJs
关于vue的语法规则检测报错问题的解决
2018/05/21 Javascript
详解Vue.js v-for不支持IE9的解决方法
2018/12/29 Javascript
JS实现的简单tab切换功能完整示例
2019/06/20 Javascript
taro 实现购物车逻辑的实例代码
2020/06/05 Javascript
[15:28]DOTA2 HEROS教学视频教你分分钟做大人-剧毒术士
2014/06/13 DOTA
Ubuntu下安装PyV8
2016/03/13 Python
python+ffmpeg批量去视频开头的方法
2019/01/09 Python
通过cmd进入python的实例操作
2019/06/26 Python
简单了解python关系(比较)运算符
2019/07/08 Python
python3 中的字符串(单引号、双引号、三引号)以及字符串与数字的运算
2019/07/18 Python
is_file和file_exists效率比较
2021/03/14 PHP
香港优质食材和美酒专门店:FoodWise
2017/09/01 全球购物
印尼最大的网上书店:Gramedia.com
2018/09/13 全球购物
如何查看在weblogic中已经发布的EJB
2012/06/01 面试题
博士生入学考试推荐信
2013/11/17 职场文书
财政局长自荐信范文
2013/12/22 职场文书
法学专业自我鉴定
2014/02/05 职场文书
有关九一八事变的演讲稿
2014/09/14 职场文书
运动会三级跳加油稿
2015/07/21 职场文书
MySQL中几种插入和批量语句实例详解
2021/09/14 MySQL
win10此电脑打不开怎么办 win10双击此电脑无响应的解决办法
2022/07/23 数码科技