首页 > 其他 > 详细

proxy_pass根据path路径转发时的"/"问题记录

时间:2017-07-07 21:07:33      阅读:309      评论:0      收藏:0      [点我收藏+]

 

在nginx中配置proxy_pass时,如果是按照^~匹配路径时,要注意proxy_pass后的url最后的/。当加上了/,相当于是绝对根路径,则nginx不会把location中匹配的路径部分代理走;如果没有/,则会把匹配的路径部分也给代理走。

比如下面设置:
location ^~ /wangshibo/ 
{ 
proxy_cache js_cache; 
proxy_set_header Host js.test.com; 
proxy_pass http://js.test.com/; 
}
如上面的配置,如果请求的url是http://servername/wangshibo/test.html会被代理成http://js.test.com/test.html

而如果这么配置
location ^~ /wangshibo/ 
{ 
proxy_cache js_cache; 
proxy_set_header Host js.test.com; 
proxy_pass http://js.test.com; 
}
则请求的url是http://servername/wangshibo/test.html会被代理到http://js.test.com/wangshibo/test.html

当然,可以用如下的rewrite来实现/的功能
location ^~ /wangshibo/ 
{ 
proxy_cache js_cache; 
proxy_set_header Host js.test.com; 
rewrite /wangshibo/(.+)$ /$1 break; 
proxy_pass http://js.test.com; 
} 

-----------------------------------------------------看看下面的实例--------------------------------------------------------------

1)第一种配置
[root@BJLX_16_202_V vhosts]# cat ssl-wangshibo.conf
upstream at {
    server 172.29.16.202:8080 max_fails=3 fail_timeout=30s;
}
 
server {
   listen 443;
   server_name www.wangshibo.com;
   ssl on;
 
   ### SSL log files ###
   access_log logs/wangshibo_access.log;
   error_log logs/wangshibo_error.log;
 
### SSL cert files ###
   ssl_certificate ssl/bkjk.cer;     
   ssl_certificate_key ssl/bkjk.key;  
 
   location /attendance/ {
   proxy_pass http://at;                                                          //不需要加上"/"                      
   proxy_next_upstream error timeout invalid_header http_500 http_502 http_503;
   proxy_set_header Host $host;
   proxy_set_header X-Real-IP $remote_addr;
   proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
   proxy_set_header X-Forwarded-Proto https;
   proxy_redirect off;
       }
 
}
 
访问https://www.wangshibo.com/attendance/和http://172.29.16.202:8080/attendance结果是一致的。
 
2)第二种配置
[root@BJLX_16_202_V vhosts]# cat ssl-wangshibo.conf
upstream at {
    server 172.29.16.202:8080 max_fails=3 fail_timeout=30s;
}
 
server {
   listen 443;
   server_name www.wangshibo.com;
   ssl on;
 
   ### SSL log files ###
   access_log logs/wangshibo_access.log;
   error_log logs/wangshibo_error.log;
 
### SSL cert files ###
   ssl_certificate ssl/bkjk.cer;     
   ssl_certificate_key ssl/bkjk.key;  
 
   location / {
   proxy_pass http://at/attendance/;                                                  //一定要加上"/"                          
   proxy_next_upstream error timeout invalid_header http_500 http_502 http_503;
   proxy_set_header Host $host;
   proxy_set_header X-Real-IP $remote_addr;
   proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
   proxy_set_header X-Forwarded-Proto https;
   proxy_redirect off;
       }
 
}
 
访问https://www.wangshibo.com和http://172.29.16.202:8080/attendance结果是一致的。

proxy_pass根据path路径转发时的"/"问题记录

原文:http://www.cnblogs.com/kevingrace/p/7133806.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!