亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

Node.js服務器啟用Gzip壓縮

Gzip是什么

复制大神们的解释吧:

GZIP最早由Jean-loup GaillyMark Adler创建,用于UNIX系统的文件压缩。我们在Linux中经常会用到后缀为.gz的文件,它们就是GZIP格式的。现今已经成为Internet 上使用非常普遍的一种数据压缩格式,或者说一种文件格式。HTTP协议上的GZIP编码是一种用来改进WEB应用程序性能的技术。大流量的WEB站点常常使用GZIP压缩技术来让用户感受更快的速度。这一般是指WWW服务器中安装的一个功能,当有人来访问这个服务器中的网站时,服务器中的这个功能就将网页内容压缩后传输到来访的电脑浏览器中显示出来.一般对纯文本内容可压缩到原大小的40%.这样传输就快了,效果就是你点击网址后会很快的显示出来.当然这也会增加服务器的负载. 一般服务器中都安装有这个功能模块的.

Gzip压缩率

举个例子,通过webpack打包后的js文件比较大,虽然我们可以利用chunk功能将文件分开混淆打包,但是总体积还是不小;这时候看看利用gzip压缩的效果:

启用Gzip前


启用Gzip后

对比其中三个文件前后压缩大小:

文本类文件:

  • iview.min.js: 429kb -> 109kb,压缩比74.6%

  • base.min.js: 309kb -> 81.7kb,压缩比73.56%

  • style.min.css: 207kb -> 30.9kb,压缩比85%

图片:

  • 图片1: 63.2kb -> 63.2kb,压缩比0%
    我们看到文本类文件的压缩效果非常显著,但是图片体积没变。看一下文本类的http响应头是有gzip压缩过:


image.png


而图片的没有:

image.png


这是因为一般对于图片(png,jpg等)使用gzip的效果不好甚至恰得其反,所以一般都默认对图片不进行gzip压缩。


node.js启用gzip

下面说一下node的express框架如何使用gzip:
1.安装一个compression依赖:

npm install compression

2.调用:

var compression = require('compression')var app = express();//尽量在其他中间件前使用compressionapp.use(compression());

基本的使用就是这样就ok了,另外如果想只对某些请求使用此功能,可以使用它的过滤方法:

app.use(compression({filter: shouldCompress}))function shouldCompress (req, res) {  if (req.headers['x-no-compression']) {    // 这里就过滤掉了请求头包含'x-no-compression'
    return false
  }  return compression.filter(req, res)
}

其他的功能请参考compression

感谢阅读!


作者:doterlin
链接:https://www.jianshu.com/p/1c9909f9b0e9


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消