路飞学城Python-Day182

Evernote Export

集群介绍
1.集群介绍
集群:将多个物理机器组成一个逻辑计算机,实现负载和容错
计算机集群简称集群,是一种计算机系统,它通过一组松散集成的计算机软件或硬件连接起来高度紧密地完成计算工作,在某种意义上,他们可以被看做是一台计算机。
组成要素
1.VIP:一个IP地址
2.分发器:nginx
3.数据服务器:Web服务器
传统web访问模型
用户发起请求
服务器接收请求
服务器处理请求(压力最大)
服务器响应请求
缺点:
单点故障
单台服务器资源有限
单台服务器处理耗时长

单点服务器的解决办法:
1.部署一台备份服务器,宕机直接切换
服务器利用率低,成本高,切换不及时,服务器压力依然大
2.部署多台服务器,根据DNS的轮询解析机制去实现用户分发
优势是用户处理速度得到了提升,但是其中一台有故障就会有一部分用户访问不了
3.使用DNS轮询方案
4.多级阵列-集群模式

2.Nginx集群原理
在该集群中Nginx扮演的角色是分发器
任务:接受请求、分发请求、响应请求
功能模块:
1.ngx_http_upstream_moudle  基于应用层分发
2.ngx_stream_core_moudle 基于传输层分发模块
Nginx集群其实是:虚拟主机+反向代理+upstream分发模块组成
虚拟主机:接受和响应请求
反向代理:带用户去数据服务器拿数据
upstream:告诉Nginx去哪个数据服务器拿数据
数据走向:
虚拟主机接受用户请求
虚拟主机去找反向代理
反向代理让去找upstream
upstream告诉一个数据服务器IP
Nginx去找数据服务器并发起请求
数据服务器接收并处理请求
数据服务器响应请求给nginx
nginx响应请求给用户
3.实现基于Nginx分发器的web集群
Nginx安装
配置业务服务器页面
配置nginx分发器
测试分发
nginx集群默认算法
upstream module 
nginx的upstream目前支持4种方式的分配
1.轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除
2.weight
指定轮询几率,weight和访问比率成正比,用户后端服务器性能不均的情况
3.ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session问题
4.fair(第三方)
按后端服务器的响应时间来分配请求,响应时间段的优先分配
5.url_hash(第三方)
按访问url的结果来分配请求,使每个url定向到同一个后端服务器,后端为缓存时比较有效。
每个设备的状态设置
1.down表示当前的server暂时不参与负载
2.weight默认为1.weight越大,负载的权重就越大
3.max_fails:允许请求失败的次数默认为1,1.当超过最大次数时,返回proxy_next_upstream模块定义的错误
4.fail_timeout:失败超时时间,在连接server时,如果在超时时间之内超过max_fails指定的失败次数,会认为在fail_timeout时间内server不可用,默认为10s
5.backup:其他所有的非backup机器down或者忙的时候,请求backup机器,所以这台机器压力会最轻
4.测试

猜你喜欢

转载自www.cnblogs.com/pandaboy1123/p/10154485.html
今日推荐