隨着nginx的發展,愈來愈多的網站使用nginx,所以nginx的優化變得愈來愈重要,今天咱們來看看nginx的gzip壓縮究竟是怎麼壓縮的呢?
gzip(GNU-ZIP)是一種壓縮技術。通過gzip壓縮後頁面大小能夠變爲原來的30%甚至更小,這樣,用戶瀏覽頁面的時候速度會塊得多。gzip的壓縮頁面須要瀏覽器和服務器雙方都支持,實際上就是服務器端壓縮,傳到瀏覽器後瀏覽器解壓並解析。瀏覽器那裏不須要咱們擔憂,由於目前的巨大多數瀏覽器都支持解析gzip過的頁面。
Nginx的壓縮輸出有一組gzip壓縮指令來實現。相關指令位於http{….}兩個大括號之間。 javascript
gzip on;
//該指令用於開啓或關閉gzip模塊(on/off) css
gzip_min_length 1k;
//設置容許壓縮的頁面最小字節數,頁面字節數從header頭得content-length中進行獲取。默認值是0,無論頁面多大都壓縮。建議設置成大於1k的字節數,小於1k可能會越壓越大。 html
gzip_buffers 4 16k;
//設置系統獲取幾個單位的緩存用於存儲gzip的壓縮結果數據流。4 16k表明以16k爲單位,安裝原始數據大小以16k爲單位的4倍申請內存。 java
gzip_http_version 1.1;
//識別http的協議版本(1.0/1.1) nginx
gzip_comp_level 2;
//gzip壓縮比,1壓縮比最小處理速度最快,9壓縮比最大但處理速度最慢(傳輸快但比較消耗cpu) 瀏覽器
gzip_types text/plain application/x-javascript text/css application/xml
//匹配mime類型進行壓縮,不管是否指定,」text/html」類型老是會被壓縮的。
gzip_vary on;
//和http頭有關係,加個vary頭,給代理服務器用的,有的瀏覽器支持壓縮,有的不支持,因此避免浪費不支持的也壓縮,因此根據客戶端的HTTP頭來判斷,是否須要壓縮 緩存
nginx 配置gzip段以下:
gzip on;
gzip_min_length 1k;
gzip_buffers 16 64k;
gzip_http_version 1.1;
gzip_comp_level 6;
gzip_types text/plain application/x-javascript text/css application/xml;
gzip_vary on; 服務器