实际应用中,Nginx的斜杠会根据不同的代理地址,代理规则有所不同
server {
listen 443 ssl;
location /app/ {
proxy_pass http://server1:8191;
}
}
--这两种匹配对/app/v1这个路径等效
server {
listen 443 ssl;
location /app {
proxy_pass http://server1:8191;
}
}
访问路径 http://nginx-server:80/app/v1
实际的代理路径为http://server1:8191/app/v1,直接理解为与location后面的匹配地址无关,直接就是proxy_pass 主机:端口+访问路径,此处访问路径为/app/v1
--A类匹配
server {
listen 443 ssl;
location /app/ {
proxy_pass http://server1:8191/;
}
}
--B类匹配
server {
listen 443 ssl;
location /app {
proxy_pass http://server1:8191/;
}
}
访问路径 http://nginx-server:80/app/v1
对A类匹配实际的代理路径为http://server1:8191/v1,直接理解为取掉location后面的匹配/app/,剩余路径直接添加到后面,就是proxy_pass 主机:端口+访问路径,此处访问路径为/app/v1,去掉/app/剩余v1,直接添加到代理路径后面。
对B类匹配实际的代理路径为http://server1:8191//v1,直接理解为取掉location后面的匹配/app,剩余路径直接添加到后面,就是proxy_pass 主机:端口+访问路径,此处访问路径为/app/v1,去掉/app剩余/v1,直接添加到代理路径后面。
-- A
server {
listen 443 ssl;
location /app/ {
proxy_pass http://server1:8191/app/v2;
}
}
-- B
server {
listen 443 ssl;
location /app {
proxy_pass http://server1:8191/app/v2;
}
}
访问路径 http://nginx-server:80/app/v1
A的匹配实际的代理路径为http://server1:8191/app/v2v1,直接理解为取掉location后面的匹配/app/,剩余路径直接添加到后面,就是proxy_pass 主机:端口+访问路径,此处访问路径为/app/v1,去掉/app/剩余v1,直接添加到代理路径后面。
B的匹配实际的代理路径为http://server1:8191/app/v2/v1,直接理解为取掉location后面的匹配/app,剩余路径直接添加到后面,就是proxy_pass 主机:端口+访问路径,此处访问路径为/app/v1,去掉/app剩余/v1,直接添加到代理路径后面。
proxy_pass 主机+端口这种类型,后将访问地址直接加到后面即主机+端口+访问路径
proxy_pass 主机+端口+访问路径(包括根路径),需要去掉location后面的匹配路径,然后将剩余的添加到proxy_pass后面