欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Node.js服務器開啟Gzip壓縮教程

 更新時間:2017年08月11日 08:45:11   作者:doterlin  
開啟網(wǎng)站的 gzip 壓縮功能,通??梢愿哌_70%,也就是說,如果你的網(wǎng)頁有30K,壓縮之后就變成9K, 對于大部分網(wǎng)站,顯然可以明顯提高瀏覽速度(注:需要瀏覽器支持)。

Gzip是什么

復制大神們的解釋吧:

GZIP最早由Jean-loup Gailly和Mark Adler創(chuàng)建,用于UNIX系統(tǒng)的文件壓縮。我們在Linux中經(jīng)常會用到后綴為.gz的文件,它們就是GZIP格式的?,F(xiàn)今已經(jīng)成為Internet 上使用非常普遍的一種數(shù)據(jù)壓縮格式,或者說一種文件格式。HTTP協(xié)議上的GZIP編碼是一種用來改進WEB應用程序性能的技術。大流量的WEB站點常常使用GZIP壓縮技術來讓用戶感受更快的速度。這一般是指WWW服務器中安裝的一個功能,當有人來訪問這個服務器中的網(wǎng)站時,服務器中的這個功能就將網(wǎng)頁內容壓縮后傳輸?shù)絹碓L的電腦瀏覽器中顯示出來.一般對純文本內容可壓縮到原大小的40%.這樣傳輸就快了,效果就是你點擊網(wǎng)址后會很快的顯示出來.當然這也會增加服務器的負載. 一般服務器中都安裝有這個功能模塊的.

Gzip壓縮率

舉個例子,通過webpack打包后的js文件比較大,雖然我們可以利用chunk功能將文件分開混淆打包,但是總體積還是不?。贿@時候看看利用gzip壓縮的效果:


啟用Gzip前


啟用Gzip后

對比其中三個文件前后壓縮大?。?/p>

文本類文件:

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%?

我們看到文本類文件的壓縮效果非常顯著,但是圖片體積沒變??匆幌挛谋绢惖膆ttp響應頭是有gzip壓縮過:


而圖片的沒有:


這是因為一般對于圖片(png,jpg等)使用gzip的效果不好甚至恰得其反,所以一般都默認對圖片不進行gzip壓縮。

node.js啟用gzip

下面說一下node的express框架如何使用gzip:

1.安裝一個compression依賴:

npm install compression

2.調用:

var compression = require('compression')
var app = express();

//盡量在其他中間件前使用compression
app.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的文檔。

另外附上nginx的配置

#on為啟用,off為關閉
gzip on;

#設置允許壓縮的頁面最小字節(jié)數(shù),頁面字節(jié)數(shù)從header頭中的Content-Length中進行獲取。默認值是0,不管頁面多大都壓縮。建議設置成大于1k的字節(jié)數(shù),小于1k可能會越壓越大。
gzip_min_length 1k;

#獲取多少內存用于緩存壓縮結果,‘4 16k'表示以16k*4為單位獲得
gzip_buffers 4 16k;

#gzip壓縮比(1~9),越小壓縮效果越差,但是越大處理越慢,所以一般取中間值
gzip_comp_level 5;

#對特定的MIME類型生效,其中'text/html'被系統(tǒng)強制啟用
gzip_types text/plain application/x-javascript text/css application/xml text/javascript application/x-httpd-php;

簡單解釋下參數(shù)

1) gzip

語法:gzip on/off
默認值:off
作用域:http, server, location
說明:開啟或者關閉 gzip 模塊,這里使用 on 表示啟動

2) gzip_min_length

語法:gzip_min_length length
默認值:gzip_min_length 0
作用域:http, server, location
說明:設置允許壓縮的頁面最小字節(jié)數(shù),頁面字節(jié)數(shù)從header頭中的Content-Length中進行獲取。默認值是0,不管頁面多大都壓縮。建議設置成大于1k的字節(jié)數(shù),小于1k可能會越壓越大。|

