美文网首页
Nginx 负载均衡

Nginx 负载均衡

作者: 栈木头 | 来源:发表于2018-10-29 18:12 被阅读0次

    负载均衡策略

    1. 默认,加权轮询平衡方法
    2. 最少连接数 least_conn (新版本取消该配置)
    3. IP地址Hash ip_hash
    4. fair 将请求分发到最不繁忙的服务

    默认,加权轮询平衡方法

    仅整理Nginx非商业订阅的参数设置,商业版还提供了更加强大的功能设置,详见官网。

    配置:

    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 后台服务地址,可以为域名或IP地址,带有可选端口,或者指定为“unix:”前缀后指定的UNIX域套接字路径;
    • weight = 5 设置服务的权重,默认为1;可以不配置,多个服务权重不同,优先分发权重高服务

    最少连接数 least_conn

    遍历服务列表,比较每个服务的额conns/weight,选取值最小的服务,将请求转发给连接数较少的后端;

    Nginx version 1.3.1 and 1.2.2中支持。

    IP地址Hash ip_hash

    如果负载均衡分发服务的API不是无状态的,而涉及常见的Session会话,可以选择这种策略,同一台客户端连续的请求都会分发到同一个服务处理。

    根据客户端IP在服务之间进行分配,客户端IPV4地址的前8位字节或整个IPV6地址用作散列秘钥;

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

    配置:

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

    fair 将请求分发到最不繁忙的服务

    该目录不跟随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;
    }
    
    • 最大失败数 max_fails , 持续时间内发生的服务通信不成功的尝试次数,默认1;
    • 服务不可用时间 fail_timeout,指定尝试次服务不可用失败,服务则在指定时间内不可用,默认10s;
    • 备用服务 backup ,将服务标记为备用服务,当主服务不可用时,将会被分发请求;
    • 不可用服务 down ,将服务标记为永久不可用。

    参考资料:

    相关文章

      网友评论

          本文标题:Nginx 负载均衡

          本文链接:https://www.haomeiwen.com/subject/kshitqtx.html