Nginx反向代理配置

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

[root@web1~]# yum-y  install  httpd
[root@web1~]# echo"192.168.2.100">/var/www/html/index.html
[root@web1~]# systemctl restart httpd

2)部署后端Web2服务器

[root@web2~]# yum-y  install  httpd
[root@web2~]# echo"192.168.2.200">/var/www/html/index.html
[root@web2~]# systemctl restart httpd

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

1)修改/usr/local/nginx/conf/nginx.conf 配置文件

[root@proxy~]#vim /usr/local/nginx/conf/nginx.conf
....
http{
....
#使用upstream定义后端服务器集群,集群名称任意(如webserver)
#使用server定义集群中的具体服务器和端口
upstream webserver{
server192.168.2.100:80;
server192.168.2.200:80;
}
....
server{
listen80;
server_name  localhost;
location /{
#通过proxy_pass将用户的请求转发给webserver集群
proxy_pass http://webserver;
}
}

2)重新加载配置

[root@proxy~]#/usr/local/nginx/sbin/nginx-s reload
#请先确保nginx是启动状态,否则运行该命令会报错,报错信息如下:
#[error]open()"/usr/local/nginx/logs/nginx.pid"failed(2:No such file or directory)

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

[root@client~]# curl http://192.168.4.5            //使用该命令多次访问查看效果
[root@client~]# curl http://192.168.4.5            //使用该命令多次访问查看效果

配置upstream服务器集群池属性

1)设置失败次数,超时时间,权重
weight可以设置后台服务器的权重,max_fails可以设置后台服务器的失败次数,fail_timeout可以设置后台服务器的失败超时时间。

[root@proxy~]#vim /usr/local/nginx/conf/nginx.conf
....
http{
....
upstream webserver{
server192.168.2.100weight=1max_fails=1fail_timeout=30;
server192.168.2.200weight=2max_fails=2fail_timeout=30;
server192.168.2.101down;
}
#weight设置服务器权重值,默认值为1
#max_fails设置最大失败次数,测试服务器几次才确认服务器失败
#fail_timeout设置失败超时时间,单位为秒
#down标记服务器已关机,不参与集群调度
....
server{
listen80;
server_name  localhost;
location /{
proxy_pass http://webserver;
}
}

2)重新加载配置

[root@proxy~]#/usr/local/nginx/sbin/nginx-s reload
#请先确保nginx是启动状态,否则运行该命令会报错,报错信息如下:
#[error]open()"/usr/local/nginx/logs/nginx.pid"failed(2:No such file or directory)

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

[root@web1~]# systemctl stop httpd

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

[root@client~]# curl http://192.168.4.5            //使用该命令多次访问查看效果

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

[root@web1~]# systemctl start httpd

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

[root@client~]# curl http://192.168.4.5            //使用该命令多次访问查看效果

配置upstream服务器集群的调度算法

1)设置相同客户端访问相同Web服务器

[root@proxy~]#vim /usr/local/nginx/conf/nginx.conf
....
http{
....
upstream webserver{
#通过ip_hash设置调度规则为:相同客户端访问相同服务器
ip_hash;
server192.168.2.100weight=1max_fails=2fail_timeout=10;
server192.168.2.200weight=2max_fails=2fail_timeout=10;
}
....
server{
listen80;
server_name  www.tarena.com;
location /{
proxy_pass http://webserver;
}
}

2)重新加载配置

[root@proxy~]#/usr/local/nginx/sbin/nginx-s reload
#请先确保nginx是启动状态,否则运行该命令会报错,报错信息如下:
#[error]open()"/usr/local/nginx/logs/nginx.pid"failed(2:No such file or directory)

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

[root@client~]# curl http://192.168.4.5            //使用该命令多次访问查看效果



作者:一个小运维
链接:https://www.jianshu.com/p/de36b240c654

相关资源:

java 对Redis的导入和导出 - Dcsdn 

Redis数据的导出和导入 - Dcsdn 

GitOps 初探 - Dcsdn

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值