如图所示:
客户机和两个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;
}
写总结的第十七天!!!