下文給大家?guī)砘趎ginx基礎負載均衡的詳解,希望能夠給大家在實際運用中帶來一定的幫助,負載均衡涉及的東西比較多,理論也不多,網(wǎng)上有很多書籍,今天我們就用創(chuàng)新互聯(lián)在行業(yè)內(nèi)累計的經(jīng)驗來做一個解答。
創(chuàng)新互聯(lián)公司成立于2013年,是專業(yè)互聯(lián)網(wǎng)技術服務公司,擁有項目網(wǎng)站制作、成都做網(wǎng)站網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元甘泉做網(wǎng)站,已為上家服務,為甘泉各地企業(yè)和個人服務,聯(lián)系電話:18980820575
http 段配置
upstream jing {
server 192.168.0.25:80 max_fails=3 fail_timeout=20s weight=1;
server 192.168.0.28:80 max_fails=3 fail_timeout=20s weight=2;
#后面參數(shù)表示如果,連續(xù)請求3次失敗,停機20s,不接受請求
}
#表示創(chuàng)建一個虛擬web組,name "jing"
server 段
location / {
proxy_pass http://jing/;
}
#location 匹配到轉(zhuǎn)發(fā)給 "jing" 虛擬web組
輪詢(rr),默認調(diào)度算法,將請求平均分配給兩個后端主機,假如一個頁面10個請求,第一個web主機響應 1 3 5 7 9 第二個主機響應,2 4 6 8 10,注意輪詢按請求來負載的。
加權輪詢(wrr),和輪詢一樣就是加了權重,假如web1 "weight=1" ,web2 "weight=2" ,有個頁面有9個請求,web1會響應3個,web會響應6個。
ip_hash,每個請求按訪問ip的hash結果分配,這樣每個訪客固定訪問一個后端云服務器,可以解決session的問題
url_hash(第三方)根據(jù)用戶所請求的url資源路徑分配到后端不同的服務器,可以解決后端是緩存服務器提高命中率。
least_conn 最少連接數(shù),根據(jù)當前后端服務器所響應的客戶端情況,把當前訪問請求調(diào)度到后端服務器響應相對較少服務器上
fair(第三方) 按后端服務器的響應時間來分配請求,響應時間短的優(yōu)先分配。比 weight、ip_hash更加智能的負載均衡算法,fair算法可以根據(jù)頁面大小和加載時間長短智能地進行負載均衡,也就是根據(jù)后端服務器的響應時間 來分配請求,響應時間短的優(yōu)先分配。Nginx本身不支持fair,如果需要這種調(diào)度算法,則必須安裝upstream_fair模塊
down 表示單前的server暫時不參與負載
weight 默認為1.weight越大,負載的權重就越大。
max_fails :允許請求失敗的次數(shù)默認為1.當超過最大次數(shù)時,設置在fail_timeout參數(shù)設置的時間內(nèi)最大失敗次數(shù),如果在這個時間內(nèi),所有針對該服務器的請求都失敗了,那么認為該服務器會被認為是停機了。
fail_timeout:max_fails次失敗后,暫停的時間,默認為10s。
backup: 其它所有的非backup機器down或者忙的時候,請求backup機器。所以這臺機器壓力會最輕。
vim /etc/nginx/nginx.conf
#先修改nignx 主配置文件,在http 段外面 添加四層代理的文件夾
mkdir -pv /etc/nginx/conf.4
vim /etc/nginx/conf.4/ssh.conf #新建轉(zhuǎn)發(fā)配置文件
stream{ upstream ssh { server 192.168.0.28:22; } server { listen 10022; proxy_connect_timeout 3s; #代理超時時間 proxy_timeout 3s; #服務器返回超時時間 proxy_pass ssh; }
}
看了以上關于基于nginx基礎負載均衡的詳解,如果大家還有什么地方需要了解的可以在創(chuàng)新互聯(lián)行業(yè)資訊里查找自己感興趣的或者找我們的專業(yè)技術工程師解答的,創(chuàng)新互聯(lián)技術工程師在行業(yè)內(nèi)擁有十幾年的經(jīng)驗了。