事情是这样的,有个需求,就是在本系统准备把所有的api 请求放到webman 框架
然后把后台的业务依然保留在fastadmin 框架,
打算加一个反向代理,用同一个域名的加上一个访问后缀,放到到webman 服务,也就是本地的127.0.0.1:8787 端口
一开始的写法就是
这样的话访问http://**** /aaa的话就转发到 127.0.0.1:8787端口的aaa 目录,那我访问http://**** /bbb的话,就访问不到127.0.0.1:8787端口的bbb目录,因为我没有配置bbb 目录的代理,这样的话,我有多少个controller 就要配置多少个正则location才能去访问,那显然是不符合我的需求的,我要的是,访问http://**** /aaa 的话能转发到127.0.0.1:8787服务就可以,而不是到aaa目录,也就是说,我要想办法去掉这个location的匹配路径,于是乎我多番查找,终于让我找到
以下是参考文章
1. location和proxy_pass都带/去除
location ^~/api/ { 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://api/; }
http://api/ 的 api后面带/, 则会移除api这个上下文
这个办法,在宝塔报错,死活不行
2. rewrite去除
location ^~/api/ { 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 ^/api/(.*)$ /$1 break; proxy_pass http://api; }
http://api 的 api后面不带/, 通过rewrite移除api这个上下文
最后采用rewrite方法,这个好,终于解决了我的问题,可以去掉上下文,感恩
3. location带/, proxy_pass不带上下文去除
# 转发示例: # 请求:http://aaa.com/system/path/request # 转发:http://bbb.com/path/request # location ^~ /system/ { proxy_pass http://bbb.com; }
这个也不行,试过了
保留
1. location不带/, proxy_pass不带上下文保留
# 转发示例 # 请求:http://aaa.com/system/path/request # 转发:http://bbb.com/system/path/request # location ^~ /system { proxy_pass http://bbb.com; }
参考文章地址:https://www.cnblogs.com/mengff/p/16788194.html