Nginx配置upstream实现负载均衡

 

今天来实践一下upstream的应用,环境如下:

名称 server1(Nginx) server2(Apache + PHP) sever3(Apache + PHP) server4(Nginx + PHP)
IP 192.168.10.3 192.168.10.4 192.168.10.5 192.168.10.6

目的是通过upstream的几种用法,将server1的请求转发到后面的几台server,实现负载均衡

 

一、轮询(默认)

在nginx.conf配置文件中的http节点下,添加upstream节点test

[root@localhost ~]# vim /usr/local/nginx/conf/nginx.conf
upstream test {
        server 192.168.10.4;
        server 192.168.10.5;
        server 192.168.10.6;
    }

在server节点中的location节点添加proxy_pass,并配置为http:// + upstream节点名

location / {
            root   html;
            index  index.html index.htm;
            proxy_pass  http://test;
        }

重新加载一下nginx配置文件

[root@localhost ~]# systemctl reload nginx

访问server1的ip,可以看到请求被转发到了server3了

Nginx配置upstream实现负载均衡_第1张图片

再刷新一次

Nginx配置upstream实现负载均衡_第2张图片

再刷新

Nginx配置upstream实现负载均衡_第3张图片

可以看到upstream按照轮询(默认)方式进行负载,每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。虽然这种方式简便、成本低廉。但缺点是:可靠性低和负载分配不均衡。适用于图片服务器集群和纯静态页面服务器集群。

 

二、weight(权重)

还是配置upstream节点,这次我们剔除掉server3,server2的权重为server3的一倍

upstream test {
        server 192.168.10.4 weight=2;
        server 192.168.10.5 weight=1;
        #server 192.168.10.6;
    }

 weight和访问比率成正比,请求三次其中两次会分配到server2,用于后端服务器性能不均的情况

 

三、ip_hash(访问ip

upstream test {
        ip_hash;
        server 192.168.10.4;
        server 192.168.10.5;
        server 192.168.10.6;
    }

每次请求都会分配到server3,ip_hash根据每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题

 

upstream还可以为每个设备设置状态值,这些状态值的含义分别如下:

    down 表示单前的server暂时不参与负载

    weight 默认为1.weight越大,负载的权重就越大。

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

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

    backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。

你可能感兴趣的:(SERVER)