简述Nginx 常用的应用场景第四篇:负载均衡

工作中Nginx经常被用来做负载均衡,负载均衡其意思就是分发请求到不同后端服务器,而不是指着一个人使劲用。当有2台或以上服务器时,根据设置的规则将请求分发到相应的服务器上处理,负载均衡配置一般都需要同时配置反向代理,通过反向代理跳转到负载均衡。而Nginx目前支持自带3种负载均衡策略,还有2种常用的第三方策略。

负载均衡通过upstream指令来实现。

1. RR(round robin :轮询 默认的负载均衡策略):

将接收到的请求按顺序循环的轮询下去,服务器接收请求的比例是 1:1,

如果某后端服务器挂掉,会自动剔除。

同一个项目分别使用10111和10112端口启动项目

upstream web_servers {  
   server localhost:10111;  
   server localhost:10112;  
}

server {
    listen       80;
    server_name  localhost;
    #access_log  logs/host.access.log  main;


    location / {
        proxy_pass http://web_servers;
        # 必须指定Header Host
        proxy_set_header Host $host:$server_port;
    }
 }

2. 权重

权重分配实际就是按指定比例分配,就好股票占比一样;

指定轮询几率,服务器接收请求的比例就是各自配置的weight的比例,后端服务器性能不均时根绝各自服务器性能设置权重值;

upstream test {
    server localhost:10111 weight=1;
    server localhost:10112 weight=3;
    server localhost:10113 weight=4 backup;
}

示例是4次请求只有一次被分配到10111上,其他3次分配到10112上。backup是指热备,只有当10111和10112都宕机的情况下才走10113.

3. ip_hash

上面的2种方式都有一个问题,那就是下一个请求来的时候请求可能分发到另外一个服务器,当我们的程序不是无状态的时候(采用了session保存数据),这时候就有一个很大的很问题了,比如把登录信息保存到了session中,那么跳转到另外一台服务器的时候就需要重新登录了,所以很多时候我们需要一个客户只访问一个服务器,那么就需要用iphash了,iphash的每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。


4. fair(第三方)

按服务器的响应时间来分配请求,响应时间短的优先分配。此配置能给与用户较快的响应;注意:使用第三方fair时,nginx需要添加fair模块,可以自行百度如何添加

upstream backend {
    fair;
    server localhost:10111;
    server localhost:10112;
}

5. url_hash(第三方)

按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法;

注意:需要安装第三方模块url_hash

upstream backend {
    hash $request_uri;
    hash_method crc32;
    server localhost:10111;
    server localhost:10112;
}

以上5种负载均衡适用不同情况下使用,可以根据实际情况选择使用哪种策略模式;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值