点击“蓝字”关注我们
#今日份技术干货#
使用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。
步骤一:部署实施后端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[root@web2 ~]# echo "192.168.2.200" > /var/www/html/index.html
2、[root@web2 ~]# systemctl restart httpd
3、[root@web2 ~]# firewall-cmd --set-default-zone=trusted
4、[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、server 192.168.2.100:80;
10、server 192.168.2.200:80;
11、}
12、..../
13、server {
14、listen 80;/
15、server_name localhost;
16、location /{
17、#通过proxy_pass将用户的请求转发给webserver集群/
18、proxy_pass http://webserver;
19、}/
20、}
#使用upstream定义后端服务器集群,集群名称任意(如webserver)
#使用server定义集群中的具体服务器和端口
重启nginx服务
[root@proxy ~]# /usr/local/nginx/
sbin/nginx -s reload
#请先确保nginx是启动状态,否则运行该命令会报错
客户端使用浏览器访问代理服务器测试轮询效果
[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、server 192.168.2.100 weight=
1 max_fails=1 fail_timeout=30;
7、server 192.168.2.200 weight=2
max_fails=2 fail_timeout=30;
8、server 192.168.2.101 down;
9、}/
10、#weight设置服务器权重值,默认值为1
11、#max_fails设置最大失败次数/
12、#fail_timeout设置失败超时时间,单位为秒
13、#down标记服务器已关机,不参与集群调度/
14、....
15、server {/
16、listen 80;
17、server_name localhost;
18、location /{
19、proxy_pass http://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
#Nginx#
为方便五湖四海的Linux爱好者共同
学(吹)习(牛)讨(打)论(趣)
热烈欢迎大家加入专属QQ群
群内定时上传资料还有老师全天答疑
入群即可免费获得
1、必备工具源码包
2、内部精选电子书
3、运维资料大礼包
欲知更多福利,欢迎你的加入
点击“阅读原文”