专栏首页DevOps持续交付失之毫厘谬以千里,Nginx配置中一个不起眼字符"/"的巨大作用

失之毫厘谬以千里,Nginx配置中一个不起眼字符"/"的巨大作用

<图片来自 51CTO 博客>

Nginx作为一个轻量级的,高性能的web服务软件,因其占有内存少,并发能力强的特点,而广受欢迎和使用。国内很多大型互联网公司也对Nginx很是青睐。像BAT(百度,阿里和腾讯),TMD(头条,美团和滴滴)等等。使用过Nginx的同学都知道,你只需要按需求准确的更改好配置启动,那么就可以优雅的访问它了。所以说Nginx对配置文件的很是看中呢,这就要求我们更改配置文件时一定要再三确认,要不然可能因为疏忽而引发惨案呢?真实案例,就因为在配置时,少些了一个字符“/”,就造成访问不通报错,因而接到投诉。那么是怎么引起的呢?原因就是:Nginx在配置proxy_pass代理转接时,少些“/”字符造成的。有同学就有疑问,加不加“/”,区别真的那么大吗?我们带着这个疑问,来探究下这个问题。

location目录匹配详解

nginx每个location都是一个匹配目录,nginx的策略是:访问请求来时,会对访问地址进行解析,从上到下逐个匹配,匹配上就执行对应location大括号中的策略,并根据策略对请求作出相应。

依访问地址:http://www.wandouduoduo.com/wddd/index.html为例,nginx配置如下:

