0 Comments

负载均衡配置实例

发布于:2013-02-28  |   作者:广州网站建设  |   已聚集:人围观
负载均衡配置实例

下面通过Nginx的反向代理功能配置一个Nginx负载均衡服务器。后端有3个服务节点,用于提供Web服务,通过Nginx的调度实现3个节点的负载均衡。

广州网站建设,网站建设,广州网页设计,广州网站设计
  1. http  
  2. {  
  3.  upstream  myserver {  
  4.    server   192.168.12.181:80 weight=3 max_fails=3 fail_timeout=20s;  
  5.    server   192.168.12.182:80 weight=1 max_fails=3 fail_timeout=20s;  
  6.    server   192.168.12.183:80 weight=4 max_fails=3 fail_timeout=20s;  
  7.  }  
  8.  
  9.  server  
  10.  {  
  11.     listen       80;  
  12.      server_name  www.domain.com 192.168.12.189;  
  13.      index index.htm index.html;  
  14.      root  /ixdba/web/wwwroot;  
  15.  
  16. location / {  
  17.      proxy_pass http://myserver;  
  18.      proxy_next_upstream http_500 http_502 http_503 error timeout invalid_header;  
  19.     include    /opt/nginx/conf/proxy.conf;  
  20.     }  
  21.  }  

在上面这个配置实例中,先定义了一个负载均衡组myserver,然后在location部分通过“proxy_pass  http://myserver”实现负载调度功能,其中proxy_pass指令用来指定代理的后端服务器地址和端口,地址可以是主机名或者IP地址,也可以是通过upstream指令设定的负载均衡组名称。

proxy_next_upstream用来定义故障转移策略,当后端服务节点返回500、502、503、504和执行超时等错误时,自动将请求转发到upstream负载均衡组中的另一台服务器,实现故障转移。最后通过include指令包含进来一个 proxy.conf文件。

其中/opt/nginx/conf/proxy.conf的内容如下:

广州网站建设,网站建设,广州网页设计,广州网站设计
  1. proxy_redirect off;  
  2. proxy_set_header Host $host;  
  3. proxy_set_header X-Real-IP $remote_addr;  
  4. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
  5.  client_body_buffer_size 128k;  
  6. proxy_connect_timeout 90;  
  7. proxy_send_timeout 90;  
  8. proxy_read_timeout 90;  
  9. proxy_buffer_size  4k;  
  10. proxy_buffers 4 32k;  
  11. proxy_busy_buffers_size 64k;  
  12. proxy_temp_file_write_size 64k; 

 

Nginx的代理功能是通过http proxy模块来实现的。默认在安装Nginx时已经安装了http proxy模块,因此可直接使用http proxy模块。下面详细解释proxy.conf文件中每个选项代表的含义。

proxy_set_header:设置由后端的服务器获取用户的主机名或真实IP地址,以及代理者的真实IP地址。

client_body_buffer_size:用于指定客户端请求主体缓冲区大小,可以理解为先保存到本地再传给用户。

proxy_connect_timeout:表示与后端服务器连接的超时时间,即发起握手等候响应的超时时间。

proxy_send_timeout:表示后端服务器的数据回传时间,即在规定时间之内后端服务器必须传完所有的数据,否则,Nginx将断开这个连接。

proxy_read_timeout:设置Nginx从代理的后端服务器获取信息的时间,表示连接建立成功后,Nginx等待后端服务器的响应时间,其实是Nginx已经进入后端的排队之中等候处理的时间。

proxy_buffer_size:设置缓冲区大小, 默认该缓冲区大小等于指令proxy_buffers设置的大小。

proxy_buffers:设置缓冲区的数量和大小。Nginx从代理的后端服务器获取的响应信息,会放置到缓冲区。

proxy_busy_buffers_size:用于设置系统很忙时可以使用的proxy_buffers大小,官方推荐的大小为proxy_buffers×2。

proxy_temp_file_write_size:指定proxy缓存临时文件的大小。

标签:
飞机