背景
在使用nginx做代理web容器转发的时候,根据url的前缀转发到不同的服务,出现了接口报405的错误,网上查了好多文档,说了好多种原因,经过排查定位,最终定位到的原因是请求的url地址不对,多了一个转发的前缀。
解决
由于定位到了原因是请求的时候多了一个web容器/assetslog的上下文地址,如下图
所以如果可以在转发的时候,将这个前缀去掉,就可以正常访问,比如:
a.com/user/user.html转发到用户服务b.com/user.html
a.com/order/order.html转发到订单服务b.com/order.html
即,url的前缀对下游的服务是不需要的,除非下游服务添加context-path, 但很多时候我们并不喜欢加这个。如果Nginx转发的时候,把这个前缀去掉就好了。
方法1:proxy_pass后面加根路径/
server {
listen 80;
server_name a.com;
location ^~/user/ {
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-NginX-Proxy true;
proxy_pass http://user/;
}
location ^~/order/ {
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-NginX-Proxy true;
proxy_pass http://order/;
}
}
^~/user/表示匹配前缀是user的请求,proxy_pass的结尾有/, 则会把/user/*后面的路径直接拼接到后面,即移除location上的规则 user和order
方法2:使用rewrite,注意到proxy_pass结尾没有/, rewrite重写了url
server {
listen 80;
server_name a.com;
location ^~/user/ {
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-NginX-Proxy true;
rewrite ^/user/(.*)$ /$1 break;
proxy_pass http://user;
}
location ^~/order/ {
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-NginX-Proxy true;
rewrite ^/order/(.*)$ /$1 break;
proxy_pass http://order;
}
}
此外nginx还可以简单的直接把请求原封不动的转发给下一个服务
比如,访问a.com/app/a/b.html, 要求转发到b.com/app/a/b.html
设置proxy_pass即可。请求只会替换域名
server {
listen 80;
server_name a.com;
location / {
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-NginX-Proxy true;
proxy_pass http://b.com;
}
}
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。