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