Nginx 壓縮(gzip、gunzip、gzip_static、send_file)的實現(xiàn)
本文主要講解通過Nginx請求壓縮,來提高性能:
- gzip:Nginx中常用的壓縮方式;
- gzip_static:靜態(tài)壓縮,由于啟用gzip壓縮,sendfile就無法生效(也就是用戶態(tài)、內核態(tài)切換)降低了性能,顧產生了gzip_static,需要我們提前把壓縮好的資源文件上傳至服務器。
- gunzip:配合gzip_static使用,由于有些瀏覽器不支持gzip壓縮,此時,如果我們使用了gzip_static,客戶端就無法將壓縮包解壓,gunzip能動態(tài)識別客戶端是否需要nginx解壓縮,配合靜態(tài)gzip,兼容性更高
- send_file:避免了nginx中資源文件從用戶態(tài) - 內核態(tài)的切換,直接網(wǎng)絡傳輸給客戶端。
要想啟用響應數(shù)據(jù) gzip 壓縮(ngx_http_gzip_module 模塊)功能,需要用戶瀏覽器也支持 gzip 解壓功能,目前大多數(shù)瀏覽器都支持 gzip 壓縮數(shù)據(jù)的顯示。Nginx 服務器接收客戶端瀏覽器發(fā)送的請求后,通過請求頭中的屬性字段 Accept-Encoding 判斷瀏覽器是否支持 gzip 壓縮,對支持 gzip 壓縮的瀏覽器將發(fā)送 gzip 壓縮的響應數(shù)據(jù)。
ngx_http_gzip_module 模塊的內置配置參數(shù)如下表所示。
指令 | 作用域 | 默認值 | 指令值可選項 | 指令說明 |
---|---|---|---|---|
gzip | http、server、location、if in location | off | on 或 off | 啟用 gzip 功能 |
gzip_buffers | http、server、location | 32 4k 或 16 8k | -- | 設置 gzip 壓縮緩沖區(qū) |
gzip_comp_level | http、server、location | 1 | -- | 設置 gzip 壓縮級別,取值范圍為 1~9,該指令值越大,壓縮程度越高 |
gzip_disable | http、server、location | -- | -- | 當請求頭中的屬性字段 User-Agent 的內容與指令值正則匹配時關閉 gzip 壓縮功能 |
gzip_http_version | http、server、location | 1.1 | 1.0 或 1.1 | 設置壓縮請求的最早 HTTP 協(xié)議版本 |
gzip_min_length | http、server、location | 20 | -- | 設置啟用 gzip 壓縮的響應數(shù)據(jù)的最小長度,判斷依據(jù)為響應頭中 Content-Length 的值。如果 Content-Length 不存在,則該指令無效;如果指令值為 0,則表示全部壓縮 |
gzip_proxied | http、server、location | off | off 或 expired 或 no-cache 或 no-store 或 private 或 no_last_modified 或 no_etag 或 auth 或 any | 根據(jù)被代理服務器返回響應數(shù)據(jù)的響應頭屬性字段判斷是否啟用 gzip 壓縮 |
gzip_types | http、server、location | text/html | -- | 設置可進行 gzip 壓縮的響應數(shù)據(jù)的 MIME 類型,指令值為 * 時表示所有 MIME 類型 |
gzip_vary | http、server、location | off | on 或 off | 在響應頭中添加 Vary:Accept-Encoding,返回給前端代理或 CDN 服務器,用于判崗是否向客戶端發(fā)送 gzip 的緩存副本,避免代理或 CDN 服務器將 gzip 壓縮后的緩存副本響應給不具備 gzip 解壓能力的瀏覽器 |
其中 gzip_proxied 指令的指令值可選項說明如下:
- off:關閉該指令功能;
- expired:若 HTTP 響應頭中包含屬性字段 Expires,則啟用壓縮;
- no-cache:若 HTTP 響應頭中包含屬性字段 Cache-Control:no-cache,則啟用壓縮;
- no-store:若 HTTP 響應頭中包含屬性字段 Cache-Control:no-store,則啟用壓縮;
- private:若 HTTP 響應頭中包含屬性字段 Cache-Control:private,則啟用壓縮;
- no_last_modified:若 HTTP 響應頭中不包含屬性字段 Last-Modified,則啟用壓縮;
- no_etag:若 HTTP 響應頭中不包含屬性字段 ETag,則啟用壓縮;
- auth:若 HTTP 響應頭中包含屬性字段 Authorization,則啟用壓縮;
- any:對所有響應數(shù)據(jù)啟用壓縮。
gzip on; gzip_buffers 16 8k; gzip_comp_level 6; gzip_http_version 1.1; gzip_min_length 256; gzip_proxied any; gzip_vary on; gzip_types text/plain application/x-javascript text/css application/xml; gzip_types text/xml application/xml application/atom+xml application/rss+xml application/xhtml+xml image/svg+xml text/javascript application/javascript application/x-javascript text/x-json application/json application/x-web-app-manifest+json text/css text/plain text/x-component font/opentype application/x-font-ttf application/vnd.ms-fontobject image/x-icon; gzip_disable "MSIE [1-6]\.(?!.*SV1)"; # 建議不要配置,正則影像性能,因為每個請求都會過壓縮
當客戶端瀏覽器不支持 gzip 壓縮時,可以使用 ngx_http_gunzip_module 模塊將壓縮的數(shù)據(jù)解壓后發(fā)送給客戶端。對支持 gzip 壓縮的瀏覽器不做處理。
ngx_http_gunzip_module 模塊的內置配置指令如下表所示。
指令 | 作用域 | 默認值 | 指令值可選項 | 指令說明 |
---|---|---|---|---|
gunzip | http、server、location | off | on 或 off | 設置是否啟用動態(tài)解壓支持 |
gunzip_buffers | http、server、location | 32 4K | -- | 設置用于解壓的緩沖區(qū)大小 |
通常 gzip 壓縮指令都是讀取未壓縮的文本,在進行動態(tài)壓縮后把響應數(shù)據(jù)發(fā)送給客戶端,ngx_http_gzip_static_module 模塊可以使 Nginx 把 gzip 壓縮過的以 .gz 為后綴的文件或已壓縮的響應數(shù)據(jù)直接發(fā)送給客戶端。
ngx_http_gzip_static_module 模塊的內置配置指令如下表所示。
名稱 | 靜態(tài)壓縮指令 |
---|---|
指令 | gzip_static |
作用域 | http、server、location |
默認值 | off |
指令值可選項 | on 或 off 或 always |
指令說明 | 啟用壓縮數(shù)據(jù)讀取功能 |
gzip_static 指令的指令值可選項說明如下:
- on:不檢查客戶端是否支持 gzip 壓縮數(shù)據(jù),始終發(fā)送 gzip 壓縮數(shù)據(jù);
- always:不檢查客戶端是否支持 gzip 壓縮數(shù)據(jù),始終發(fā)送 gzip 壓縮數(shù)據(jù);
- 該指令的執(zhí)行優(yōu)先級高于 gzip 指令;
- 開啟該指令后,默認優(yōu)先查找以 .gz 為后綴的文件;
- gzip_types 指令對 gzip_static 的設置無效。
配置樣例如下:
gzip_static always; # 始終發(fā)送靜態(tài)的gzip壓縮數(shù)據(jù) gunzip on; # 若客戶端瀏覽器不支持gzip壓縮數(shù)據(jù),則解壓后發(fā)送 gunzip_buffers 16 8k; # 解壓緩沖區(qū)大小為128KB gzip_proxied expired no-cache no-store private auth; # 當被代理的服務器符合條件時, # 對響應數(shù)據(jù)啟用gzip壓縮 gzip on; # 啟用動態(tài)gzip壓縮功能 gzip_min_length 1k; # 響應數(shù)據(jù)超過1KB時啟用gzip壓縮 gzip_buffers 4 16k; # 動態(tài)壓縮的緩沖區(qū)大小是64KB gzip_comp_level 3; # 壓縮級別為3 gzip_types text/plain application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png; # 對指定的MIME類型數(shù)據(jù)啟用動態(tài)壓縮 gzip_vary on; # 向前端代理或緩存服務器發(fā)送添加"Vary: Accept- # Encoding"的響應數(shù)據(jù)
到此這篇關于Nginx 壓縮(gzip、gunzip、gzip_static、send_file)的實現(xiàn)的文章就介紹到這了,更多相關Nginx 壓縮內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
nginx實現(xiàn)多geoserver服務的負載均衡的示例代碼
本文主要介紹了nginx實現(xiàn)多geoserver服務的負載均衡的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-05-05nginx location中多個if里面proxy_pass的方法
這篇文章主要介紹了nginx location中多個if里面proxy_pass的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-11-11nginx通過location配置代理的原理和實現(xiàn)方式
這篇文章主要介紹了nginx通過location配置代理的原理和實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-03-03