1分钟彻底搞懂关于nginx的proxy_pass

本文详细解析了nginx中proxy_pass的两种类型,强调了只包含IP和端口号与包含完整路径的区别,以及不带URI和带URI方式下location路径的处理方式。通过实例解释了proxy_pass的URL替换机制,帮助读者深入理解这一关键配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在整理相关文档时,看到一篇文章,对于经常使用nginx却一直对proxy_pass云里雾里的同学很有帮助。

(下面这段不重要,知道就好)
Nginx的官网将proxy_pass分为两种类型:一种是只包含IP和端口号的(连端口之后的/也没有,这里要特别注意),比如proxy_pass http://localhost:8080,这种方式称为不带URI方式;另一种是在端口号之后有其他路径的,包含了只有单个/的如proxy_pass http://localhost:8080/,以及其他路径,比如proxy_pass http://localhost:8080/abc。

(记住下面两句话:)
也即:proxy_pass http://localhost:8080和proxy_pass http://localhost:8080/(多了末尾的/)是不同的的处理方式而proxy_pass http://localhost:8080/和proxy_pass http://localhost:8080/abc是相同的处理方式

对于不带URI方式,nginx将会保留location中路径部分,比如:

     location /api1/ {
           proxy_pass http://localhost:8080;
        }
在访问http://localhost/api1/xxx时,会代理到http://localhost:8080/api1/xxx

对于带URI方式,nginx将使用诸如alias的替换方式对URL进行替换,并且这种替换只是字面上的替换,比如:

     location /api2/ {
           proxy_pass http://localhost:8080/;
        }
当访问 http://localhost/api2/xxx 时,http://localhost/api2/(注意最后的/)
被替换成了http://localhost:8080/,然后再加上剩下的xxx,于是变成了http://localhost:8080/xxx。

又比如:

 location /api5/ {
           proxy_pass http://localhost:8080/haha;
        }
当访问:
“http://localhost/api5/xxx” 时,
“http://localhost/api5/” 被替换成了 “http://localhost:8080/haha”,
请注意这里haha后面没有/,然后再加上剩下的xxx,即:
http://localhost:8080/haha+xxx=http://localhost:8080/hahaxxx,奇怪吧。

如果上面的内容你还没明白,下面的例子可以收藏起来:

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,请注意这里的双斜杠。
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值