Nginx 手记(九)负载均衡
Nginx 手记(九)负载均衡
神奇Sam 发表于3个月前
Nginx 手记(九)负载均衡
  • 发表于 3个月前
  • 阅读 586
  • 收藏 0
  • 点赞 0
  • 评论 0

腾讯云 新注册用户 域名抢购1元起>>>   

实现原理

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;
}
标签: Nginx CentOS Linux
共有 人打赏支持
粉丝 16
博文 41
码字总数 27998
×
神奇Sam
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: