<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

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

        來源:懂視網 責編:小采 時間:2020-11-27 22:33:04
        文檔

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

        Node.js服務器開啟Gzip壓縮教程:Gzip是什么 復制大神們的解釋吧: GZIP最早由Jean-loup Gailly和Mark Adler創建,用于UNIX系統的文件壓縮。我們在Linux中經常會用到后綴為.gz的文件,它們就是GZIP格式的。現今已經成為Internet 上使用非常普遍的一種數據壓縮格式,或者說一種文件格式。HT
        推薦度:
        導讀Node.js服務器開啟Gzip壓縮教程:Gzip是什么 復制大神們的解釋吧: GZIP最早由Jean-loup Gailly和Mark Adler創建,用于UNIX系統的文件壓縮。我們在Linux中經常會用到后綴為.gz的文件,它們就是GZIP格式的。現今已經成為Internet 上使用非常普遍的一種數據壓縮格式,或者說一種文件格式。HT

        Gzip是什么

        復制大神們的解釋吧:

        GZIP最早由Jean-loup Gailly和Mark 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壓縮過:


        而圖片的沒有:


        這是因為一般對于圖片(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;
        
        #設置允許壓縮的頁面最小字節數,頁面字節數從header頭中的Content-Length中進行獲取。默認值是0,不管頁面多大都壓縮。建議設置成大于1k的字節數,小于1k可能會越壓越大。
        gzip_min_length 1k;
        
        #獲取多少內存用于緩存壓縮結果,‘4 16k'表示以16k*4為單位獲得
        gzip_buffers 4 16k;
        
        #gzip壓縮比(1~9),越小壓縮效果越差,但是越大處理越慢,所以一般取中間值
        gzip_comp_level 5;
        
        #對特定的MIME類型生效,其中'text/html'被系統強制啟用
        gzip_types text/plain application/x-javascript text/css application/xml text/javascript application/x-httpd-php;

        簡單解釋下參數

        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
        說明:設置允許壓縮的頁面最小字節數,頁面字節數從header頭中的Content-Length中進行獲取。默認值是0,不管頁面多大都壓縮。建議設置成大于1k的字節數,小于1k可能會越壓越大。|

        3) gzip_buffers

        語法: gzip_buffers number size
        默認值: gzip_buffers 4 4k/8k
        作用域: http, server, location
        說明:設置系統獲取幾個單位的緩存用于存儲gzip的壓縮結果數據流。4 16k 代表以 16k 為單位,按照原始數據大小以 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。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

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

        Node.js服務器開啟Gzip壓縮教程:Gzip是什么 復制大神們的解釋吧: GZIP最早由Jean-loup Gailly和Mark Adler創建,用于UNIX系統的文件壓縮。我們在Linux中經常會用到后綴為.gz的文件,它們就是GZIP格式的。現今已經成為Internet 上使用非常普遍的一種數據壓縮格式,或者說一種文件格式。HT
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 久久精品蜜芽亚洲国产AV| 四虎精品亚洲一区二区三区| 精品国产免费一区二区三区| 日韩免费高清视频网站| 亚洲欧美国产欧美色欲| 毛片免费vip会员在线看| 亚洲videos| 两性色午夜免费视频| 亚洲国模精品一区| 中文字幕免费播放| 亚洲综合伊人久久综合| 两个人看的www免费视频中文| 亚洲一区爱区精品无码| 热99RE久久精品这里都是精品免费 | 色偷偷噜噜噜亚洲男人| 免费看www视频| 日亚毛片免费乱码不卡一区 | 免费看少妇作爱视频| 粉色视频成年免费人15次| 99re视频精品全部免费| 久久不见久久见中文字幕免费 | 色屁屁www影院免费观看视频| 一本色道久久88亚洲综合 | 免费看黄福利app导航看一下黄色录像| 亚洲国产av一区二区三区| 美女网站在线观看视频免费的| 亚洲大片在线观看| 黄色视频在线免费观看| 亚洲av中文无码乱人伦在线咪咕| 3344免费播放观看视频| 亚洲av永久无码精品表情包| 日本免费xxxx| 曰批免费视频播放免费| 亚洲伦理一区二区| 日韩免费高清一级毛片在线| 成人免费ā片在线观看| 亚洲天堂中文字幕在线观看| 五月天婷亚洲天综合网精品偷| 无码日韩精品一区二区免费暖暖| 亚洲色欲色欱wwW在线| 大学生一级特黄的免费大片视频|