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 相关文章推荐
兼容多浏览器的字幕特效Marquee的通用js类
Jul 20 Javascript
JS实现商品倒计时实现代码
May 03 Javascript
javascript表单验证和Window详解
Dec 11 Javascript
JQuery中DOM事件冒泡实例分析
Jun 13 Javascript
jQuery实现网页抖动的菜单抖动效果
Aug 07 Javascript
使用jquery实现的循环连续可停顿滚动实例
Nov 23 Javascript
简单实现js无缝滚动效果
Feb 05 Javascript
使用jQuery ajaxupload插件实现无刷新上传文件
Apr 23 jQuery
基于匀速运动的实例讲解(侧边栏,淡入淡出)
Oct 17 Javascript
Vue实现美团app的影院推荐选座功能【推荐】
Aug 29 Javascript
浅谈angular表单提交中ng-submit的默认使用方法
Sep 30 Javascript
微信小程序实现用table显示数据库反馈的多条数据功能示例
May 07 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数组操作
2011/12/30 PHP
php中apc缓存使用示例
2013/12/25 PHP
PHP超牛逼无限极分类生成树方法
2015/05/11 PHP
php简单统计中文个数的方法
2016/09/30 PHP
利用php + Laravel如何实现部署自动化详解
2017/10/11 PHP
IE8 原生JSON支持
2009/04/13 Javascript
javascript 处理HTML元素必须避免使用的一种方法
2009/07/30 Javascript
JS中实现简单Formatter函数示例代码
2014/08/19 Javascript
jquery插件jSignature实现手动签名
2015/05/04 Javascript
jquery操作angularjs对象
2015/06/26 Javascript
JavaScrip常见的一些算法总结
2015/12/28 Javascript
轻松搞定jQuery.noConflict()
2016/02/15 Javascript
jQuery模拟select实现下拉菜单功能
2016/06/20 Javascript
浅谈React 属性和状态的一些总结
2016/11/21 Javascript
AngularJS实现网站换肤实例
2021/02/19 Javascript
javascript 正则表达式分组、断言详解
2017/04/20 Javascript
在Js页面通过POST传递参数跳转到新页面详解
2017/08/25 Javascript
vue单页应用加百度统计代码(亲测有效)
2018/01/31 Javascript
详解webpack4升级指南以及从webpack3.x迁移
2018/06/12 Javascript
浅谈Vuex注入Vue生命周期的过程
2019/05/20 Javascript
三步实现ionic3点击退出app程序
2019/09/17 Javascript
angular inputNumber指令输入框只能输入数字的实现
2019/12/03 Javascript
[50:02]完美世界DOTA2联赛PWL S2 Magma vs FTD 第三场 11.29
2020/12/03 DOTA
Python使用sqlalchemy模块连接数据库操作示例
2019/03/13 Python
django迁移数据库错误问题解决
2019/07/29 Python
python中时间转换datetime和pd.to_datetime详析
2019/08/11 Python
python将print输出的信息保留到日志文件中
2019/09/27 Python
Python 复平面绘图实例
2019/11/21 Python
Python: glob匹配文件的操作
2020/12/11 Python
Alpine安装Python3依赖出现的问题及解决方法
2020/12/25 Python
详解HTML5如何使用可选样式表为网站或应用添加黑暗模式
2020/04/07 HTML / CSS
Myprotein荷兰官网:欧洲第一运动营养品牌
2020/07/11 全球购物
办理信用卡工作证明
2014/01/11 职场文书
幼儿园中班下学期评语
2014/04/18 职场文书
房地产开发项目建议书
2014/05/16 职场文书
2016中秋节广告语
2016/01/28 职场文书