代理后端如果有多台服务器,自然可形成负载均衡,
但proxy_pass如何指向多台服务器?
把多台服务器用 upstream指定绑定在一起并起个组名,
然后proxy_pass指向该组
server{
listen 81;
server_name localhost;
root html;
access_log log/81-access.log main;
}
server{
listen 82;
server_name localhost;
root html;
access_log log/82-access.log main;
}
upstream imgserver{
server 192.168.1.200:81 weight=1 max_fails=2 fail_timeout=3;
server 192.168.1.200:82 weight=1 max_fails=2 fail_timeout=3;
}
location ~\.(jpg|jpeg|png){
proxy_set_header X-Forwarded-For $remote_addr;
proxy_pass http://imgserver;
}
默认的均衡的算法很简单,就是针对后端服务器的顺序,逐个请求.
也有其他负载均衡算法,如一致性哈希,需要安装第3方模块.gx_http_upstream_consistent_hash为
(自行预习nginx第3方模块的安装,以安装n例)
反向代理导致了后端服务器的IP,为前端服务器的IP,而不是客户真正的IP,proxy_set_header X-Forwarded-For $remote_addr;
转载于:https://my.oschina.net/goudingcheng/blog/631764