乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      Helloweba

       高階漁夫 2018-06-22

      負(fù)載均衡模塊Upstream

      Upstream是Nginx的HTTP Upstream模塊,這個(gè)模塊通過一個(gè)簡單的調(diào)度算法來實(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è)定中,通過upstream指令指定了一個(gè)負(fù)載均衡器的名稱webhost。這個(gè)名稱可以任意指定,在后面需要用到的地方直接調(diào)用即可。

      Upstream模塊支持的負(fù)載均衡策略

      Nginx的Upstream負(fù)載均衡模塊目前支持以下常用的策略算法:

      輪詢:這是默認(rèn)的策略,每個(gè)請求按時(shí)間順序逐一分配到不同的后端服務(wù)器,如果后端某臺服務(wù)器宕機(jī),故障系統(tǒng)被自動(dòng)剔除,使用戶訪問不受影響。

      upstream webhost { server 192.168.11.31; server 192.168.11.32; }

      權(quán)重:weight默認(rèn)值為1,值越大則代表被訪問的幾率越大,主要用于后端每個(gè)服務(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值分配,這樣同一客戶端的請求都會被分配到同一個(gè)server上,如果牽扯到session的問題,比如記錄用戶登錄狀態(tài),用這個(gè)是最好的選擇,可保證每次請求都是同一個(gè)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í)還可以設(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í)候,才會請求backup機(jī)器,因此這臺機(jī)器的壓力最輕。

      max_fails:允許請求失敗的次數(shù),默認(rèn)為1。當(dāng)超過最大次數(shù)時(shí),返回proxy_next_upstream 模塊定義的錯(cuò)誤。

      fail_timeout:在經(jīng)歷了max_fails次失敗后,暫停服務(wù)的時(shí)間。max_fails可以和fail_timeout一起使用。

      注意,當(dāng)負(fù)載調(diào)度算法為ip_hash時(shí),后端服務(wù)器在負(fù)載均衡調(diào)度中的狀態(tài)不能是weightbackup

      實(shí)驗(yàn)測試

      學(xué)習(xí)了Upstream模塊相關(guān)知識后,我們接下來開始動(dòng)手實(shí)驗(yàn)測試。

      1、準(zhǔn)備實(shí)驗(yàn)環(huán)境
      • 域名:mytest.net
      • 服務(wù)器系統(tǒng):Centos7.2、nginx/1.12.2
      • 1號服務(wù)器:192.168.11.31
      • 2號服務(wù)器:192.168.11.32
      • 3號服務(wù)器:192.168.11.34

      準(zhǔn)備3臺虛擬機(jī)服務(wù)器,其中3號服務(wù)器用來做負(fù)載均衡配置,綁定域名。1號和2號服務(wù)器作為后置服務(wù)器用來提供真實(shí)數(shù)據(jù)服務(wù)。

      2、實(shí)驗(yàn)預(yù)期效果

      我們希望,通過瀏覽器輸入域名mytest.net,刷新頁面,可以分別訪問到1號服務(wù)器和2號服務(wù)器上提供的內(nèi)容,從而實(shí)現(xiàn)負(fù)載均衡。斷開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; #定義請求頭中真實(shí)IP地址,方便后端被代理服務(wù)器獲取真實(shí)的IP proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $host; } }

      upstream是定義在server{ }之外的,不能定義在server{ }內(nèi)部。定義好upstream之后,用proxy_pass引用一下即可。

      這里我們還需要注意的是,proxy_set_header用來設(shè)置請求頭部header,上面的代碼中我們設(shè)置了頭部包含獲取客戶端真實(shí)IP,如果不設(shè)置,使用Nginx的負(fù)載均衡后,獲取的是代理服務(wù)器的IP,我們在后面會驗(yàn)證。

      編輯好后保存配置文件,并重載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配置就和正常站點(diǎn)的配置一樣,無需配置Upstream模塊,站點(diǎn)配置可參考:《Nginx配置多域名多站點(diǎn)》。

      為了驗(yàn)證負(fù)載均衡的有效性,我們在1號和2號服務(wù)器上可以分別加上一段PHP代碼,用來響應(yīng)服務(wù)器請求,根據(jù)負(fù)載分配過來的請求,獲取用戶的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 '客戶端真實(shí)IP:'. $server['HTTP_X_REAL_IP'] . '<br/>';
      5、驗(yàn)證

      最后,我們用瀏覽器訪問域名mytest.net(本機(jī)設(shè)置好域名指向host文件),得到如下響應(yīng):

      很顯然,我們通過3號服務(wù)器訪問到了1號服務(wù)器的內(nèi)容,再次刷新,可以訪問到2號服務(wù)器的內(nèi)容(本機(jī)客戶端IP:192.168.11.5)。

      我們可以把2號服務(wù)器暫時(shí)停止服務(wù),嘗試訪問下域名看看。

      不斷刷新頁面,我們會發(fā)現(xiàn),Server 1和Server 2會交替出現(xiàn)。從實(shí)驗(yàn)效果來看,我們已經(jīng)實(shí)現(xiàn)了Nginx的負(fù)載均衡功能。實(shí)驗(yàn)中,3號服務(wù)器起了關(guān)鍵作用,它就像路由器一樣,根據(jù)負(fù)載均衡策略,把用戶的請求分配給后端服務(wù)器,并把后端服務(wù)器的響應(yīng)傳遞給客戶端。

      最后問題來了,假如3號服務(wù)器掛了這么辦?3號服務(wù)器是關(guān)鍵服務(wù)器,它掛了就意味著請求得不到響應(yīng),當(dāng)然有解決方案。接下來Helloweba會有文章介紹Keepalive實(shí)現(xiàn)高可用。

        本站是提供個(gè)人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多