Nginx是最流行的Web服務(wù)器之一,,具有非常強大的負載均衡器選項,,旨在提高服務(wù)器資源的可用性和效率。在本文中,,小編將給大家解釋Nginx如何配置負載均衡,?
一、NGINX安裝
作為第一步,,部署這3個服務(wù)器以針對應(yīng)用程序進行平衡,。在所有這 3臺服務(wù)器上安裝NGINX。
在所有這3臺服務(wù)器上安裝NGINX,。
# apt-get 安裝 nginx
在這個階段我們不會部署額外的應(yīng)用程序,;我們只會編輯主要的 index.nginx-debian.html文件。在此文件中,,使用指定名稱SERVER 1,、SERVER 2,、SERVER 3保存每個服務(wù)器。
# echo '你好,!我的名字服務(wù)器 1' > /var/www/html/index.nginx-debian.html
完畢,。安裝了NGINX并派生了服務(wù)器名稱。現(xiàn)在,,當(dāng)在瀏覽器中單擊此鏈接時,,我們將能夠看到已為每個服務(wù)器備份NGINX Web服務(wù)器的消息。
讓我們?yōu)槊總€服務(wù)器建立一個IP:10.10.10.1,、10.10.10.2和 10.10.10.3,。平衡服務(wù)器IP將為10.10.10.99
當(dāng)嘗試對第一臺服務(wù)器進行查詢時,我們將得到以下響應(yīng):
#curl http :// 10 . 10 ,。10 ,。1 /
我的名字服務(wù)器 1
對其余兩臺服務(wù)器重復(fù)安裝和文本寫入過程。
二,、NGINX配置負載均衡
使用NGINX默認設(shè)置安裝所有三臺服務(wù)器后,,我們將部署平衡器服務(wù)器。我們還將繼續(xù)安裝 NGINX 服務(wù)器:
# apt-get 安裝 nginx
現(xiàn)在讓我們?yōu)樾碌呐渲梅?wù)器配置服務(wù)器平衡,。為了顯示3個以前的服務(wù)器進行平衡,,讓我們將以下值部署到NGINX配置中:
在此配置中,,我們可以看到這三臺先前部署的服務(wù)器處于“上游”服務(wù)器組的配置中,。平衡機制的類型也在“上游”指令中指明。如果不指定,,則默認采用`round-robin` ,。要指定這2個其他機制,請指定`least_conn`或`ip_hash` ,。下面的`balanced`值將被指定為用于平衡的組的標題,。任何隨機名稱都足以在以后的配置中用作指向該特定服務(wù)器組的鏈接。
然后,,如果我們過渡到,,我們將看到 `server` 配置組。在此階段,,我們通過端口80的HTTP協(xié)議進行操作,。為此,必須指定一個將監(jiān)聽`listen 80`網(wǎng)絡(luò)服務(wù)器的端口,。然后,,必須根據(jù)目錄編寫位置算法。如果指定了location / ,,則所有查詢都將由該塊提供服務(wù),。然后,,我們可以看到里面的proxy_pass負責(zé)將查詢代理到第三方服務(wù)器。在此階段,,我們指定一個“平衡”服務(wù)器組以及傳輸控制協(xié)議,,并將http保留在端口80上。為此,,我們將http://放在開頭,。
至此,負載均衡安裝以最簡單的配置完成,。讓我們繼續(xù)進行測試,。
重新啟動我們的Web服務(wù)器以應(yīng)用新配置:
#服務(wù)nginx重啟
為了測試,我們可以向平衡服務(wù)器啟動CURL查詢:
因此,,我們可以觀察到10個查詢正在由不同的服務(wù)器處理。每個新請求都已發(fā)送到新服務(wù)器,。
例如,,如果其中一臺服務(wù)器出現(xiàn)故障怎么辦。例如,,讓我們轉(zhuǎn)到服務(wù)器2,,然后將其關(guān)閉:#服務(wù)nginx停止
重新查詢時,我們會看到第二臺服務(wù)器被自動忽略了,。因此,項目的容錯能力增加了,。
顯然,響應(yīng)以循環(huán)模式出現(xiàn),,該機制稱為“round-robin”,。對于不同的平衡機制,一個新的指令將被添加到“upstream”配置組,。新指令可以是`ip_hash`或`least_conn`,。如果我們設(shè)置`ip_hash`方法,這就是 NGINX配置文件的樣子,。
三、額外的負載均衡配置
我們只會考慮一些通常在負載平衡設(shè)置中選擇使用的額外配置,。這些是可選參數(shù),,例如:`weight`、`max_fails`,、`fail_timeout`,。
上述所有參數(shù)都要在服務(wù)器的上游目錄組中指定,。
`weight` 參數(shù)指定服務(wù)器之間的所有查詢平衡。讓我們考慮具有以下配置的服務(wù)器的情況:
每10個查詢將平衡如下:3個查詢將轉(zhuǎn)到10.10.10.1服務(wù)器,,接下來的5個查詢將轉(zhuǎn)到10.10.10.2服務(wù)器,1個查詢將轉(zhuǎn)到10.10.10.3和 10.10.10.4,。
`max_fails`和`fail_timeout`參數(shù)是相互關(guān)聯(lián)的,。它們確定與斷開連接的服務(wù)器重新建立連接的嘗試次數(shù)。例如,,如果`max_fails`參數(shù)設(shè)置為3,,并且`fail_timeout` = 60 ,那么如果在60秒內(nèi)服務(wù)器上有3次不成功的處理嘗試,,那么在接下來的60秒內(nèi)將不會嘗試發(fā)送查詢到這個服務(wù)器,。`fail_timeout`設(shè)置為10 秒,`max_fails`默認設(shè)置為1,。
以下是使用這些參數(shù)的配置示例:
四、正確的負載平衡日志記錄配置
如果我們有一個不方便的應(yīng)用程序在多個服務(wù)器上運行并配置為平衡,。有時需要跟蹤查詢直到接收服務(wù)器,。為此,需要準確記錄平衡,。
將NGINX主配置文件/etc/nginx/nginx.conf添加到 `http` 組,,并使用新的日志格式:
然后打開文件/etc/nginx/sites-available/default并添加以下日志記錄值:
然后,,保存文件,檢查配置并重新啟動Web服務(wù)器,。
# nginx -t && 服務(wù)nginx重啟
如果我們對負載平衡進行4次查詢,,在負載平衡/var/log/nginx/default-access.log日志中,我們將找到以下日志片段:
五,、UTP協(xié)議下DNS服務(wù)器的均衡
如前所述,nginx還可以在傳輸級別執(zhí)行負載平衡,。在此示例中,,我們將考慮DNS服務(wù)器的平衡。
我們在這里指定了幾個DNS后端服務(wù)器,,然后將nginx配置為通過端口53監(jiān)聽UDP數(shù)據(jù)包,。`proxy_pass` 指令將后端發(fā)送到服務(wù)器。Nginx 默認期望后端發(fā)送一個或多個響應(yīng),。由于對一個請求會有一個響應(yīng),,因此我們配置了proxy_responses 1,。
TCP的負載均衡比較相似:
以上是Nginx配置負載均衡相關(guān)步驟,,希望能幫助到大家,。
Copyright ? 2013-2020. All Rights Reserved. 恒訊科技 深圳市恒訊科技有限公司 粵ICP備20052954號 IDC證:B1-20230800.移動站