Nginx反向代理(web服务器)

如图所示:
在这里插入图片描述
客户机和两个web服务器不在同一个网段中,因此无法直接请求web服务。但是Nginx代理服务器,有两个ip地址,可以和客户机进行通信,也可以和web服务器进行通信。
在配置之前需要关闭防火墙和selinux。

	配置nginx服务器:
	vim /usr/local/nginx/conf/nginx.conf
	upstream webserver {		# 使用upstream创建一个名为webserver的集群。
		server 192.168.2.100:80;	# web1服务器上的 http服务
		server 192.168.2.200:80;	# web2服务器上的http服务
	}
	server {
		listen 80;	# nginx的http服务是80端口。
		server_name localhost:	# 域名,想要启用域名需要dns,或者修改本地/etc/hosts
		location / {	# 所有的http请求
			proxy_pass http://webserver;	# 将请求转发给webserver集群(这句话具有最高优先级)
			root html; # 可以不定义
			index index.html;	# 可以不定义
		}
	}

	重启nginx服务:nginx -s reload
	这样请求 http://192.168.4.5	就可以访问 web1,或者web2的http了。
	nginx代理采用的是轮询的方式,把请求分配在不同的web服务器上,这样可以做到负载均衡。

集群属性:

	upstream xxxx {
		server xxxx:xx [集群属性];
	}
	集群属性可以是weight,max_fails,fail_timeout,down这几个,{max_fails,fail_timeout}通常一起使用。
	
	weight:表示权值,默认是1,对于服务的请求,按照权值进行分配。
	max_fails:表示最大失败连接次数。如果max_fails = 2,则表示再失败两次之后不再进行连接。
	fail_timeout:表示超时时间。如果fail_timeout=20,则表示连接失败之后20之内不再进行连接。
	down:标记服务器已经关机,不参与集群的调度。

设置相同的客户机访问相同的服务器:

	nginx代理服务器,采用的是轮询的方式把请求分发给web服务器的,如果现在有10台服务器,
	则请求会依次转发给这10太服务器,如果有登录的请求,则需要请求10次,并且输入10次账号密码。
	因此当客户机的请求固定在某一台服务器上。(第一次请求是轮询,之后的请求就是固定服务器了。)
	upstream webserver {
		ip_hash;	# 设置调度规则,相同的客户机向固定的服务器发送请求。
		server xxxxx:xx;
		server xxxxx:xx;
	}

写总结的第十七天!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值