3) gzip_buffers

語法: gzip_buffers number size
默認值: gzip_buffers 4 4k/8k
作用域: http, server, location
說明:設置系統(tǒng)獲取幾個單位的緩存用于存儲gzip的壓縮結果數(shù)據(jù)流。4 16k 代表以 16k 為單位,按照原始數(shù)據(jù)大小以 16k 為單位的4倍申請內存。

4) gzip_comp_level

語法: gzip_comp_level 1..9
默認值: gzip_comp_level 1
作用域: http, server, location
說明:gzip壓縮比,1 壓縮比最小處理速度最快,9 壓縮比最大但處理最慢(傳輸快但比較消耗cpu)。這里設置為 5。
5) gzip_types

語法: gzip_types mime-type [mime-type ...]
默認值: gzip_types text/html
作用域: http, server, location
說明:匹配MIME類型進行壓縮,(無論是否指定)"text/html" 類型總是會被壓縮的。這里設置為 text/plain application/x-javascript text/css application/xml text/javascript application/x-httpd-php。

相關文章

  • 利用Node.js檢測端口是否被占用的方法

    利用Node.js檢測端口是否被占用的方法

    這篇文章主要給大家介紹了關于利用Node.js檢測端口是否被占用的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-12-12
  • 全面解析node 表單的圖片上傳

    全面解析node 表單的圖片上傳

    本文給大家介紹分享node全面解析表單的圖片上傳,本文給大家介紹的非常詳細,具有參考借鑒價值,感興趣的朋友一起看看吧
    2016-11-11
  • nodejs如何在typescript項目中申明全局變量

    nodejs如何在typescript項目中申明全局變量

    這篇文章主要介紹了nodejs在typescript項目中申明全局變量,本文通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧
    2024-05-05
  • koa2使用ejs和nunjucks作為模板引擎的使用

    koa2使用ejs和nunjucks作為模板引擎的使用

    這篇文章主要介紹了koa2使用ejs和nunjucks作為模板引擎的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • node.js中watch機制詳解

    node.js中watch機制詳解

    本文給大家?guī)淼氖且黄P于nodejs中watch機制的探討,主要探討內容是為什么watch不是銀彈,嘗試使用更好的方案來解決這個問題
    2014-11-11
  • Node.js查詢MySQL并返回結果集給客戶端的全過程

    Node.js查詢MySQL并返回結果集給客戶端的全過程

    nodejs最大的優(yōu)勢也是大家用著最為難以理解的一點,就是它的異步功能,它幾乎所有的io操作都是異步的,這也就導致很多人不理解也用不習慣,下面這篇文章主要給大家介紹了關于Node.js查詢MySQL并返回結果集給客戶端的相關資料,需要的朋友可以參考下
    2022-12-12
  • Node常見的三種安全防范手段詳解

    Node常見的三種安全防范手段詳解

    這篇文章主要為大家介紹了Node常見的三種安全防范手段詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • npm全局模塊卸載及默認安裝目錄修改方法

    npm全局模塊卸載及默認安裝目錄修改方法

    今天小編就為大家分享一篇npm全局模塊卸載及默認安裝目錄修改方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • Node.js巧妙實現(xiàn)Web應用代碼熱更新

    Node.js巧妙實現(xiàn)Web應用代碼熱更新

    本文給大家講解的是Node.js的代碼熱更新的問題,其主要實現(xiàn)原理 是怎么對 module 對象做處理,也就是手工監(jiān)聽文件修改, 然后清楚模塊緩存, 重新掛載模塊,思路清晰考慮細致, 雖然有點冗余代碼,但還是推薦給大家
    2015-10-10
  • 淺談nodejs中的類定義和繼承的套路

    淺談nodejs中的類定義和繼承的套路

    本篇文章主要介紹了淺談nodejs中的類定義和繼承的套路,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07

最新評論