亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

nginx?gzip?動態(tài)靜態(tài)壓縮詳解

 更新時間:2023年03月19日 10:27:03   作者:waylonzheng  
這篇文章主要為大家介紹了nginx?gzip?動態(tài)靜態(tài)壓縮實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

前言

gzip壓縮是解決編譯產(chǎn)物體積過大、縮短靜態(tài)資源請求時長的常用手段之一,我們在網(wǎng)站上經(jīng)常能看到 Content-Encoding: gzip 這個 http 響應(yīng)頭,表示內(nèi)容使用 gzip 壓縮;gzip壓縮分為動態(tài)壓縮與靜態(tài)壓縮,下面淺淺的介紹下這兩種方式以及使用;

動態(tài)壓縮

動態(tài)壓縮實際上就是由nginx服務(wù)器對編譯造物進(jìn)行壓縮,需要在nginx.conf的http、https模塊中開啟下面的配置:

? ? gzip? on; # 開啟gizo壓縮
    gzip_min_length 1k; # gizp壓縮起點,文件大于1k才進(jìn)行壓縮
    gzip_comp_level 6; # 壓縮級別 數(shù)字越大壓縮得越小 但是越耗性能 根據(jù)實際情況而定
? ? gzip_proxied any; # nginx做為反向代理時啟用, 詳細(xì)見官方文檔:http://nginx.org/en/docs/http/ngx_http_gzip_module.html#gzip_proxied
? ? gzip_vary on; # 是否在http header中添加Vary: Accept-Encoding
? ? gzip_buffers 16 8k; # 設(shè)置壓縮所需要的緩沖區(qū)大小,以8k為單位,案例中則申請16*4k的緩沖區(qū)
? ? gzip_http_version 1.1; # http的版本
? ? gzip_types text/plain application/javascript text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript; # 文件類型

更改完配置,重啟nginx服務(wù)器,查看靜態(tài)資源響應(yīng)頭,出現(xiàn)Content-Encoding: gzip ****則代表開啟成功;

靜態(tài)壓縮

動態(tài)壓縮是在服務(wù)器上進(jìn)行的,壓縮級別越高越耗性能,靜態(tài)壓縮就是為了解決這個問題而生的,開啟靜態(tài)壓縮后,nginx會自動尋找.gz后綴的文件,如果沒有則返回源文件;于是乎,我們就可以在前端構(gòu)建的時候進(jìn)行g(shù)zip壓縮;

以vite為例,我們需要引入vite-plugin-compression插件,并且在vite.config.js中按照下面的方式配置;

    import viteCompression from 'vite-plugin-compression'; // gzip
    plugins: [ viteCompression() ]

插件支持自定義,主要配置如下

    verbose: true, // 是否在控制臺輸出壓縮結(jié)果 這里我們打開查看壓縮的效果
    disable: false, // 是否禁用
    threshold: 10240, // 大于這個值才進(jìn)行壓縮 單位為b
    algorithm: 'gzip', // 算法 除了gzip還有 ['brotliCompress' ,'deflate','deflateRaw']
    ext: '.gz', // 輸出的后綴

引入插件后編譯,我們即可看見編譯文件中會多出一些.gz結(jié)尾的文件,這些便是壓縮的產(chǎn)物,查看編譯輸出,我們可以看到

    dist/D:/code/vue/mine/waylon-blog/packages/waylon-blog-pages/assets/index-d023f1e5.css.gz? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 598.32kb / gzip: 67.81kb

一個598.32kb的css文件經(jīng)過壓縮之后大小變成了67.81kb;

將靜態(tài)資源部署到服務(wù)器上,在nginx.conf中開啟下面的配置,nginx會自動去尋找.gz結(jié)尾的文件,直接返回給客戶端,這就是所謂的靜態(tài)壓縮;

    gzip_static on

坑點?。?!

1,nginx對靜態(tài)壓縮的文件要求較高,必須與原文件同時生成,如果不是同時生成的,那么nginx將無法進(jìn)行匹配(對于這一點,筆者在引入插件后源代碼未變更,導(dǎo)致gz文件與原文件時間不一致,導(dǎo)致靜態(tài)壓縮不生效);

官網(wǎng)原話:

The files can be compressed using the gzip command, or any other compatible one. It is recommended that the modification date and time of original and compressed files be the same.

2,nginx默認(rèn)是沒有安裝ngx_http_gzip_static_module靜態(tài)壓縮模塊的,需手動開啟,開啟方法這里不贅述,直接上指令:

