nginx学习:upstream模块实现负载均衡

2017-01-04  本文已影响132人  Flippancy

负载均衡模块用于从”upstream”指令定义的后端主机列表中选取一台主机。nginx先使用负载均衡模块找到一台主机,再使用upstream模块实现与这台主机的交互。


  1. 在http节点下添加upstream节点。

upstream test{
server 10.0.0.1:11;
server 10.0.0.1:22;}

  1. 将server节点下的location节点中的proxy_pass配置为:http:// + upstream名称,即“http://test”.

location / {
root html;
index index.html;
proxy_pass http://test;}

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

upstream test{
server 10.0.0.33 weight=1;
server 10.0.0.44 weight=2;}

upstream test{
ip_hash;
server 10.0.0.33:8080;
server 10.0.0.44:8080;}

upstream test{
server 10.0.0.33:8080;
server 10.0.0.44:8080;
fair;}

upstream test{
server 10.0.0.33:8080;
server 10.0.0.44:8080;
hash $request_uri;
hash_method crc32;}

upstream test{
#定义负载均衡设备的Ip及设备状态
ip_hash;
server 10.0.0.11:9090 down;
server 10.0.0.11:8080 weight=2;
server 10.0.0.11:7070;
server 10.0.0.11:6060 backup;}
在需要使用负载均衡的server中增加 proxy_pass http://test/;

上一篇 下一篇

猜你喜欢

热点阅读