代理后端如果有多台服务器,自然可形成负载均衡,
但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;