負載均衡模塊UpstreamUpstream是Nginx的HTTP Upstream模塊,這個模塊通過一個簡單的調(diào)度算法來實現(xiàn)客戶端IP到后端服務(wù)器的負載均衡。 upstream webhost
{
ip_hash;
server 192.168.11.31;
server 192.168.11.32 max_fails=3 fail_timeout=20s;
}
在上面的設(shè)定中,通過upstream指令指定了一個負載均衡器的名稱webhost。這個名稱可以任意指定,在后面需要用到的地方直接調(diào)用即可。 Upstream模塊支持的負載均衡策略Nginx的Upstream負載均衡模塊目前支持以下常用的策略算法: 輪詢:這是默認(rèn)的策略,每個請求按時間順序逐一分配到不同的后端服務(wù)器,如果后端某臺服務(wù)器宕機,故障系統(tǒng)被自動剔除,使用戶訪問不受影響。 upstream webhost
{
server 192.168.11.31;
server 192.168.11.32;
}
權(quán)重:weight默認(rèn)值為1,值越大則代表被訪問的幾率越大,主要用于后端每個服務(wù)器性能不均的情況下。如下配置,32的訪問數(shù)量是31的2倍 upstream webhost
{
server 192.168.11.31 weight=1;
server 192.168.11.32 weight=2;
}
ip_hash:根據(jù)訪問客戶端ip的hash值分配,這樣同一客戶端的請求都會被分配到同一個server上,如果牽扯到session的問題,比如記錄用戶登錄狀態(tài),用這個是最好的選擇,可保證每次請求都是同一個session,規(guī)避不同服務(wù)器間session共享問題。 upstream webhost
{
ip_hash;
server 192.168.11.31;
server 192.168.11.32;
}
狀態(tài)參數(shù)在HTTP Upstream模塊中,可以通過server指令指定后端服務(wù)器的IP地址和端口,同時還可以設(shè)定每個后端服務(wù)器在負載均衡調(diào)度中的狀態(tài)。常用的狀態(tài)有: down:表示當(dāng)前的server暫時不參與負載均衡。 backup:預(yù)留的備份機器。當(dāng)其他所有的非backup機器出現(xiàn)故障或者忙的時候,才會請求backup機器,因此這臺機器的壓力最輕。 max_fails:允許請求失敗的次數(shù),默認(rèn)為1。當(dāng)超過最大次數(shù)時,返回proxy_next_upstream 模塊定義的錯誤。 fail_timeout:在經(jīng)歷了max_fails次失敗后,暫停服務(wù)的時間。max_fails可以和fail_timeout一起使用。 注意,當(dāng)負載調(diào)度算法為 實驗測試學(xué)習(xí)了Upstream模塊相關(guān)知識后,我們接下來開始動手實驗測試。 1、準(zhǔn)備實驗環(huán)境
準(zhǔn)備3臺虛擬機服務(wù)器,其中3號服務(wù)器用來做負載均衡配置,綁定域名。1號和2號服務(wù)器作為后置服務(wù)器用來提供真實數(shù)據(jù)服務(wù)。 2、實驗預(yù)期效果我們希望,通過瀏覽器輸入域名mytest.net,刷新頁面,可以分別訪問到1號服務(wù)器和2號服務(wù)器上提供的內(nèi)容,從而實現(xiàn)負載均衡。斷開1號和2號服務(wù)器中的任意一臺,都不會影響用戶訪問。 3、配置3號服務(wù)器配置nginx。 [root@localhost ~]# vim /usr/local/nginx/conf/vhost/mytest.conf
upstream webhost
{
#ip_hash;
server 192.168.11.31;
server 192.168.11.32;
}
server
{
listen 80;
server_name mytest.net;
index index.html index.htm;
root /home/mytest;
location /
{
proxy_pass http://webhost;
proxy_redirect off;
proxy_set_header X-Real-IP $remote_addr; #定義請求頭中真實IP地址,方便后端被代理服務(wù)器獲取真實的IP
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $host;
}
}
upstream是定義在 這里我們還需要注意的是, 編輯好后保存配置文件,并重載nginx使配置生效: [root@localhost ~]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload
[root@localhost ~]#
4、配置1號和2號服務(wù)器1號和2豪服務(wù)器的Nginx配置就和正常站點的配置一樣,無需配置Upstream模塊,站點配置可參考:《Nginx配置多域名多站點》。 為了驗證負載均衡的有效性,我們在1號和2號服務(wù)器上可以分別加上一段PHP代碼,用來響應(yīng)服務(wù)器請求,根據(jù)負載分配過來的請求,獲取用戶的IP以及代理IP等信息: <?php
echo '<h1>Server 1.</h1>';
$server = $_SERVER;
echo '訪問服務(wù)器IP:'. $server['SERVER_ADDR'] . '<br/>';
echo '代理服務(wù)器IP:'. $server['REMOTE_ADDR'] . '<br/>';
echo '客戶端真實IP:'. $server['HTTP_X_REAL_IP'] . '<br/>';
5、驗證最后,我們用瀏覽器訪問域名mytest.net(本機設(shè)置好域名指向host文件),得到如下響應(yīng): 很顯然,我們通過3號服務(wù)器訪問到了1號服務(wù)器的內(nèi)容,再次刷新,可以訪問到2號服務(wù)器的內(nèi)容(本機客戶端IP:192.168.11.5)。 我們可以把2號服務(wù)器暫時停止服務(wù),嘗試訪問下域名看看。 不斷刷新頁面,我們會發(fā)現(xiàn),Server 1和Server 2會交替出現(xiàn)。從實驗效果來看,我們已經(jīng)實現(xiàn)了Nginx的負載均衡功能。實驗中,3號服務(wù)器起了關(guān)鍵作用,它就像路由器一樣,根據(jù)負載均衡策略,把用戶的請求分配給后端服務(wù)器,并把后端服務(wù)器的響應(yīng)傳遞給客戶端。 最后問題來了,假如3號服務(wù)器掛了這么辦?3號服務(wù)器是關(guān)鍵服務(wù)器,它掛了就意味著請求得不到響應(yīng),當(dāng)然有解決方案。接下來Helloweba會有文章介紹Keepalive實現(xiàn)高可用。 |
|