首頁  >  文章  >  運維  >  nginx怎麼實現負載平衡的

nginx怎麼實現負載平衡的

(*-*)浩
(*-*)浩原創
2019-11-01 10:25:175637瀏覽

Nginx("engine x")是一款是由俄羅斯的程式設計師Igor Sysoev所開發高效能的Web和反向代理伺服器,也是 IMAP/POP3/SMTP 代理伺服器。

nginx怎麼實現負載平衡的

在高連線並發的情況下,Nginx是Apache伺服器不錯的替代品。

負載平衡:負載平衡也是Nginx常用的功能,當一台伺服器的單位時間內的訪問量越大時,伺服器壓力就越大,大到超過自身承受能力時,伺服器就會崩潰。為了避免伺服器崩潰,讓使用者有更好的體驗,我們透過負載平衡的方式來分擔伺服器壓力。 (推薦學習:nginx教程

我們可以建立很多很多伺服器,組成一個伺服器集群,當用戶訪問網站時,先訪問一個中間伺服器,在讓這個中間伺服器在伺服器在叢集中選擇一個壓力較小的伺服器,然後將該存取請求引入該伺服器。

如此以來,用戶的每次訪問,都會保證伺服器叢集中的每個伺服器壓力趨於平衡,分擔了伺服器壓力,避免了伺服器崩潰的情況。負載平衡配置一般都需要同時配置反向代理,透過反向代理跳到負載平衡。

nginx提供了以下三種負載平衡機制、方法:

round-robin — 請求以循環、輪轉的方式分發到應用程式伺服器。

least-connected — 下一個請求被指派到擁有最少活動連線數的伺服器

ip-hash — 使用一個雜湊函數,基於客戶端ip位址判斷下一個請求應該被分發到哪個伺服器。

預設的負載平衡配置

http {
   upstream myapp1 {
       server srv1.example.com;
       server srv2.example.com;
       server srv3.example.com;
   }
  
   server {
       listen 80;
  
       location / {
           proxy_pass http://myapp1;
       }
   }
}

以上是nginx怎麼實現負載平衡的的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn