指引网

当前位置: 主页 > 服务器 > Nginx >

CentOS6中Nginx负载均衡及轮询分流负载均衡例子

来源:网络 作者:佚名 点击: 时间:2017-06-13 21:34
[摘要]  负载均衡我们通常有许多的方法,今天小编整理了一篇负载均衡的配置教程,这个一个是常规的配置另一个是轮询实现负载均衡了,这个有点像cdn加速一样的道理。

方法一,nginx 轮询分流实现负载均衡

准备工作,3台服务器,或者开虚拟机吧!我就是开虚拟机实现的。
    ip分别为:192.168.1.10  192.168.1.11  192.168.1.12   (环境安装了ngixn 没有做任何配置)
    3台服务器环境最好一样,我是再vm里直接克隆出来的,环境绝对一样吧!不一样,我估计会遇到很多奇怪的问题,没试过。

    192.168.1.10  作为  负载均衡服务器  (一会负载均衡就在这里台服务器做配置,另外2台不用做配置)
    
   先了解下负载一些常见知识
  
nginx 的 upstream目前支持 4 种方式的分配
1)、轮询(默认)
      每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
2)、weight
      指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
2)、ip_hash
      每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。 
3)、fair(第三方)
      按后端服务器的响应时间来分配请求,响应时间短的优先分配。 
4)、url_hash(第三方)

    可以开始配置了。打开192.168.1.10 的nginx.conf  只需要在配置文件增加如下代码

upstream  netkou  { 
          server   192.168.1.11:80; 
          server   192.168.1.12:80; 

 
server { 
  listen 80; 
  server_name www.111cn.net; 
  location / { 
     proxy_pass        http://www.111cn.net; 
     proxy_set_header   Host             $host; 
     proxy_set_header   X-Real-IP        $remote_addr; 
     proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for; 
  } 
  access_log logs/access_log; 
  error_log logs/error_log; 

实践结果: 

    www.111cn.net  我通过修改host 指向了  192.168.1.10
    未了使测试结果明显,我修改了ngixn默认页面的html
    vi /usr/local/nginx/html/index.html
   再index.html 加入显示本机ip
  192.168.1.11 和  192.168.1.12  都要修改,这样测才明显
    我通过本机浏览器,输入 www.111cn.net
    每次刷新,都会跳转到不同的服务器上页面(当然我这个是为了明显所以用的是轮询的方式,大家可以根据自己需求进行修改)

方法二,Nginx服务器负载均衡配置实例


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


upstream myserver {
server 192.168.12.181:80 weight=3 max_fails=3 fail_timeout=20s;
server 192.168.12.182:80 weight=1 max_fails=3 fail_timeout=20s;
server 192.168.12.183:80 weight=4 max_fails=3 fail_timeout=20s;
}

server
{
listen 80;
server_name www.admin130.cn 192.168.12.189;
index index.htm index.html;
root /ixdba/web/wwwroot;

location / {
proxy_pass http://myserver;
proxy_next_upstream http_500 http_502 http_503 error timeout invalid_header;
include /opt/nginx/conf/proxy.conf;
}
}


在上面这个配置实例中,首先定义了一个负载均衡组 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 的内容为:

proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
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缓存临时文件的大小。

------分隔线----------------------------