Bootstrap

Nginx-location匹配规则

每次配置Nginx的时候,不是多个这匹配不上就是那匹配不上,多个斜线少个斜线的,然后头疼,尤其多层代理之后,真是疯狂掉头发

正则匹配
uri
location匹配
正则匹配
全路径匹配
资源
静态资源
proxy_pass 代理接口
http://ip:port
http://ip:port/xx
http://ip:port/xx/

location匹配规则

ps: 一帮情况下我们不会用到太复杂的正则匹配的。

  1. = 全路径匹配。
  2. ~ 用于表示uri包含正则表达式,并且区分大小写。
  3. ~* 用于表示uri包含正则表达式,并且不区分大小写
  4. ^~ 用于不含正则表达式的uri前,要求Nginx服务器找到标识uri和请求字符串匹配度最高的location,立即使用此location 处理请求,而不再使用location中的正则uri 和请求字符串匹配。

proxy_pass 代理接口

  1. http://ip:port 如果是这种情况,会将location的内容追加到http://ip:port
http://192.168.10.211/api/fdsdsdds
客户端
Nginx
location配置
/api/
最终代理结果为
proxy_pass配置
http://192.168.10.211:7001
http://192.168.10.211:7001/api/fdsdsdds
  1. http://ip:port/xx 如果是这种情况,会将location的匹配到的内容删除掉,然后把剩余的部分拼接到http://ip:port/xx
http://192.168.10.211/api/fdsdsdds
客户端
Nginx
location配置
/api/
最终代理结果为
proxy_pass配置
http://192.168.10.211:7001/A
http://192.168.10.211:7001/Afdsdsdds
  1. http://ip:port/xx/ 如果是这种情况,会将location的匹配到的内容删除掉,然后把剩余的部分拼接到http://ip:port/xx/
http://192.168.10.211/api/fdsdsdds
客户端
Nginx
location配置
/api/
最终代理结果为
proxy_pass配置
http://192.168.10.211:7001/A/
http://192.168.10.211:7001/A/fdsdsdds
  1. 同理说下location配置后缀和不配置后缀的区别其实只要proxy_pass 端口后跟location中匹配到的就会删除掉,只是删除掉的和proxy_pass加到一起形成完整的URL能不能访问到你要代理的资源,对你没看错,是追加的**//**,但是这个路径是可以识别的
http://192.168.10.211/api/fdsdsdds
客户端
Nginx
location配置
/api
最终代理结果为
proxy_pass配置
http://192.168.10.211:7001/A/
http://192.168.10.211:7001/A//fdsdsdds

可以删除掉proxy_pass 中最后一个**/**

http://192.168.10.211/api/fdsdsdds
客户端
Nginx
location配置
/api
最终代理结果为
proxy_pass配置
http://192.168.10.211:7001/A
http://192.168.10.211:7001/A/fdsdsdds
;