Nginx("engine x")是一款是由俄羅斯的程式設計師Igor Sysoev所開發高效能的Web和反向代理伺服器,也是 IMAP/POP3/SMTP 代理伺服器。
在高連線並發的情況下,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中文網其他相關文章!