nginx配置详解之upstream模块

nginx的upstream模块用来控制负载均衡,内容分发,nginx的upstream目前支持一下几种方式的分配:

1、轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除 配置如下:

upstream img_relay {
    server 127.0.0.1:8027;
    server 127.0.0.1:8028;
}

2、weight(权重)
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。

upstream bakend {
    server 192.168.0.14 weight=10;
    server 192.168.0.15 weight=20;
}

注:如果应用程序有会话控制  则不适应以上2方法  因为此方法不能保证把这次请求和下一次请求发送到同一台机器上

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

upstream bakend {
    ip_hash;
    server 192.168.0.14:88;
    server 192.168.0.15:80;
}

4、fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
upstream backend {
    server server1;
    server server2;
    fair;
}

5、url_hash(第三方)

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


注意:在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法 $request_url为nginx变量 表示请求url 实例如下

upstream backend {
    server squid1:3128;
    server squid2:3128;
    hash $request_uri;
    hash_method crc32;
}

一个完成的负载均衡tip

upstream bakend{#定义负载均衡设备的Ip及设备状态
    ip_hash;
    server 127.0.0.1:9090 down;
    server 127.0.0.1:8080 weight=2;
    server 127.0.0.1:6060;
    server 127.0.0.1:7070 backup;
} 

#在需要使用负载均衡的server中增加 proxy_pass http://bakend/; bakend为你定义的upstream的名字

#配置虚拟机
server{
    listen 80;
    #配置监听端口

    server_name image.***.com;
    #配置访问域名

    location ~* \.(mp3|exe)$ {
        #对以“mp3或exe”结尾的地址进行负载均衡
        proxy_pass http://img_relay$request_uri;
        #设置被代理服务器的端口或套接字,以及URL

        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        #以上三行,目的是将代理服务器收到的用户的信息传到真实服务器上
    }
}


你可能感兴趣的:(服务器,nginx应用详解,nginx,负载均衡,server,后端服务)