前言
作為這個世界上最好的web服務器之一,Nginx的優(yōu)勢不明而喻。下面來講講,Nginx是如何合并請求連接的。
小知識
當我們在瀏覽網(wǎng)頁的時候,對瀏覽速度有一個重要的影響因素,就是瀏覽器的并發(fā)數(shù)量。并發(fā)數(shù)量簡單通俗的講就是,當瀏覽器網(wǎng)頁的時候同時工作的進行數(shù)量。
當然瀏覽器的并發(fā)請求數(shù)目限制是針對同一域名的,同一時間針對同一域名下的請求有一定數(shù)量限制,超過限制數(shù)目的請求會被阻塞。
首先我們看下各個瀏覽器的并發(fā)連接數(shù):
![](http://img.jbzj.com/file_images/article/201907/2019716170232780.png?201961617247)
羅列一下瀏覽器這么決定可能有什么考慮
- 由于TCP 協(xié)議的限制,PC 端只有65536個端口可用以向外部發(fā)出連接,而操作系統(tǒng)對半開連接數(shù)也有限制以保護操作系統(tǒng)的 TCPIP 協(xié)議棧資源不被迅速耗盡,因此瀏覽器不好發(fā)出太多的 TCP 連接,而是采取用完了之后再重復利用 TCP 連接或者干脆重新建立 TCP 連接的方法。
- 如果采用阻塞的套接字模型來建立連接,同時發(fā)出多個連接會導致瀏覽器不得不多開幾個線程,而線程有時候算不得是輕量級資源,畢竟做一次上下文切換開銷不小。
- 這是瀏覽器作為一個有良知的客戶端在保護服務器。就像以太網(wǎng)的沖突檢測機制,客戶端在使用公共資源的時候必須要自行決定一個等待期。當超過2個客戶端要使用公共資源時,強勢的那個邪惡的客戶端可能會導致弱勢的客戶端完全無法訪問公共資源。從前迅雷被噴就是因為它不是一個有良知的客戶端,它作為 HTTP 協(xié)議客戶端沒有考慮到服務器的壓力,作為 BT 客戶端沒有考慮到自己回饋上傳量的義務。
淘寶tengine
我們在訪問有些網(wǎng)站的時候,會看到代碼中的部分js和css文件是通過一次請求獲取的,上面的小知識知道瀏覽器請求的并發(fā)數(shù)量是有限制的,但是如果把多條記錄合并一次請求就可能會加快響應速度。
淘寶使用的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
如果已經(jīng)安裝過Nginx,只是配置第三方插件。Nginx -V,檢查一下Nginx的版本,如果沒有,下載對應的版本。
執(zhí)行一下代碼即可。
./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --add-module=../nginx-http-concat-master
make
編譯成功以后
#復制之前請備份nginx執(zhí)行文件
cp /objs/nginx /usr/local/nginx/sbin/nginx
殺掉Nginx,重啟即可。
配置
在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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。