Nginx的gzip指令使用小結(jié)
簡(jiǎn)介
GZIP顧名思義,就是將文件壓縮傳輸。圖片、視頻、大文件不建議使用壓縮,壓縮需要占用你的服務(wù)器資源,壓縮完效果也不大。文章出現(xiàn)很多圖片的話,我建議使用圖床來存放你的圖片。文章給大家介紹Nginx的gzip指令。
說一段廢話
壓縮響應(yīng)數(shù)據(jù)有什么作用呢?問的好:從用戶體驗(yàn)和IT成本兩方面回答這個(gè)問題:
- 用戶體驗(yàn)上
網(wǎng)速一定的情況下,傳輸5MB數(shù)據(jù)比傳輸10MB數(shù)據(jù)的時(shí)間快了一半。所以傳輸數(shù)據(jù)越小用戶加載頁(yè)面就越快,當(dāng)然相比較之下體驗(yàn)會(huì)更好。
- IT成本上
對(duì)這個(gè)場(chǎng)景來說的成本主要是帶寬成本, 數(shù)據(jù)不壓縮那么傳輸這些數(shù)據(jù)相應(yīng)的帶寬肯定更大,對(duì)比之下壓縮耗費(fèi)的CPU資源在帶寬費(fèi)用上不值一提。
所以你有什么理由不用壓縮呢?
背景
當(dāng)然Nginx也提供了gzip的壓縮方式可以使用,但是在日常的工作中我發(fā)現(xiàn)或多或少在使用上有些問題,有點(diǎn)像:用了但又好像沒用的感覺。 這篇就記錄一下gzip的使用方式和易錯(cuò)點(diǎn)。
指令介紹
gzip
gzip指令來自 ngx_http_gzip_module 模塊,提供的核心能力就是壓縮響應(yīng)數(shù)據(jù)。
該模塊下提供的指令如下:
gzip on; # 開啟gzip gzip_comp_level 6; # 壓縮等級(jí):1-9 1:壓縮最快/CPU消耗最少/壓縮率最低 以次類推 gzip_min_length 1000; # 小于此大小的數(shù)據(jù)不壓縮(單位字節(jié)/byte);數(shù)據(jù)來源"Content-Length"頭 gzip_buffers 32 4k; # 壓縮響應(yīng)的緩沖區(qū)數(shù)量和大小(4K 內(nèi)存頁(yè)大小取決于平臺(tái)) gzip_proxied any; # 對(duì)代理的請(qǐng)求是否開啟壓縮 gzip_types text/plain application/xml application/javascript application/x-javascript text/css application/json; # 哪些類型的數(shù)據(jù)需要被壓縮 gzip_disable "MSIE [1-5]\."; # User-Agent 被正則匹配到的不開啟壓縮 gzip_vary on; # 當(dāng)gzip對(duì)請(qǐng)求生效時(shí)會(huì)被添加一個(gè)響應(yīng)頭 "Vary: Accept-Encoding"
tips:
- gzip 是動(dòng)態(tài)壓縮: 每個(gè)請(qǐng)求在被響應(yīng)時(shí)都會(huì)在gzip邏輯內(nèi)走一遍
- 壓縮等級(jí)不是越高越好: 壓縮到一定程度后就會(huì)吃力不討好, 從js的測(cè)試來看性價(jià)比最高的級(jí)別是 5或6
- buffer大小設(shè)置最好是和平臺(tái)的內(nèi)存頁(yè)保持一致: getconf PAGE_SIZE
- gzip_types不要瞎寫: 寫壓縮率大的(css/js/xml/json/ttf), image圖片就不要寫了,壓縮空間太小,又耗CPU
gzip_static
gzip_stati指令來自 ngx_http_gzip_static_module模塊,提供的核心能力是靜態(tài)/預(yù)壓縮
該模塊提供的指令如下:
gzip_static on|off|always; # always: 不管客戶端是否支持壓縮我他媽全部給你壓縮之后給你
tips:
- 可以復(fù)用gzip_module中以下的指令:
gzip_http_version, gzip_proxied, gzip_disable, gzip_vary
- gzip_static是靜態(tài)壓縮:意思是你的服務(wù)端需要同時(shí)存在源文件和使用gzip壓縮后的源文件,這時(shí)請(qǐng)求的時(shí)候會(huì)優(yōu)先吧壓縮文件返回,這樣就不用再耗費(fèi)CPU去動(dòng)態(tài)壓縮了。(視情況來用,我們沒用)
- 可以和gzip一同開啟,沒啥影響,它的優(yōu)先級(jí)高于gzip
易錯(cuò)點(diǎn)提示
在實(shí)際的生產(chǎn)環(huán)境中架構(gòu)都比較負(fù)載,不像一個(gè)單純的Nginx一樣,我配置好了就萬事大吉了。
時(shí)常會(huì)遇到有些網(wǎng)站明明配置了gzip但是展示上看并沒有生效,為什么?
此時(shí)需要梳理這個(gè)請(qǐng)求流程,看看這個(gè)請(qǐng)求都經(jīng)過了哪些地方,比如 你的請(qǐng)求通過三次代理(CDN-->Nginx-->Nginx)那么在其中一層沒有配置或者配置錯(cuò)誤那么整體的返回?cái)?shù)據(jù)就是沒有被壓縮的, 這種情況出現(xiàn)還是比較多的。
到此這篇關(guān)于Nginx的gzip指令使用小結(jié)的文章就介紹到這了,更多相關(guān)Nginx的gzip指令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Linux 系統(tǒng) nginx 服務(wù)器安裝及負(fù)載均衡配置詳解
nginx(engine x) 是一個(gè) 高性能 的 HTTP 和 反向代理 服務(wù)器、郵件代理服務(wù)器以及通用的 TCP/UDP 代理服務(wù)器。這篇文章主要介紹了Linux 系統(tǒng) nginx 服務(wù)器安裝及負(fù)載均衡配置詳解,需要的朋友可以參考下2019-07-07nginx 502、413和404錯(cuò)誤原因排查和解決辦法總結(jié)
這篇文章主要給大家介紹了NGINX 502錯(cuò)誤排查,辦法總結(jié),Nginx 413錯(cuò)誤的排查以及Nginx 400錯(cuò)誤排查,文中通過代碼示例給出了詳細(xì)的排查方法和解決方案,需要的朋友可以參考下2023-12-12Nginx中部署Angular項(xiàng)目遇到的坑巨坑
這篇文章主要介紹了Nginx中部署Angular項(xiàng)目遇到的坑巨坑,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10nginx上設(shè)置html不緩存的方法實(shí)現(xiàn)
前端項(xiàng)目發(fā)布以后,經(jīng)常會(huì)遇到訪問不到最新的版本,這主要是由于我們項(xiàng)目的入口文件index.html被瀏覽器或者代理緩存了,本文主要介紹了nginx上設(shè)置html不緩存,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02uwsgi+nginx代理Django無法訪問靜態(tài)資源的解決
這篇文章主要介紹了uwsgi+nginx代理Django無法訪問靜態(tài)資源,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05