Nginx负载均衡的6种配置

  • Post author:
  • Post category:其他




配置思路

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服务

在这里插入图片描述



版权声明:本文为m0_46674735原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。