Nginx的运用配置(四)负载均衡

负载均衡是nginx的一个重要的功能,在高并发的系统下,需要采用集群或是分布式的服务进行部署,nginx的负载均衡就是将客户端的请求分摊到各个操作单元机器上

负载方式:

1、轮询(默认)

upstream www_servers{  
   server localhost:8081;  
   server localhost:8082;  
}
server {
    listen       80;
    server_name  localhost;
    #access_log  logs/host.access.log  main;
    location / {
        proxy_pass http://www_servers;
        # 必须指定Header Host
        proxy_set_header Host $host:$server_port;
    }
 }

2、权重

weight越大 权重越高

upstream www_servers{  
   server localhost:8081 weight=1;  
   server localhost:8082 weight=2; 
   server localhost:8083 weight=4 backup;
}

假如3次请求 8081 1次,8082 2次

backup是指热备,只有当8081和8082都宕机的情况下才走8083。

3、ip_hash

大家都知道当我们的服务不是无状态的,采用session保存数据比如登录信息,那么如果采用轮询的话那么轮询到一台新的服务器的话,那么就找不到对应session了,所以ip_hash就是让一个客户之访问一个服务器,那么就要用ip_hash,每个请求都是按照ip的hash结果分配

upstream www_servers{
    ip_hash;
    server localhost:8080;
    server localhost:8081;
}

4、fair

按后端服务器的响应时间来分配请求,响应时间短的优先分配。这个配置是为了更快的给用户响应。

upstream www_servers{
    fair;
    server localhost:8080;
    server localhost:8081;
}

5、url hash

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

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

以上5种负载均衡最常用的还是第一二三种,也可以根据实际情况选择使用哪种策略模式,不过fair和url_hash需要安装第三方模块才能使用。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值