Nginx 配置之 proxy_pass 配置
1、基本说明
在 nginx 中配置 proxy_pass
代理转发时,如果在 proxy_pass
后面的url加/,表示绝对根路径;如果没有/,表示相对路径,把匹配的路径部分也给代理走。
假设下面四种情况分别用 http://192.168.1.1/proxy/test.html 进行访问。
第一种:
1
2
3location /proxy/ {
proxy_pass http://127.0.0.1/;
}http://192.168.1.1/proxy/test.html 代理到URL:http://127.0.0.1/test.html
第二种(相对于第一种,最后少一个 /)
1
2
3location /proxy/ {
proxy_pass http://127.0.0.1;
}http://192.168.1.1/proxy/test.html 代理到URL:http://127.0.0.1/proxy/test.html
第三种:
1
2
3location /proxy/ {
proxy_pass http://127.0.0.1/aaa/;
}http://192.168.1.1/proxy/test.html 代理到URL:http://127.0.0.1/aaa/test.html
第四种(相对于第三种,最后少一个 / )
1
2
3
4location /proxy/ {
proxy_pass [http://127.0.0.1/aaa](http://127.0.0.1/aaa);
}
http://192.168.1.1/proxy/test.html 代理到URL:http://127.0.0.1/aaatest.html
简单来说:
- 若proxy_pass代理地址端口后无任何字符,则转发后地址为:代理地址+访问的path。
- 若proxy_pass代理地址端口后有目录(包括”/“),则转发后地址为:代理地址+访问的path去除location匹配的路径
2、两个 proxy_pass
nginx中有两个模块都有proxy_pass
指令。
2.1、ngx_http_proxy_module
的proxy_pass
:
- 语法: proxy_pass URL;
- 场景: location, if in location, limit_except
- 说明: 设置后端代理服务器的协议(protocol)和地址(address),以及location中可以匹配的一个可选的URI。协议可以是”http”或”https”。地址可以是一个域名或ip地址和端口,或者一个 unix-domain socket 路径。
- 详见官方文档: http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_pass
1 |
|
2.2、ngx_stream_proxy_module
的proxy_pass
:
- 语法: proxy_pass address;
- 场景: server
- 说明: 设置后端代理服务器的地址。这个地址(address)可以是一个域名或ip地址和端口,或者一个 unix-domain socket路径。
- 详见官方文档: http://nginx.org/en/docs/stream/ngx_stream_proxy_module.html#proxy_pass
1 |
|
2.3、两个proxy_pass
的关系和区别
在两个模块中,两个proxy_pass
都是用来做后端代理的指令。
ngx_stream_proxy_module
模块的proxy_pass
指令只能在server段使用使用, 只需要提供域名或ip地址和端口。可以理解为端口转发,可以是tcp端口,也可以是udp端口。ngx_http_proxy_module
模块的proxy_pass
指令需要在location段,location中的if段,limit_except段中使用,处理需要提供域名或ip地址和端口外,还需要提供协议,如”http”或”https”,还有一个可选的uri可以配置。
2.4、proxy_pass
后,后端服务器的url
(request_uri
)情况分析
1 |
|
文件: /data/www/test/test.php
1 |
|
通过查看 $_SERVER['REQUEST_URI']
的值,我们可以看到每次请求的后端的 request_uri
的值,进行验证。
小结
- 情形A和情形B进行对比,可以知道
proxy_pass
后带一个URI,可以是斜杠(/)也可以是其他uri,对后端request_uri
变量的影响。 - 情形D说明,当location为正则表达式时,
proxy_pass
不能包含URI部分。 - 情形E通过变量(
$request_uri
, 也可以是其他变量),对后端的request_uri
进行改写。 - 情形F和情形G通过rewrite配合break标志,对url进行改写,并改写后端的
request_uri
。需要注意,proxy_pass
地址的URI部分在情形G中无效,不管如何设置,都会被忽略。
3、注意
注意,如果请求的 url 中有 #
, 则 #
之后的 url 不会转发
如:/tt0/1111111#/app/identity/govern/identity
转发时 /tt0/1111111
proxy_pass url 中 url 不能加 #
,加上之后会直接返回 400。