<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
gzip壓縮是解決編譯產物體積過大、縮短靜態資源請求時長的常用手段之一,我們在網站上經常能看到 Content-Encoding: gzip
這個 http 響應頭,表示內容使用 gzip 壓縮;gzip壓縮分為動態壓縮與靜態壓縮,下面淺淺的介紹下這兩種方式以及使用;
動態壓縮實際上就是由nginx伺服器對編譯造物進行壓縮,需要在nginx.conf的http、https模組中開啟下面的設定:
gzip on; # 開啟gizo壓縮 gzip_min_length 1k; # gizp壓縮起點,檔案大於1k才進行壓縮 gzip_comp_level 6; # 壓縮級別 數位越大壓縮得越小 但是越耗效能 根據實際情況而定 gzip_proxied any; # nginx做為反向代理時啟用, 詳細見官方檔案: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; # 設定壓縮所需要的緩衝區大小,以8k為單位,案例中則申請16*4k的緩衝區 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伺服器,檢視靜態資源響應頭,出現Content-Encoding: gzip ****則代表開啟成功;
動態壓縮是在伺服器上進行的,壓縮級別越高越耗效能,靜態壓縮就是為了解決這個問題而生的,開啟靜態壓縮後,nginx會自動尋找.gz字尾的檔案,如果沒有則返回原始檔;於是乎,我們就可以在前端構建的時候進行gzip壓縮;
以vite為例,我們需要引入vite-plugin-compression外掛,並且在vite.config.js中按照下面的方式設定;
import viteCompression from 'vite-plugin-compression'; // gzip plugins: [ viteCompression() ]
外掛支援自定義,主要設定如下
verbose: true, // 是否在控制檯輸出壓縮結果 這裡我們開啟檢視壓縮的效果 disable: false, // 是否禁用 threshold: 10240, // 大於這個值才進行壓縮 單位為b algorithm: 'gzip', // 演演算法 除了gzip還有 ['brotliCompress' ,'deflate','deflateRaw'] ext: '.gz', // 輸出的字尾
引入外掛後編譯,我們即可看見編譯檔案中會多出一些.gz結尾的檔案,這些便是壓縮的產物,檢視編譯輸出,我們可以看到
dist/D:/code/vue/mine/waylon-blog/packages/waylon-blog-pages/assets/index-d023f1e5.css.gz 598.32kb / gzip: 67.81kb
一個598.32kb的css檔案經過壓縮之後大小變成了67.81kb;
將靜態資源部署到伺服器上,在nginx.conf中開啟下面的設定,nginx會自動去尋找.gz結尾的檔案,直接返回給使用者端,這就是所謂的靜態壓縮;
gzip_static on
坑點!!!
1,nginx對靜態壓縮的檔案要求較高,必須與原檔案同時生成,如果不是同時生成的,那麼nginx將無法進行匹配(對於這一點,筆者在引入外掛後原始碼未變更,導致gz檔案與原檔案時間不一致,導致靜態壓縮不生效);
官網原話:
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預設是沒有安裝ngx_http_gzip_static_module靜態壓縮模組的,需手動開啟,開啟方法這裡不贅述,直接上指令:
找到安裝路徑的configure檔案以後,就在這個資料夾下,執行如下命令
./configure --with-http_gzip_static_module
等待執行完畢以後就是執行make指令
make
實際應用中我們通常會採取靜態壓縮+動態壓縮結合的方式來處理我們的靜態資源,靜態壓縮的優先順序會高於動態壓縮,並不是說壓縮的越到小越好,如果已經進行過靜態壓縮的檔案就沒有必要再進行動態壓縮了,因為這樣浪費效能,得不償失,所以動態壓縮的gzip_min_length這個設定尤為重要,能讓我們避免一些無謂的操作;
經過上面一系列操作之後,可以用站長工具測試下壓縮的效果,直接將靜態資源的連線複製進去即可: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 動態靜態壓縮詳解的詳細內容,更多關於nginx gzip動靜態壓縮的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45