Nginx负载均衡的6种配置

配置思路

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服务
在这里插入图片描述

  • 1
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值