Nginx负载均衡

负载均衡原理

负载均衡:顾名思义,是一种策略,用于防止一台服务器过载,而其他服务器闲置情况发生的策略。当客户端发起一个请求后,负载均衡会通过预先设定好的策略将该请求转发给上游的服务器进行处理。
在这里插入图片描述

负载均衡调度算法

  • 轮询:(Round-Robin):每一次把来自用户的请求轮流分配给内部中的服务器,从1开始,直到N(内部服务器个数),然后重新开始循环。
  • 权重(weight):指定轮询几率,weight和访问比率成正比,主要用于后端服务器性能不均的情况,默认每个服务器的weight权重是1,如果后端服务器down掉,能自动剔除。
  • fair:按后端服务器的响应时间来分配请求,响应时间短的优先分配。
  • Hash:通过使用客户端信息(如:$ip, $uri, $args等变量)作为参数,使用hash或consistent_hash算法将客户端映射到后端节点。

普通hash与consistent_hash

  • 普通hash:key=HASH(object)%N中,节点N数量发生变化,则需重新按照公式key=HASH(object)%(N-i)计算,之前计算得到的key值会全部发生变化,意味着缓存节点下缓存的数据全部失效,要重新缓存全部节点数据。如果是高并发大数据,对后端节点服务器的冲击是致命的,很有可能会导致系统的全面瘫痪。
  • consistent_hash:机器通过一定的hash算法处理后映射到环上,key=HASH(object)。环形Hash空间是用hash算法将对应的key哈希到一个具有232次方个桶的空间中,即0~(232)-1的数字空间中。将这些数字头尾相连,形成一个闭合的环形。如下图:
    在这里插入图片描述

负载均衡应用

在这里插入图片描述

  • consistent_hash
  • upstream模块配置
  • nginx的https配置
  • nginx统一认证(auth_basic认证+token)
    nginx负载均衡配置
upstream  exastrean{
    hash $arg_md5 consistent; //参数一致性hash
    server 127.0.0.1:443;
    server 192.168.1.1:443;
    server 192.168.1.2:443;
    check interval=3000 rise=2 fall=5 timeout=1000 type=ssl_hello;
    //nginx_upstream_check_module 来检查后端服务器的健康情况
}
......
location / {
    ......
    proxy_pass https://exastream;         
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值