今天来实践一下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了
再刷新一次
再刷新
可以看到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机器。所以这台机器压力会最轻。