Nginx负载均衡

2019-10-09  本文已影响0人  魔曦帝天

单机实战

nginx配置7层协议

/etc/nginx/conf.d/proxy.conf中  

upstream mytest1 {
      
      server 192.168.122.110:80;  # 设置负载均衡
      server 192.168.122.111:80;
      server 192.168.122.112:80;
      server 192.168.122.113:80;
  }
server {
listen 80;
server_name www.proxy.com;
root         /usr/share/nginx/app1;
  access_log   /var/log/www.proxy.log main;
  error_log  
/var/log/www.proxy.error.log;
location / {
              proxy_pass http://mytest1; # 请求转向 代理服务器列表(我代理了谁)
              proxy_set_header Host $http_host;
              proxy_set_header X-Real-IP $remote_addr; 
              proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
              proxy_set_header X-Forwarded-Proto $scheme;
              proxy_set_header X-NginX-Proxy true;
              proxy_connect_timeout 30;   #
              proxy_send_timeout 60;
              proxy_read_timeout 60;
              proxy_buffering on;
              proxy_buffer_size 32k;
              proxy_buffers 4 128k;
              proxy_busy_buffers_size 256k;
              proxy_max_temp_file_size 256k;
   index index.html;  
 }
}

/etc/nginx/conf.d/app1.conf 服务端添加配置

server {
listen 192.168.122.110:80;  # 虚拟主机
server_name www.app1.com;
root         /usr/share/nginx/app1;
  access_log   /var/log/app1.com.log main;
  error_log  
/var/log/app1.com.error.log;

set_real_ip_from 10.0.122.156; ##谁代理了我
location / {

   index index.html;  
 }
}

其他提供服务修改对应ip地址即可

负载均衡算法

A、 轮询(默认) :每个请求按时间顺序逐一分配到不同的后端服务器;
B、 ip_hash :每个请求按访问IP的hash结果分配,同一个IP客户端固定访问一个后端服务器。可以保证
来自同一ip的请求被打到固定的机器上,可以解决session问题。
C、 url_hash :按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器。后台服务器为
缓存的时候效率。
D、 fair :这是比上面两个更加智能的负载均衡算法。此种算法可以依据页面大小和加载时间长短智能
地进行负载均衡,也就是根据后端服务器的响应时间来分配请求,响应时间短的优先分配。 Nginx 本身
是不支持 fair 的,如果需要使用这种调度算法,必须下载Nginx的 upstream_fair 模块。

热备

服务器处理请求的顺序:AAAAAA突然A挂啦,BBBBBBBBBBBBBB.....

upstream myweb {
    server 172.17.14.2:8080;
    server 172.17.14.3:8080 backup;  #热备    
 
}

轮询

服务器处理请求的顺序:ABABABABAB

upstream myweb {
    server 172.17.14.2:8080;
    server 172.17.14.3:8080;      
 
}

加权轮询

下面服务器的请求顺序为:ABBABBABBABBABB....默认为1

upstream myweb {
    server 172.17.14.2:8080 weight=1;
    server 172.17.14.3:8080 weight=2;
}

ip_hash

nginx会让相同的客户端ip请求相同的服务器。

upstream myweb {
    server 172.17.14.2:8080;
    server 172.17.14.3:8080;
    ip_hash;

}

nginx负载均衡配置状态参数

down,表示当前的server暂时不参与负载均衡。
backup,预留的备份机器。当其他所有的非backup机器出现故障或者忙的时候,才会请求
backup机器,因此这台机器的压力最轻。
max_fails,允许请求失败的次数,默认为1。当超过最大次数时,返回proxy_next_upstream 模
块定义的错误。
fail_timeout,在经历了max_fails次失败后,暂停服务的时间。max_fails可以和fail_timeout一起
使用。

upstream myweb {
server 172.17.14.2:8080 weight=2 max_fails=2 fail_timeout=2;
server 172.17.14.3:8080 weight=1 max_fails=2 fail_timeout=1;
}

nginx配置4层协议方法(扩展)

/etc/nginx/nginx.conf

向该文件nginx.conf写入,stream与http同级

stream {
 
upstream mytest1 {
      server 192.168.122.110:80;
      server 192.168.122.111:80;
  }
  server {
      listen      10.0.122.156:8888;  
      proxy_connect_timeout 10s;
      proxy_timeout 30s;
      proxy_pass mytest1;  # 定义的负载均衡服务器列表
  } 
  upstream mytest2 {
      server 192.168.122.112:80;
      server 192.168.122.113:80;
  }
  server {
      listen     10.0.122.156:8989;
      proxy_connect_timeout 10s;
      proxy_timeout 30s;
      proxy_pass mytest2;
 
}
}

负载均衡

proxy_connect_timeout 1; #nginx服务器与被代理的服务器建立连接的超时时间,默认60秒
proxy_read_timeout 1; #nginx服务器想被代理服务器组发出read请求后,等待响应的超时间,默认为
60秒。
proxy_send_timeout 1; #nginx服务器想被代理服务器组发出write请求后,等待响应的超时间,默认
为60秒。
proxy_ignore_client_abort on; #客户端断网时,nginx服务器是否终端对被代理服务器的请求。默
认为off。
proxy_next_upstream timeout; #反向代理upstream中设置的服务器组,出现故障时,被代理服务
器返回的状态值。
error|timeout|invalid_header|http_500|http_502|http_503|http_504|http_404|off

上一篇下一篇

猜你喜欢

热点阅读