信步漫谈之Nginx—负载均衡

Nginx ("engine x") 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 服务器。

主要介绍 Nginx 负载均衡配置,以实例进行说明。

准备材料:nginx(http://nginx.org/),web 项目(此处以 jetty 编写可自定义访问 IP 和端口的项目为例)

关键代码:

HelloWorldHandler.java
JettyMain.java
pom.xml

nginx 结构:

image

修改 nginx 配置文件 conf/nginx.conf,http 段添加 upstream 节点,并在 http 段中 server 节点的 location 节点中添加 proxy_pass 配置为:http:// + upstream 名称。

upstream
proxy_pass

配置完成后,即可启动 nginx(双击 nginx.exe,窗口闪退是正常的,是否正常启动是看是否启动了 nginx 的进程)

image

配置成功后的 nginx.conf 文件如下:

nginx.conf

访问地址:http://127.0.0.1:8088/,刷新切换服务器。

image

image

以上,最简单的负载均衡完成。

upstream 按照轮询(默认)方式进行负载,每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器 down 掉,能自动剔除。虽然这种方式简便、成本低廉。但缺点是:可靠性低和负载分配不均衡。适用于图片服务器集群和纯静态页面服务器集群。

除此之外,upstream 还有其它的分配策略,分别如下:

weight(权重)
    指定轮询几率,weight 和访问比率成正比,用于后端服务器性能不均的情况。如下所示,10.0.0.88 的访问比率要比 10.0.0.77 的访问比率高一倍。

upstream site{ 
      server 10.0.0.77 weight=5; 
      server 10.0.0.88 weight=10; 
}

ip_hash(访问ip)
    每个请求按访问 ip 的 hash 结果分配,这样每个访客固定访问一个后端服务器,可以解决 session 的问题。

upstream site{ 
      ip_hash; 
      server 10.0.0.10:8080; 
      server 10.0.0.11:8080; 
}

fair(第三方)
    按后端服务器的响应时间来分配请求,响应时间短的优先分配。与 weight 分配策略类似。

upstream site{      
      server 10.0.0.10:8080; 
      server 10.0.0.11:8080; 
      fair; 
}

url_hash(第三方)
    按访问url的hash结果来分配请求,使每个 url 定向到同一个后端服务器,后端服务器为缓存时比较有效。

upstream site{ 
      server 10.0.0.10:7777; 
      server 10.0.0.11:8888; 
      hash $request_uri; 
      hash_method crc32; 
}

注意:在 upstream 中加入 hash 语句,server 语句中不能写入 weight 等其他的参数,hash_method 是使用的 hash 算法。

upstream 还可以为每个设备设置状态值,这些状态值的含义分别如下:

down:表示单前的 server 暂时不参与负载.
weight:默认为1。weight 越大,负载的权重就越大。
max_fails:允许请求失败的次数默认为1.当超过最大次数时,返回 proxy_next_upstream 模块定义的错误.
fail_timeout:max_fails 次失败后,暂停的时间。
backup:其它所有的非 backup 机器 down 或者忙的时候,请求 backup 机器。所以这台机器压力会最轻。

upstream site{ #定义负载均衡设备的Ip及设备状态 
      ip_hash; 
      server 10.0.0.11:9090 down; 
      server 10.0.0.11:8080 weight=2; 
      server 10.0.0.11:6060; 
      server 10.0.0.11:7070 backup; 
}
posted @ 2016-09-11 22:50  临渊启明  阅读(719)  评论(0编辑  收藏  举报