美文网首页
Nginx负载均衡

Nginx负载均衡

作者: 魔曦帝天 | 来源:发表于2019-10-09 20:42 被阅读0次

    单机实战

    nginx配置7层协议

    /etc/nginx/conf.d/proxy.conf中  
    
    upstream mytest1 {
          
          server 192.168.122.110:80;  # 设置负载均衡
          server 192.168.122.111:80;
          server 192.168.122.112:80;
          server 192.168.122.113:80;
      }
    server {
    listen 80;
    server_name www.proxy.com;
    root         /usr/share/nginx/app1;
      access_log   /var/log/www.proxy.log main;
      error_log  
    /var/log/www.proxy.error.log;
    location / {
                  proxy_pass http://mytest1; # 请求转向 代理服务器列表(我代理了谁)
                  proxy_set_header Host $http_host;
                  proxy_set_header X-Real-IP $remote_addr; 
                  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                  proxy_set_header X-Forwarded-Proto $scheme;
                  proxy_set_header X-NginX-Proxy true;
                  proxy_connect_timeout 30;   #
                  proxy_send_timeout 60;
                  proxy_read_timeout 60;
                  proxy_buffering on;
                  proxy_buffer_size 32k;
                  proxy_buffers 4 128k;
                  proxy_busy_buffers_size 256k;
                  proxy_max_temp_file_size 256k;
       index index.html;  
     }
    }
    

    /etc/nginx/conf.d/app1.conf 服务端添加配置

    server {
    listen 192.168.122.110:80;  # 虚拟主机
    server_name www.app1.com;
    root         /usr/share/nginx/app1;
      access_log   /var/log/app1.com.log main;
      error_log  
    /var/log/app1.com.error.log;
    
    set_real_ip_from 10.0.122.156; ##谁代理了我
    location / {
    
       index index.html;  
     }
    }
    

    其他提供服务修改对应ip地址即可

    负载均衡算法

    A、 轮询(默认) :每个请求按时间顺序逐一分配到不同的后端服务器;
    B、 ip_hash :每个请求按访问IP的hash结果分配,同一个IP客户端固定访问一个后端服务器。可以保证
    来自同一ip的请求被打到固定的机器上,可以解决session问题。
    C、 url_hash :按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器。后台服务器为
    缓存的时候效率。
    D、 fair :这是比上面两个更加智能的负载均衡算法。此种算法可以依据页面大小和加载时间长短智能
    地进行负载均衡,也就是根据后端服务器的响应时间来分配请求,响应时间短的优先分配。 Nginx 本身
    是不支持 fair 的,如果需要使用这种调度算法,必须下载Nginx的 upstream_fair 模块。

    热备

    服务器处理请求的顺序:AAAAAA突然A挂啦,BBBBBBBBBBBBBB.....

    upstream myweb {
        server 172.17.14.2:8080;
        server 172.17.14.3:8080 backup;  #热备    
     
    }
    

    轮询

    服务器处理请求的顺序:ABABABABAB

    upstream myweb {
        server 172.17.14.2:8080;
        server 172.17.14.3:8080;      
     
    }
    

    加权轮询

    下面服务器的请求顺序为:ABBABBABBABBABB....默认为1

    upstream myweb {
        server 172.17.14.2:8080 weight=1;
        server 172.17.14.3:8080 weight=2;
    }
    

    ip_hash

    nginx会让相同的客户端ip请求相同的服务器。

    upstream myweb {
        server 172.17.14.2:8080;
        server 172.17.14.3:8080;
        ip_hash;
    
    }
    

    nginx负载均衡配置状态参数

    down,表示当前的server暂时不参与负载均衡。
    backup,预留的备份机器。当其他所有的非backup机器出现故障或者忙的时候,才会请求
    backup机器,因此这台机器的压力最轻。
    max_fails,允许请求失败的次数,默认为1。当超过最大次数时,返回proxy_next_upstream 模
    块定义的错误。
    fail_timeout,在经历了max_fails次失败后,暂停服务的时间。max_fails可以和fail_timeout一起
    使用。

    upstream myweb {
    server 172.17.14.2:8080 weight=2 max_fails=2 fail_timeout=2;
    server 172.17.14.3:8080 weight=1 max_fails=2 fail_timeout=1;
    }

    nginx配置4层协议方法(扩展)

    /etc/nginx/nginx.conf

    向该文件nginx.conf写入,stream与http同级

    stream {
     
    upstream mytest1 {
          server 192.168.122.110:80;
          server 192.168.122.111:80;
      }
      server {
          listen      10.0.122.156:8888;  
          proxy_connect_timeout 10s;
          proxy_timeout 30s;
          proxy_pass mytest1;  # 定义的负载均衡服务器列表
      } 
      upstream mytest2 {
          server 192.168.122.112:80;
          server 192.168.122.113:80;
      }
      server {
          listen     10.0.122.156:8989;
          proxy_connect_timeout 10s;
          proxy_timeout 30s;
          proxy_pass mytest2;
     
    }
    }
    

    负载均衡

    proxy_connect_timeout 1; #nginx服务器与被代理的服务器建立连接的超时时间,默认60秒
    proxy_read_timeout 1; #nginx服务器想被代理服务器组发出read请求后,等待响应的超时间,默认为
    60秒。
    proxy_send_timeout 1; #nginx服务器想被代理服务器组发出write请求后,等待响应的超时间,默认
    为60秒。
    proxy_ignore_client_abort on; #客户端断网时,nginx服务器是否终端对被代理服务器的请求。默
    认为off。
    proxy_next_upstream timeout; #反向代理upstream中设置的服务器组,出现故障时,被代理服务
    器返回的状态值。
    error|timeout|invalid_header|http_500|http_502|http_503|http_504|http_404|off

    相关文章

      网友评论

          本文标题:Nginx负载均衡

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