在nginx中配置proxy_pass时,如果在proxy_pass后面的url加/,相当于是绝对根路径,则nginx不会把location中匹配的路径部分代理走;如果没有/,则会把匹配的路径部分给代理走。
下面四种情况分别用http://106.12.74.123/abc/index.html进行访问。
# 第一种
# 访问地址: http://localhost:9001/abc 注意:最后不能有/
location /abc
{
proxy_pass http://106.12.74.123:83/;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# 结论:会被代理到http://106.12.74.123/index.html 这个url
# 第二种(相对于第一种,最后少一个 /)
location /abc
{
proxy_pass http://106.12.74.123:83;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# 结论:会被代理到http://106.12.74.123/abc/index.html 这个url
第三种:
location /abc
{
proxy_pass http://106.12.74.123:83/linux/;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# 结论:会被代理到http://106.12.74.123/linux/index.html 这个url。
# 第四种(相对于第三种,最后少一个 / ):
location /abc
{
proxy_pass http://106.12.74.123:83/linux;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# 结论:会被代理到http://106.12.74.123/linuxindex.html 这个url