Nginx 負載均衡

負載均衡策略

  1. 默認,加權(quán)輪詢平衡方法
  2. 最少連接數(shù) least_conn (新版本取消該配置)
  3. IP地址Hash ip_hash
  4. fair 將請求分發(fā)到最不繁忙的服務(wù)

默認,加權(quán)輪詢平衡方法

僅整理Nginx非商業(yè)訂閱的參數(shù)設(shè)置,商業(yè)版還提供了更加強大的功能設(shè)置,詳見官網(wǎng)。

配置:

upstream backend {
    server backend1.example.com:80 weight=5;
    server backend1.example.com:81 weight=3;
}

server {
    location / {
        proxy_pass http://backend;
    }
}

配置解釋:

  • backend 名稱,用于配置代理;
  • backend1.example.com 后臺服務(wù)地址,可以為域名或IP地址,帶有可選端口,或者指定為“unix:”前綴后指定的UNIX域套接字路徑;
  • weight = 5 設(shè)置服務(wù)的權(quán)重,默認為1;可以不配置,多個服務(wù)權(quán)重不同,優(yōu)先分發(fā)權(quán)重高服務(wù)

最少連接數(shù) least_conn

遍歷服務(wù)列表,比較每個服務(wù)的額conns/weight,選取值最小的服務(wù),將請求轉(zhuǎn)發(fā)給連接數(shù)較少的后端;

Nginx version 1.3.1 and 1.2.2中支持。

IP地址Hash ip_hash

如果負載均衡分發(fā)服務(wù)的API不是無狀態(tài)的,而涉及常見的Session會話,可以選擇這種策略,同一臺客戶端連續(xù)的請求都會分發(fā)到同一個服務(wù)處理。

根據(jù)客戶端IP在服務(wù)之間進行分配,客戶端IPV4地址的前8位字節(jié)或整個IPV6地址用作散列秘鑰;

Nginx versions 1.3.2 and 1.2.2 以后版本支持。

配置:

upstream backend {
    ip_hash;

    server backend1.example.com;
    server backend2.example.com;
}

fair 將請求分發(fā)到最不繁忙的服務(wù)

該目錄不跟隨Nginx默認源,需要獨立安裝。

安裝:

--add-module=path/to/upstream_fair/directory

配置:

upstream backend {
    server backend1.example.com;
    server backend2.example.com;
    fair;
}

負載均衡其他配置

配置:

upstream backend {
    server backend1.example.com max_fails=3 fail_timeout=30s;
    server backend2.example.com max_fails=3 fail_timeout=30s;
    server backend2.example.com backup;
    server backend2.example.com down;
}
  • 最大失敗數(shù) max_fails , 持續(xù)時間內(nèi)發(fā)生的服務(wù)通信不成功的嘗試次數(shù),默認1;
  • 服務(wù)不可用時間 fail_timeout,指定嘗試次服務(wù)不可用失敗,服務(wù)則在指定時間內(nèi)不可用,默認10s;
  • 備用服務(wù) backup ,將服務(wù)標(biāo)記為備用服務(wù),當(dāng)主服務(wù)不可用時,將會被分發(fā)請求;
  • 不可用服務(wù) down ,將服務(wù)標(biāo)記為永久不可用。

參考資料:

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容