banner
moeyy

moeyy

一条有远大理想的咸鱼。
github
mastodon
email

宝塔面板LNMP開啟Brotli壓縮,可提高網站載入速度

說明:BrotliGoogle推出的開源壓縮演算法,通過變種的LZ77演算法、Huffman編碼以及二階文本建模等方式進行數據壓縮,與其他壓縮演算法相比,它有著更高的壓縮效率,性能也比我們目前常見的Gzip17-25%,可以幫我們更高效的壓縮網頁中的各類文件大小及腳本,從而提高加載速度,提升網頁瀏覽體驗。博主目前也給開啟了Brotli壓縮,體驗還行吧,這裡就說下寶塔面板的開啟方法。

安裝#

1、下載 Brotli

cd /www/server
#下載brotli
git clone https://github.com/google/ngx_brotli.git
cd ngx_brotli
#更新brotli
git submodule update --init

2、編譯 Nginx

提示:手動編譯只測試過Nginx 1.15,部分版本好像會提示缺少模塊,建議使用後面的寶塔腳本編譯方法。

先查看目前的Nginx版本信息,使用命令:

nginx -V

大概會輸出以下信息:

[root@rats ~]# nginx -V
nginx version: nginx/1.15.10
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC) 
built with OpenSSL 1.1.1b  26 Feb 2019
TLS SNI support enabled
configure arguments: --user=www --group=www --prefix=/www/server/nginx --with-openssl=/www/server/nginx/src/openssl ... --with-ld-opt=-ljemalloc

nginx版本為1.15.10configure arguments:後面的為你nginx的編譯參數,下面會用到。

然後重新下載nginx,並開始編譯,使用命令:

#下載nginx,這裡下載的1.15.10版本,如果是其他版本,把下載鏈接的1.15.10改成你的版本號即可
wget http://nginx.org/download/nginx-1.15.10.tar.gz
#解壓並刪除壓縮包
tar -xvzf nginx-*.tar.gz && rm -rf nginx-*.tar.gz
#進入nginx目錄
cd nginx*
#生成Makefile,./configure後面的參數直接複製上面看到的,然後在後面額外加一個--add-module=/www/server/ngx_brotli
./configure --user=www --group=www --prefix=/www/server/nginx ... --add-module=/www/server/ngx_brotli
#編譯nginx
make && make install

不出意外的話,就編譯完成了,然後繼續使用命令查看信息:

nginx -V

image

返回參數後面多了個--add-module=/www/server/ngx_brotli就編譯成功了。

除了手動編譯外,還一種更加方便,且出錯率很低的方法,使用寶塔自帶的Nginx安裝腳本進行編譯安裝,大致步驟:

1、編輯nginx安裝腳本,路徑/www/server/panel/install/nginx.sh,找到Install_Configure(){...}或Install_Nginx(){...}字段,然後找出你要安裝的nginx版本號,在下面一行的./configure --user=www ...後面添加--add-module=/www/server/ngx_brotli即可,記得之間間隔一個英文空格。

2、在ssh客戶端使用命令開始編譯,根據自己的版本,將後面數字改為1.10、1.12、1.14、1.15、1.17、1.8、openresty等
sh /www/server/panel/install/nginx.sh install 1.16

3、安裝好了使用nginx -V查看是否含有模塊即可。

3、開啟 Brotli 壓縮
接下來點擊面板左側軟件商店 -Nginx設置 - 配置修改,在http段內添加以下內容來啟用Brotli壓縮。

brotli on;
brotli_comp_level 6;
brotli_min_length 512;
brotli_types text/plain text/javascript text/css text/xml text/x-component application/javascript application/x-javascript application/xml application/json application/xhtml+xml application/rss+xml application/atom+xml application/x-font-ttf application/vnd.ms-fontobject image/svg+xml image/x-icon font/opentype;
brotli_static always;

最後點擊Nginx設置裡的重載配置生效即可。

Brotli全部參數詳解:

brotli on;              #啟用
brotli_comp_level 6;    #壓縮等級,默認6,最高11,太高的壓縮水平可能需要更多的CPU
brotli_buffers 16 8k;   #請求緩衝區的數量和大小
brotli_min_length 20;   #指定壓縮數據的最小長度,只有大於或等於最小長度才會對其壓縮。這裡指定20字節
brotli_types text/plain application/javascript application/x-javascript text/javascript text/css application/xml text/html application/json image/svg application/font-woff application/vnd.ms-fontobject application/vnd.apple.mpegurl image/x-icon image/jpeg image/gif image/png image/bmp;   #指定允許進行壓縮類型
brotli_static always;   #是否允許查找預處理好的、以.br結尾的壓縮文件,可選值為on、off、always
brotli_window 512k;     #窗口值,默認值為512k

image

全部配置好了,就可以使用谷歌瀏覽器查看下是否開啟成功,看到br字段即為成功。

最後博主感覺壓縮效果還行,有興趣的可以開一下,對於其它的安裝環境,安裝方法都差不多,這裡默認是BrotliGzip共存,並且都啟用了,好處就是部分老舊的瀏覽器不支持Brotli的時候會自動變成Gzip壓縮。

載入中......
此文章數據所有權由區塊鏈加密技術和智能合約保障僅歸創作者所有。