使用Nginx实现Web反向代理功能,实现如下功能:

  • 后端Web服务器两台,可以使用httpd实现
  • Nginx采用轮询的方式调用后端Web服务器
  • 两台Web服务器的权重要求设置为不同的值
  • 最大失败次数为1,失败超时时间为30秒

方案

使用4台centos7虚拟机,其中一台作为Nginx代理服务器,该服务器需要配置两块网卡,IP地址分别为192.168.4.5和192.168.2.5,两台Web服务器IP地址分别为192.168.2.100和192.168.2.200。客户端测试主机IP地址为192.168.4.10。




nginx 添加收到请求时间戳_nginx代理网卡


步骤一:部署实施后端Web服务器

1)部署后端Web1服务器

后端Web服务器可以简单使用yum方式安装httpd实现Web服务,为了可以看出后端服务器的不同,可以将两台后端服务器的首页文档内容设置为不同的内容。

1. [root@web1 ~]# yum -y install httpd
2. [root@web1 ~]# echo "192.168.2.100" > /var/www/html/index.html
3. [root@web1 ~]# systemctl restart httpd
4. [root@web1 ~]# firewall-cmd --set-default-zone=trusted
5. [root@web1 ~]# setenforce 0

2)部署后端Web2服务器

1. [root@web2 ~]# yum -y install httpd
2. [root@web2 ~]# echo "192.168.2.200" > /var/www/html/index.html
3. [root@web2 ~]# systemctl restart httpd
4. [root@web2 ~]# firewall-cmd --set-default-zone=trusted
5. [root@web2 ~]# setenforce 0

步骤二:配置Nginx服务器,添加服务器池,实现反向代理功能

1. 修改/usr/local/nginx/conf/nginx.conf配置文件
2. [root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
3. .. ..
4. http {
5. .. ..
6. #使用upstream定义后端服务器集群,集群名称任意(如webserver)
7. #使用server定义集群中的具体服务器和端口
8. upstream webserver {
9. 192.168.2.100:80;
10. 192.168.2.200:80;
11. }
12. .. ..
13. server {
14. 80;
15. ;
16. / {
17. #通过proxy_pass将用户的请求转发给webserver集群
18. ://webserver;
19. }
20. }

#使用upstream定义后端服务器集群,集群名称任意(如webserver)

#使用server定义集群中的具体服务器和端口

  1. 重启nginx服务
[root@proxy ~]# /usr/local/nginx/sbin/nginx -s reload

#请先确保nginx是启动状态,否则运行该命令会报错

  1. 客户端使用浏览器访问代理服务器测试轮询效果
[root@client ~]# curl ref="http://192.168.4.5/">http://192.168.4.5 //使用该命令多次访问查看效果
[root@client ~]# curl http://192.168.4.5 //使用该命令多次访问查看效果

步骤三:配置upstream服务器集群池属性

weight可以设置后台服务器的权重,

max_fails可以设置后台服务器的失败次数,

fail_timeout可以设置后台服务器的失败超时时间。

down标记服务器已关机,不参与集群调度

1. [root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
2. .. ..
3. http {
4. .. ..
5. upstream webserver {
6. 192.168.2.100 weight=1 max_fails=1 fail_timeout=30;
7. 192.168.2.200 weight=2 max_fails=2 fail_timeout=30;
8. 192.168.2.101 down;
9. }
10. #weight设置服务器权重值,默认值为1
11. #max_fails设置最大失败次数
12. #fail_timeout设置失败超时时间,单位为秒
13. #down标记服务器已关机,不参与集群调度
14. .. ..
15. server {
16. 80;
17. ;
18. / {
19. ://webserver;
20. }
21. }

重启nginx服务

[root@proxy ~]# /usr/local/nginx/sbin/nginx -s reload

关闭一台后端服务器(如web1)

[root@web1 ~]# systemctl stop httpd

客户端使用浏览器访问代理服务器测试轮询效果

[root@client ~]# curl http://192.168.4.5

再次启动后端服务器的httpd(如web1)

[root@web1 ~]# systemctl start httpd

客户端再次使用浏览器访问代理服务器测试轮询效果

[root@client ~]# curl http://192.168.4.5