location /wddd/  {                    proxy_connect_timeout 18000; ##修改成半个小时                        proxy_send_timeout 18000;                    proxy_read_timeout 18000;                    proxy_pass http://127.0.0.1:8080;        }

那访问时就会匹配这个location,从而把请求代理转发到本机的8080Tomcat服务中,Tomcat相应后,信息原路返回。总结:location如果没有“/”时,请求就可以模糊匹配以字符串开头的所有字符串,而有“/”时,只能精确匹配字符本身。

下面举个例子说明:

配置location /wandou可以匹配/wandoudouduo请求,也可以匹配/wandou*/duoduo等等,只要以wandou开头的目录都可以匹配到。而location /wandou/必须精确匹配/wandou/这个目录的请求,不能匹配/wandouduoduo/或/wandou*/duoduo等请求。

proxy_pass有无“/”的四种区别探究

访问地址都是以:http://www.wandouduoduo.com/wddd/index.html 为例。请求都匹配目录/wddd/

第一种:加"/"

location  /wddd/ {    proxy_pass  http://127.0.0.1:8080/;}

测试结果,请求被代理跳转到:http://127.0.0.1:8080/index.html

第二种: 不加"/"

location  /wddd/ {            proxy_pass http://127.0.0.1:8080;}

测试结果,请求被代理跳转到:http://127.0.0.1:8080/wddd/index.html

第三种: 增加目录加"/"

location  /wddd/ {            proxy_pass http://127.0.0.1:8080/sun/;}

测试结果,请求被代理跳转到:http://127.0.0.1:8080/sun/index.html

第四种:增加目录不加"/"

location  /wddd/ {    proxy_pass http://127.0.0.1:8080/sun;}测试结果,请求被代理跳转到:http://127.0.0.1:8080/sunindex.html

总结

location目录后加"/",只能匹配目录,不加“/”不仅可以匹配目录还对目录进行模糊匹配。而proxy_pass无论加不加“/”,代理跳转地址都直接拼接。

为了加深大家印象可以用下面的配置实验测试下:

server {     listen       80;     server_name  localhost;   # http://localhost/wddd01/xxx -> http://localhost:8080/wddd01/xxx
  location /wddd01/ {               proxy_pass http://localhost:8080;     }
  # http://localhost/wddd02/xxx -> http://localhost:8080/xxx     location /wddd02/ {               proxy_pass http://localhost:8080/;      }
  # http://localhost/wddd03/xxx -> http://localhost:8080/wddd03*/xxx     location /wddd03 {               proxy_pass http://localhost:8080;     }
  # http://localhost/wddd04/xxx -> http://localhost:8080//xxx,请注意这里的双斜线,好好分析一下。  location /wddd04 {               proxy_pass http://localhost:8080/;     }
  # http://localhost/wddd05/xxx -> http://localhost:8080/hahaxxx,请注意这里的haha和xxx之间没有斜杠,分析一下原因。  location /wddd05/ {               proxy_pass http://localhost:8080/haha;      }
  # http://localhost/api6/xxx -> http://localhost:8080/haha/xxx     location /wddd06/ {               proxy_pass http://localhost:8080/haha/;     }
  # http://localhost/wddd07/xxx -> http://localhost:8080/haha/xxx     location /wddd07 {               proxy_pass http://localhost:8080/haha;     }           # http://localhost/wddd08/xxx -> http://localhost:8080/haha//xxx,请注意这里的双斜杠。  location /wddd08 {               proxy_pass http://localhost:8080/haha/;     }}精选推荐
Dockerfile 详解,看这一篇就够了Docker公司发展新战略,以Docker Hub为中心,为用户提供SaaS服务
Mac下Docker Desktop的Kubernetes一直处于starting状态的解决办法
写给孩子看的kubernetes动画指南
使用 Kubernetes 和 Jenkins 创建一个 CI/CD 流水线
简明RESTful API设计规范
解读与部署:基于 Kubernetes 的基础设施即代码
Jenkinsclient 1.0发布,功能强大的开源跨平台的Jenkins命令行客户端
Jenkins Update Center Changer发布,一键切换国内镜像源
Jenkins经典界面交互革新,新UX抢先看,美翻了!

本文分享自微信公众号 - DevOps持续交付(devopscd)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-05-26

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • K8s自动扩缩容工具KEDA发布2.0版本,全面升级应用扩展能力

    一年前,红帽和微软共同发布了Kubernetes自动扩缩容工具KEDA 1.0,而现在官方强化KEDA的扩缩容器,发布第2个主要更新KEDA 2.0,能支持更多...

    DevOps持续交付
  • 使用 Kubernetes 和 Jenkins 创建一个 CI/CD 流水线

    CI/CD 同 DevOps、Agile、Scrum、Kanban、自动化以及其他术语一样,是一个一起被经常提及的专用术语。有时候,它被当做工作流的一部分,但是...

    DevOps持续交付
  • Jenkins常见问题集锦(二)

    参考:通俗理解,Blue Ocean可以看作是Jenkins推出的新的UI界面,有更现代的外观和更好的交互。

    DevOps持续交付
  • Nginx配置中一个不起眼字符"/"的巨大作用,失之毫厘谬以千里

    Nginx作为一个轻量级的,高性能的web服务软件,因其占有内存少,并发能力强的特点,而广受欢迎和使用。国内很多大型互联网公司也对Nginx很是青睐。像BAT(...

    民工哥
  • Shell curl 和 wget 使用代理IP

    Linux Shell 提供两个非常实用的命令来爬取网页,它们分别是 curl 和 wget

    阳光岛主
  • GO中间件(Middleware )

    中间件是一种计算机软件,可为操作系统提供的软件应用程序提供服务,以便于各个软件之间的沟通,特别是系统软件和应用软件。广泛用于web应用和面向服务的体系结构等。

    孤烟
  • [Go] 提供http服务出现两次请求以及处理favicon.ico

    在http包使用的时候,注册了/这个根路径的模式处理,浏览器会自动的请求favicon.ico ,一定要注意处理 ,否则会出现两次请求

    陶士涵
  • 真正“搞”懂http协议01—背景故事

    zaking
  • HTTPie 工具使用入门

    阳光岛主
  • webservices系列(一)——基础知识和JAX-WS入门demo

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 ...

    逝兮诚

扫码关注云+社区

领取腾讯云代金券