Nginx 手记(九)负载均衡

实现原理

Nginx使用proxy_pass,把请求转发到后端一组服务池(upstream server)上,根据相关负载均衡规则来指定一台提供服务的服务端进行请求的处理。

一、基本语法配置

#upstream server
语法:upstream name{ ... }
默认值:无
上下文:http

如:
upstream backend {
    server backend1.example.com     weight=5;   #weight轮询权重
    server backend2.example.com:8080;
    server unix:/tmp/backend3;
    
    server backup1.example.com:8080     backup; #备份节点
    server backup2.example.com:8080     backup; #备份节点
}

简单用例
#轮询负载均衡
upstream backend {
    server 127.0.0.1:8001;
    server 127.0.0.1:8002;
    server 127.0.0.1:8003;
}
server {
    listen       80;
    server_name  localhost www.sam.com;

    #charset koi8-r;
    #access_log  /var/log/nginx/host.access.log  main;

    location / {
        proxy_pass http://backend;
        
        #当命中的服务器出现错误、超时、请求头不完整、500、502、503时,会跳过这一台服务器去访问下一台服务器。
        proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
        
        proxy_redirect default; #一般配置默认即可
        
        #添加头信息
        proxy_set_header Host $http_host;
        proxy_set_header X-Real-IP $remote_addr;
        
        #配置超时
        proxy_connect_timeout 30;
        proxy_send_timeout 60;
        proxy_read_timeout 60;
        
        #配置缓冲区,
        proxy_buffer_size 32k;
        proxy_buffering on;
        proxy_buffers 4 128k;
        proxy_busy_buffers_size 256k;
        proxy_max_temp_file_size 256k;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
    
}

二、后端服务器在负载均衡调度中的状态

down            当前的server暂时不参与负载均衡
backup          预留的备份服务器
max_fails       允许请求失败的次数
fail_timeout    经过max_fails失败后,服务暂停的时间
max_conns       限制最大的接收的连接数
例子
upstream backend {
    server 127.0.0.1:8001 down;     #不提供服务
    server 127.0.0.1:8002 backup;   #备份服务,如果8003挂了 将会提供服务
    server 127.0.0.1:8003 max_fails=1 fail_timeout=10s;
}

三、负载均衡策略 - 调度算法

轮询            按时间顺序逐一分配到不同的后端服务器
加权轮询        weight值越大,分配到的访问几率越高
ip_hash         每个请求按访问IP的hash结果分配,这样来自同一个IP的固定访问同一个后端服务器
url_hash        按照访问的URL的hash结果来分配请求,是每个URL定向到同一个后端服务器,通过hash关键数值实现
least_conn      最少连接数,哪个机器连接数少就分配到哪个机器
hash关键数值    hash自定义的key
1、轮询与加权轮询
#轮询与加权轮询
#理论上:当有7个请求过来的时候,将会有5个请求命中8002机器
upstream backend {
    server 127.0.0.1:8001;
    server 127.0.0.1:8002 weight=5; #5权重
    server 127.0.0.1:8003;
}
2、ip_hash基于ip的hash值实现负载均衡
#每个请求按访问IP的hash结果分配,这样来自同一个IP的固定访问同一个后端服务器
upstream backend {
    ip_hash;
    server 127.0.0.1:8001;
    server 127.0.0.1:8002;
    server 127.0.0.1:8003;
}
3、url_hash基于url的hash值实现负载均衡
#按照访问的URL的hash结果来分配请求,是每个URL定向到同一个后端服务器
upstream backend {
    hash $request_uri;      #请求参数,如 http://www.sam.com/index.html 中的 /index.html
    server 127.0.0.1:8001;
    server 127.0.0.1:8002;
    server 127.0.0.1:8003;
}

转载于:https://my.oschina.net/magicalSam/blog/1526151

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值