找到安裝路徑的configure文件以后,就在這個文件夾下,執(zhí)行如下命令

./configure  --with-http_gzip_static_module

等待執(zhí)行完畢以后就是執(zhí)行make指令

make

動靜結(jié)合

實際應(yīng)用中我們通常會采取靜態(tài)壓縮+動態(tài)壓縮結(jié)合的方式來處理我們的靜態(tài)資源,靜態(tài)壓縮的優(yōu)先級會高于動態(tài)壓縮,并不是說壓縮的越到小越好,如果已經(jīng)進(jìn)行過靜態(tài)壓縮的文件就沒有必要再進(jìn)行動態(tài)壓縮了,因為這樣浪費性能,得不償失,所以動態(tài)壓縮的gzip_min_length這個配置尤為重要,能讓我們避免一些無謂的操作;

經(jīng)過上面一系列操作之后,可以用站長工具測試下壓縮的效果,直接將靜態(tài)資源的連接復(fù)制進(jìn)去即可:https://tool.chinaz.com/Gzips/?q=c.nxw.so

如圖

文檔參考:

http://nginx.org/en/docs/http/ngx_http_gzip_static_module.html

http://nginx.org/en/docs/http/ngx_http_gzip_module.html

以上就是nginx gzip 動態(tài)靜態(tài)壓縮詳解的詳細(xì)內(nèi)容,更多關(guān)于nginx gzip動靜態(tài)壓縮的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Linux Nginx VPS下簡單解決CC攻擊

    Linux Nginx VPS下簡單解決CC攻擊

    Linux Nginx VPS下簡單解決CC攻擊,使用Nginx與php的朋友可以參考下。
    2010-12-12
  • Nginx proxy_set_header配置方式

    Nginx proxy_set_header配置方式

    這篇文章主要介紹了Nginx proxy_set_header配置方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • nginx日志配置指令詳解

    nginx日志配置指令詳解

    這篇文章主要介紹了nginx日志配置指令詳解,nginx有一個非常靈活的日志記錄模式,每個級別的配置可以有各自獨立的訪問日志,需要的朋友可以參考下
    2014-07-07
  • Nginx工作模式及代理配置的使用細(xì)節(jié)

    Nginx工作模式及代理配置的使用細(xì)節(jié)

    這篇文章主要為大家介紹了Nginx工作模式及代理配置的使用細(xì)節(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-03-03
  • Nginx ssi合并頁面的具體實現(xiàn)

    Nginx ssi合并頁面的具體實現(xiàn)

    nginx的ssi模塊是一種類似于ASP的基于服務(wù)器的網(wǎng)頁制作技術(shù),本文主要介紹了Nginx ssi合并頁面的具體實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2024-05-05
  • Nginx服務(wù)快速入門教程

    Nginx服務(wù)快速入門教程

    這篇文章主要介紹了Nginx服務(wù)快速入門教程的的相關(guān)資料,幫助大家更好的理解和使用nginx,感興趣的朋友可以了解下
    2021-02-02
  • Nginx獲取客戶端真實IP(real_ip_header)的實現(xiàn)

    Nginx獲取客戶端真實IP(real_ip_header)的實現(xiàn)

    在使用Nginx作為反向代理時,確保獲取客戶端真實IP是關(guān)鍵,通過配置real_ip_header和set_real_ip_from,Nginx可以正確解析X-Forwarded-For頭部信息,并更新$remote_addr為客戶端真實IP,下面就來具體介紹一下
    2024-10-10
  • Windows下Nginx的啟動停止等基本操作命令詳解

    Windows下Nginx的啟動停止等基本操作命令詳解

    在Windows下使用Nginx,我們需要掌握一些基本的操作命令,今天為大家分享幾個Windows下操作Nginx的基本命令
    2018-10-10
  • Nginx日志分割實戰(zhàn)

    Nginx日志分割實戰(zhàn)

    Nginx默認(rèn)沒有提供對日志文件的分割功能,本文主要介紹了Nginx日志分割實戰(zhàn),分割Nginx日志的方法有很多,這里推薦利用Logrotate來完成,感興趣的可以了解一下
    2024-03-03
  • FastDFS安裝和配置整合Nginx-1.13.3的方法

    FastDFS安裝和配置整合Nginx-1.13.3的方法

    這篇文章主要介紹了FastDFS安裝和配置整合Nginx-1.13.3的方法,需要的朋友可以參考下
    2017-08-08

最新評論