nginx反向代理proxy_pass配置URI引起的思考
反向代理proxy_pass的语法结构为proxy_pass URL,其中,URL为要设置的被代理服务器的地址,包含传输协议、主机名称或IP地址加端口号、URI等要素。
例如:proxy_pass http://www.myweb.com/uri;
1. 如果被代理服务器是一组服务器的话,可以使用upstream指令配置后端服务器组。
upstream proxy_svrs
{
server http://192.168.0.1/uri;
server http://192.168.0.2/uri;
}
server块:
server
{
listen 80;
server_name localhost;
location /
{
proxy_pass proxy_svrs;
}
}
注意:如果组内的各个服务器都指明了传输协议 http:// ,那么在proxy_pass 指令中就不用指明了。反之也是如此。
2.另外,还要注意proxy_pass URL ,URL中是否含有URI,如果不包含,nginx服务器不会改变原地址的URI;如果包含了URI,则nginx服务器会使用新的URI替换原来的URI。
例如:
如果客户端请求http://10.66.30.223/api/exam,请求被该location块处理,由于proxy_pass指令的URL中不含URI,所以转向地址http://10.66.30.233:8080/api/exam。
再来看下面的配置:
在此示例中,由于proxy_pass URL中包含了URI "/loc",如果客户端发出http://www.myweb.com/server,nginx服务器会把地址转向 http://192.168.1.1/loc 。
总结:在使用proxy_pass指令时,如果不想改变原地址中的URI,就不要在URL变量中配置URI。