nginx的使用(5)——配置多个服务器实现负载均衡


前言

负载均衡也是Nginx常⽤的⼀个功能,负载均衡其意思就是分摊到多个操作单元上进⾏执⾏,例如Web服务器、FTP服务器、企 业关键应⽤服务器和其它关键任务服务器等,从⽽共同完成⼯作任务。 简单⽽⾔就是当有2台或以上服务器时,根据规则随机的将请求分发到指定的服务器上处理,负载均衡配置⼀般都需要同时配置 反向代理,通过反向代理跳转到负载均衡。⽽Nginx⽬前⽀持⾃带3种负载均衡策略,还有2种常⽤的第三⽅策略。

一、简单配置

upstream test {
 server localhost:8080;
 server localhost:8081; 
 }
server {
 listen 80;  #监听端口
 server_name localhost;
 client_max_body_size 1024M; 
 location / { 
  proxy_pass http://test;
  proxy_set_header Host $host:$server_port;
  }
}

二、负载均衡访问策略

  1. RR(默认)每个请求按时间顺序逐⼀分配到不同的后端服务器,如果后端服务器down掉,能⾃动剔除。

  2. 权重,指定轮询⼏率,weight和访问⽐率成正⽐,⽤于后端服务器性能不均的情况。如:

    upstream test { 
    server localhost:8080 weight=9; 
    server localhost:8081 weight=1; 
    }
    
  3. ip_hash,上⾯的2种⽅式都有⼀个问题,那就是下⼀个请求来的时候请求可能分发到另外⼀个服务器,当我们的程序不是⽆状态的时候 (采⽤了session保存数据),这时候就有⼀个很⼤的很问题了,⽐如把登录信息保存到了session中,那么跳转到另外⼀台服务 器的时候就需要重新登录了,所以很多时候我们需要⼀个客⼾只访问⼀个服务器,那么就需要⽤iphash了,iphash的每个请求按 访问ip的hash结果分配,这样每个访客固定访问⼀个后端服务器,可以解决session的问题。如:

    upstream test {
     ip_hash; 
     server localhost:8080;
     server localhost:8081; 
    }
    
  4. fair(第三⽅),按后端服务器的响应时间来分配请求,响应时间短的优先分配。

    upstream backend { 
    fair;
    server localhost:8080;
    server localhost:8081;
    }
    
  5. url_hash(第三⽅),按访问url的hash结果来分配请求,使每个url定向到同⼀个后端服务器,后端服务器为缓存时⽐较有效。在upstream中加⼊ hash语句,server语句中不能写⼊weight等其他的参数,hash_method是使⽤的hash算法

    upstream backend {
     hash $request_uri; 
     hash_method crc32; 
     server localhost:8080;
     server localhost:8081;
    }
    

    以上5种负载均衡各⾃适⽤不同情况下使⽤,所以可以根据实际情况选择使⽤哪种策略模式,不过fair和url_hash需要安装第三⽅ 模块才能使⽤,由于本⽂主要介绍Nginx能做的事情,所以Nginx安装第三⽅模块不会再本⽂介绍

总结

负载均衡的关键就是

upstream test {
 server localhost:8080;
 server localhost:8081; 
 }
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值