zoukankan      html  css  js  c++  java
  • nginx中proxy_pass的斜杠配置

    nginx中proxy_pass的斜杠配置

      

      Nginx的官网将proxy_pass分为两种类型:
    • 不带URI方式:只包含IP和端口号的,不带uri(单个/也算uri),比如proxy_pass http://localhost:8080
    • 带URI方式:在端口号之后有其他路径的,包含了只有单个/的如proxy_pass http://localhost:8080/,以及其他路径,比如proxy_pass http://localhost:8080/abc

    一、URL末尾存在 uri

      处理逻辑:代理请求时,会先将请求的uri中和location匹配的部分替换成 proxy_pass 指定的uri,再将最终的uri拼接到代理地址,才是最终访问的url,如:

    location /proxy {
    	proxy_pass http://127.0.0.1:8099/svr1;  # uri为'/svr1'
    }

      有如下请求:http://localhost:8088/proxy/index.html
      详细解析:

      请求的uri:/proxy/index.html
      location匹配的部分:/proxy
      proxy_pass 指定的uri:/svr1
      最终的uri:/svr1/index.html (将请求的uri中和location匹配的部分替换成 proxy_pass 指定的uri)
      代理地址:http://127.0.0.1:8099
      最终访问的url:http://127.0.0.1:8099/svr1/index.html
      即访问 http://localhost:8088/proxy/index.html,实际请求路径为 http://127.0.0.1:8099/svr1/index.html  

    二、URL末尾不存在 uri

      处理逻辑:代理请求时,直接将请求的uri拼接到代理地址,就是最终访问的url,如:

    location /proxy2 {
    	proxy_pass http://127.0.0.1:8099;  # 无uri
    }
      有如下请求:http://localhost:8088/proxy2/index.html  
      详细解析:  
      请求的uri:/proxy2/index.html
      代理地址:http://127.0.0.1:8099
      最终访问的url:http://127.0.0.1:8099/proxy2/index.html
      即访问 http://localhost:8088/proxy2/index.html,实际请求路径为 http://127.0.0.1:8099/proxy2/index.html

    下面的几个例子加深理解:

    server {
       listen       80;
       server_name  localhost;
    
       location /api1/ {
               proxy_pass http://localhost:8080;
            }
       # http://localhost/api1/xxx -> http://localhost:8080/api1/xxx
    
    
       location /api2/ {
               proxy_pass http://localhost:8080/;
            }
       # http://localhost/api2/xxx -> http://localhost:8080/xxx
    
    
       location /api3 {
               proxy_pass http://localhost:8080;
            }
       # http://localhost/api3/xxx -> http://localhost:8080/api3/xxx
    
    
       location /api4 {
               proxy_pass http://localhost:8080/;
            }
       # http://localhost/api4/xxx -> http://localhost:8080//xxx,请注意这里的双斜线,好好分析一下。
    
    
       location /api5/ {
               proxy_pass http://localhost:8080/haha;
            }
       # http://localhost/api5/xxx -> http://localhost:8080/hahaxxx,请注意这里的haha和xxx之间没有斜杠,分析一下原因。
    
       location /api6/ {
               proxy_pass http://localhost:8080/haha/;
            }
       # http://localhost/api6/xxx -> http://localhost:8080/haha/xxx
    
       location /api7 {
               proxy_pass http://localhost:8080/haha;
            }
       # http://localhost/api7/xxx -> http://localhost:8080/haha/xxx
    
       location /api8 {
               proxy_pass http://localhost:8080/haha/;
            }
      # http://localhost/api8/xxx -> http://localhost:8080/haha//xxx,请注意这里的双斜杠。
    }

    参考:

    https://markix.blog.csdn.net/article/details/107072652

    https://www.jianshu.com/p/c751250a5112

  • 相关阅读:
    几道算法题及学java心得
    css入门
    关于 移动端整屏切换专题 效果的思考
    css3实现卡牌旋转与物体发光效果
    九方格抽奖插件
    绑定弹窗事件最好的方法,原生JS和JQuery方法
    整屏滚动效果 jquery.fullPage.js插件+CSS3实现
    自定义 页面滚动条
    有趣的HTML5 CSS3效果
    CSS3 过渡与动画
  • 原文地址:https://www.cnblogs.com/xiaohang123/p/14945400.html
Copyright © 2011-2022 走看看