• Linux下nginx反向代理负载均衡几种方式以及配置


     下面以ip地址192.168.1.1 和192.168.1.2举例

    1.轮询
       (1)、轮询:每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
      upstream backserver {
        server 192.168.1.1;
        server 192.168.1.2;
    }
     注意:Linux中默认修改文件为 /etc/nginx/nginx.conf
     
    (2)weight:指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
      upstream backserver {
        server 192.168.1.1 weight=3;
        server 192.168.1.2 weight=7;
    }
     
      权重越高,在被访问的概率越大,如上例,分别是30%,70%。
      缺点:会造成session丢失,用户信息丢失

    2.ip_hash:如果客户已经访问了某个服务器,当用户再次访问时,会将该请求通过哈希算法,自动定位到该服务器。每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题.
      upstream backserver {
        ip_hash;
        server 192.168.1.1;
        server 192.168.1.2;
    }

    3.fair:按后端服务器的响应时间来分配请求,响应时间短的优先分配。
    upstream backserver {
        server 192.168.1.1;
        server 192.168.1.2;
        fair;
    }
    4.url_hash:按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效
    upstream backserver {
        server 192.168.1.1;
        server 192.168.1.2;
        hash $request_uri;
        hash_method crc32;
    }
    每个设备的状态设置为:
       1.down 表示单前的server暂时不参与负载
       2.weight 默认为1.weight越大,负载的权重就越大。
       3.max_fails:允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream模块定义的错误
       4.fail_timeout:max_fails次失败后,暂停的时间。
        5.backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力  会最轻。

    5.配置方法(此处以8081和8082端口为例)

    vi /nignx目录/nginx.conf

    #添加下面这段 backend可以自由命名

    upstream backend {

       #添加服务器到负载均衡

         server 192.168.1.1:8081 weight=1;

                 server 192.168.1.1:8082 weight=2; #设置该服务器在负载均衡中的权重  默认为1;越高则访问的频次越大

             #    server 192.168.1.3  down;   #表示down掉这台服务器,不参与负载均衡

             #    server 192.168.1.4  backup;  #备用服务器 当其他服务器很忙或者down掉之后才会启动这台的

             }

    #配置参数
    #max_fails :允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误

    #fail_timeout:max_fails次失败后,暂停的时间。

    server {

            listen       80;

            server_name  localhost;

            location / {

                 #反向代理的地址

                 proxy_pass http://backend;     

            }

    }
    这样子就已经配置完成了

    访问192.168.1.1,如果2台服务器能轮询切换就证明配置成功

  • 相关阅读:
    Ubuntu 16 编译装python2.7
    配置ubunto 流量使用限制 python 实现简单 http server
    vnstat 流量统计 并附带一个小 php 查看流量的页面
    ubunto 免输入密码 登录 putty ssh-keygen
    nes 红白机模拟器 第5篇 全屏显示
    arm 添加 samb 文件共享
    arm 添加 ftp server 之 bftpd
    Tga图片格式分析以及程序实现
    领导力:刘邦的管理之道
    AS3:辨析ROLL_OVER与MOUSE_OVER,ROLL_OUT与MOUSE_OUT
  • 原文地址:https://www.cnblogs.com/911sky/p/14188992.html
Copyright © 2020-2023  润新知