Nginx的location路径与proxy_pass匹配规则说明
路径替换
配置proxy_pass时,可以实现URL路径的部分替换。
proxy_pass的目标地址,默认不带/,表示只代理域名(ip+端口),path和query部分不会变(把请求的path和query拼接到proxy_pass目标域名之后作为代理的URL)
如果在目标地址端口后有‘/’或者‘/xx/yy’等目录,则表示把path中location匹配成功的部分剪切掉之后再拼接到proxy_pass目标地址后面
- 比如请求 /a/b.html
location /a {
proxy_pass http://server;
}- 实际代理的目标url是http://server/a/b.html (把/a/b.html拼接到http://server之后)
location /a/ {
proxy_pass http://server/;
}总结
当访问地址是 http://127.0.0.1/api/user/list
若proxy_pass代理地址端口后无任何字符
则转发后地址为:代理地址+访问的path
| location | proxy_pass | 代理路径 |
|---|---|---|
| /api/ | http://server:8080 | http://server:8080/api/user/list |
| /api/ | http://server:8080/ | http://server:8080/user/list |
| /api | http://server:8080 | http://server:8080/api/user/list |
| /api | http://server:8080/ | http://server:8080//user/list |
若proxy_pass代理地址端口后有目录(包括"/")
则转发后地址为:代理地址+访问的path去除location匹配的路径
| location | proxy_pass | 代理路径 |
|---|---|---|
| /api/ | http://server:8080/gw | http://server:8080/gwuser/list |
| /api/ | http://server:8080/gw/ | http://server:8080/gw/user/list |
| /api | http://server:8080/gw | http://server:8080/gw/user/list |
| /api | http://server:8080/gw/ | http://server:8080/gw//user/list |
注意
location后斜杆与proxy_pass后斜杆"/"问题,最好要么两者都加斜杆,要么都不加
以服务地址http://127.0.0.1:5053/api/test/list进行说明,访问地址是http://127.0.0.1/api/test/list。
location后斜杆与proxy_pass后斜杆问题如下:
- location、proxy_pass都不加斜杠,实际代理地址:http://127.0.0.1:5053/api/test/list,正确的
location /api {
proxy_pass http://127.0.0.1:5053;
}- location加斜杠,proxy_pass不加斜杠,实际代理地址:http://127.0.0.1:5053/api/test/list,正确的
location /api/ {
proxy_pass http://127.0.0.1:5053;
}- location不加斜杠,proxy_pass加斜杠,实际代理地址:http://127.0.0.1:5053//test/list,错误的,也出现了双斜杠
location /api {
proxy_pass http://127.0.0.1:5053/;
}- location、proxy_pass都加斜杠,实际代理地址:http://127.0.0.1:5053/test/list,错误的
location /api/ {
proxy_pass http://127.0.0.1:5053/;
}- location不加斜杠,proxy_pass加"api",实际代理地址:http://127.0.0.1:5053/api/test/list,正确的
location /api {
proxy_pass http://127.0.0.1:5053/api;
}- location加斜杠,proxy_pass加"api",实际代理地址:http://127.0.0.1:5053/apitest/list,错误的,少了一个斜杆
location /api/ {
proxy_pass http://127.0.0.1:5053/api;
}- location不加斜杠,proxy_pass加"api/",实际代理地址:http://127.0.0.1:5053/api//test/list,出现双斜杠问题,后端在认证请求时会校验失败
location /api {
proxy_pass http://127.0.0.1:5053/api/;
}- location加斜杠,proxy_pass加"api/",实际代理地址:http://127.0.0.1:5053/api/test/list,正确的
location /api/ {
proxy_pass http://127.0.0.1:5053/api/;
}最后
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
- Nginx中location proxy_pass加与不加/的区别说明
- Nginx location和proxy_pass配置示例详解
- Nginx中proxy_pass的斜杠的两种方式
- Nginx捕获并自定义proxy_pass返回的错误问题
- nginx中如何配置proxy_pass
- Nginx rewrite和proxy_pass的区别及说明
- Nginx proxy_pass如何到https后端
- nginx代理参数proxy_pass的实现
- nginx反向代理proxy_pass遇到的死循环问题
- 解决nginx配置proxy_pass之后,响应变慢的问题
- Nginx使用if指令实现多个proxy_pass方式
- Nginx中proxy_pass使用小结
相关文章
Nginx配置反向代理服务器实现在https网站中请求http资源
Nginx反向代理是一种将客户端请求转发到后端服务器的技术,主要用于负载均衡、提高安全性和提升性能,本文给大家介绍了Nginx配置反向代理服务器实现在https网站中请求http资源,需要的朋友可以参考下2025-03-03
Nginx报403 forbidden错误 (13: Permission denied)的解决办法
这篇文章主要介绍了Nginx报403 forbidden错误 (13: Permission denied)的解决办法,引起nginx 403 forbidden通常是三种情况:一是缺少索引文件,二是权限问题,三是SELinux状态。具体内容详情大家可以参考下本文2017-01-01
详解Nginx反向代理WebSocket响应403的解决办法
本篇文章主要介绍了详解Nginx反向代理WebSocket响应403的解决办法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-01-01
nginx-ingress-controller部署配置详解
这篇文章主要为大家介绍了nginx ingress controller的部署配置,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-11-11


最新评论