nginx调度算法

1. 轮询-roundrobin

  • 一个轮一个的
  • 缺点:有的服务器性能好,有的性能差,性能差的机器接受的请求多了肯定不乐意
upstream servers {
        server 172.28.28.19:80 ;
        server 172.28.28.20:80 ;   
}
#权重weight默认是1

2.加权轮询weight-roundrobin

  • 也是一个一个轮询的,只不过是比例不一样了,比如2:1、3:2之类的
  • weight后的数字不是数值,是比重
upstream servers {
        server 172.28.28.19:80 weight=2 max_fails=2 fail_timeout=30;
        server 172.28.28.20:80 weight=1 max_fails=1 fail_timeout=20;
}

#max_fails 表示的是proxy最多检查几次(针对坏掉的机器)
#fail_timeout  表示的是proxy在每次检查后,间隔多长事件后再去检查

3.源地址ip_hash检测

  • 背景:用户请求登录扣扣,服务器1返回登录界面,用户登录;用户再次请求登录扣扣,服务器2返回登录界面,用户登录
  • 实现:用过ip_hash检测,如果是同一个客户端登录,proxy会把请求始终转发到同一服务器上
  • 相同客户端访问相同的服务器,ip_hash是根据ip地址的前几位进行检测的
upstream servers {
        ip_hash; #此算法是针对整个集群的
        server 172.28.28.19:80 weight=2;
        server 172.28.28.20:80 max_fails=1 fail_timeout=20;
        #server 172.28.28.20:80 down;
    }

#down:服务器出现重大故障,已没必要修复,添加down,把该服务器剔除
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Nginx提供了多种负载均衡调度算法,可以根据实际需求选择适合的算法。以下是常见的Nginx负载均衡调度算法: 1. 轮询(Round Robin):默认的负载均衡算法,按照顺序将请求依次分配给后端服务器,循环往复。 2. 加权轮询(Weighted Round Robin):可以给每个后端服务器设置权重,权重越高的服务器获取到的请求数量就越多。 3. IP哈希(IP Hash):根据客户端的IP地址计算哈希值,将相同IP的请求发送到同一台后端服务器,实现会话保持。 4. 最少连接(Least Connections):将请求发送到当前连接数最少的后端服务器,以实现动态负载均衡。 5. 最快响应时间(Least Time):根据后端服务器的响应时间来选择目标服务器,将请求发送到响应时间最短的服务器上。 这些负载均衡算法可以通过在Nginx配置文件中的`upstream`块中设置`load balancing`指令来进行配置。例如: ```nginx http { upstream backend_servers { round-robin; # 使用轮询算法 server backend1.example.com; server backend2.example.com; } server { listen 80; location / { proxy_pass http://backend_servers; } } } ``` 在上述示例中,`round-robin`指令表示使用轮询算法进行负载均衡。你可以根据需要选择其他算法,并根据实际情况配置后端服务器的地址和权重等信息。 需要注意的是,Nginx负载均衡算法的选择应该根据具体的应用场景和需求来确定,以达到最佳的负载均衡效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

河 静

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值