1. 程式人生 > >Nginx學習之合併請求連線加速網站訪問

Nginx學習之合併請求連線加速網站訪問

作為這個世界上最好的web伺服器之一,Nginx的優勢不明而喻。下面來講講,Nginx是如何合併請求連線的。

小知識

當我們在瀏覽網頁的時候,對瀏覽速度有一個重要的影響因素,就是瀏覽器的併發數量。併發數量簡單通俗的講就是,當瀏覽器網頁的時候同時工作的進行數量。

當然瀏覽器的併發請求數目限制是針對同一域名的,同一時間針對同一域名下的請求有一定數量限制,超過限制數目的請求會被阻塞。

首先我們看下各個瀏覽器的併發連線數:
在這裡插入圖片描述
羅列一下瀏覽器這麼決定可能有什麼考慮

  • 由於TCP 協議的限制,PC 端只有65536個埠可用以向外部發出連線,而作業系統對半開連線數也有限制以保護作業系統的 TCPIP 協議棧資源不被迅速耗盡,因此瀏覽器不好發出太多的 TCP 連線,而是採取用完了之後再重複利用 TCP 連線或者乾脆重新建立 TCP 連線的方法。
  • 如果採用阻塞的套接字模型來建立連線,同時發出多個連線會導致瀏覽器不得不多開幾個執行緒,而執行緒有時候算不得是輕量級資源,畢竟做一次上下文切換開銷不小。
  • 這是瀏覽器作為一個有良知的客戶端在保護伺服器。就像乙太網的衝突檢測機制,客戶端在使用公共資源的時候必須要自行決定一個等待期。當超過2個客戶端要使用公共資源時,強勢的那個邪惡的客戶端可能會導致弱勢的客戶端完全無法訪問公共資源。從前迅雷被噴就是因為它不是一個有良知的客戶端,它作為 HTTP 協議客戶端沒有考慮到伺服器的壓力,作為 BT 客戶端沒有考慮到自己回饋上傳量的義務。

淘寶tengine

我們在訪問有些網站的時候,會看到程式碼中的部分js和css檔案是通過一次請求獲取的,上面的小知識知道瀏覽器請求的併發數量是有限制的,但是如果把多條記錄合併一次請求就可能會加快響應速度。

淘寶使用的tengine是基於nginx的web伺服器,從11年底開源。開源模組nginx-http-concat,可以合併多個檔案在一個響應報文中。

安裝

初次安裝第三方模組nginx-http-concat

wget http://tengine.taobao.org/download/tengine-2.2.0.tar.gz
wget https://github.com/alibaba/nginx-http-concat/archive/master.zip -O nginx-http-concat-master.zip
unzip nginx-http-concat-master.zip
tar -xzvf tengine-2.2.0.tar.gz
cd  tengine-2.2.0

配置編譯安裝

 ./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --add-module=../nginx-http-concat-master
 make
 make install

如果已經安裝過Nginx,只是配置第三方外掛。Nginx -V,檢查一下Nginx的版本,如果沒有,下載對應的版本。

執行一下程式碼即可。

./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --add-module=../nginx-http-concat-master
make

編譯成功以後

#複製之前請備份nginx執行檔案
cp /objs/nginx  /usr/local/nginx/sbin/nginx

殺掉Nginx,重啟即可。

歡迎大家加入粉絲群:963944895,群內免費分享Spring框架、Mybatis框架SpringBoot框架、SpringMVC框架、SpringCloud微服務、Dubbo框架、Redis快取、RabbitMq訊息、JVM調優、Tomcat容器、MySQL資料庫教學視訊及架構學習思維導圖

配置

在location段增加如下配置:

location /static/css/ {
   concat on;
   concat_max_files 20;
   concat_unique off;
   concat_types text/css application/javascript;
}

合併方式

http://static.52itstyle.com/static/css/??index.css,common.css?v=20171111