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; }
upstream backend { server server1; server server2; fair; }
upstream backend { server squid1:3128; server squid2:3128; hash $request_uri; hash_method crc32; }
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; #以上三行,目的是将代理服务器收到的用户的信息传到真实服务器上 } }