配置思路
Nginx做负载均衡,需要借助nginx的upstream模块和proxy_pass反向代理模块共同实现
upstream模块:
用来定义服务器组,将后端服务器添加到组中,并定义向后调度的算法!
proxy_pass模块:
实现反向代理,将接受到请求转发给upstream定义的服务器组
实验逻辑图如图所示:
服务器均为 centos6 操作系统
实验之前的操作
开始实验之前关闭所有服务器的防火墙和selinux
Nginx负载均衡器的配置
安装NGINX
在NGINX负载均衡器上源码安装NGINX
超链接>>
安装教程
NGINX负载均衡配置
修改NGINX配置文件
[root@localhost ~]# vim /usr/local/nginx/conf/nginx.conf
NGINX负载均衡的算法一共有6种
1. 轮询算法 (默认)
请求被平均调度给了不同的服务器来处理
配置如下:
开启NGINX服务
[root@localhost nginx-1.18.0]# /usr/local/nginx/sbin/nginx
实验效果
2. 加权轮询算法(weight)
当为服务器指定权重参数时, 权重将作为负载均衡决策的一部分。
重启NGINX服务
[root@localhost nginx-1.18.0]# /usr/local/nginx/sbin/nginx -s reload
实验效果
3. 最小连接算法(least_conn)
在连接负载最小的情况下,nginx会尽量避免使用过多的请求来过载繁忙的应用程序服务器,而将新的请求分发给不太繁忙的服务器。
效果
4. ip_hash算法
将客户端的IP地址用作散列键,以确定应该为客户端的请求选择服务器组中的哪个服务器。此方法可确保来自同一客户端的请求将始终定向到同一服务器,除非此服务器不可用。
重启NGINX服务
[root@localhost nginx-1.18.0]# /usr/local/nginx/sbin/nginx -s reload
效果如图:
5. url_hash算法
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。
效果
6. fair算法
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
需要安装 nginx-upstream-fair-master 第三方模块
下载地址:
https://github.com/gnosek/nginx-upstream-fair
重新检测nginx编译环境
编译时需要指定添加模块的绝对路径
[root@localhost nginx-1.18.0]# ./configure --with-http_ssl_module --add-module=/root/nginx-upstream-fair-master
编译并安装
[root@localhost nginx-1.18.0]# make && make install
报错
若出现以下报错
error: ‘ngx_http_upstream_srv_conf_t’ has no member named ‘default_port’
解决方法
修改NGINX下的ngx_http_upstream.h文件
[root@localhost ~]# vim nginx-1.18.0/src/http/ngx_http_upstream.h
在ngx_http_upstream_srv_conf_s结构添加一行 in_port_t default_port
然后重新编译安装就可以了
修改NGINX的配置文件
指定算法为fair算法
修改完之后保存退出
重启NGINX服务
[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload
webserver1的配置
安装Apache服务
创建测试页面
开启Apache服务
webserver2的配置
安装Apache服务
参加测试页面
开启Apache服务