前言

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

一、简单配置

  1. upstream test {
  2. server localhost:8080;
  3. server localhost:8081;
  4. }
  5. server {
  6. listen 80; #监听端口
  7. server_name localhost;
  8. client_max_body_size 1024M;
  9. location / {
  10. proxy_pass http://test;
  11. proxy_set_header Host $host:$server_port;
  12. }
  13. }

二、负载均衡访问策略

  1. RR(默认)每个请求按时间顺序逐⼀分配到不同的后端服务器,如果后端服务器down掉,能⾃动剔除。
  2. 权重,指定轮询⼏率,weight和访问⽐率成正⽐,⽤于后端服务器性能不均的情况。如:

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

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

    1. upstream backend {
    2. fair;
    3. server localhost:8080;
    4. server localhost:8081;
    5. }
  5. url_hash(第三⽅),按访问url的hash结果来分配请求,使每个url定向到同⼀个后端服务器,后端服务器为缓存时⽐较有效。在upstream中加⼊ hash语句,server语句中不能写⼊weight等其他的参数,hash_method是使⽤的hash算法
    以上5种负载均衡各⾃适⽤不同情况下使⽤,所以可以根据实际情况选择使⽤哪种策略模式,不过fair和url_hash需要安装第三⽅ 模块才能使⽤,由于本⽂主要介绍Nginx能做的事情,所以Nginx安装第三⽅模块不会再本⽂介绍

    1. upstream backend {
    2. hash $request_uri;
    3. hash_method crc32;
    4. server localhost:8080;
    5. server localhost:8081;
    6. }

总结

负载均衡的关键就是

  1. upstream test {
  2. server localhost:8080;
  3. server localhost:8081;
  4. }