新手 nginx 反向代理求助。。

2019-07-23 15:54:48 +08:00
 a494836960

前端项目 想把 8010 和 8020 两个端口合并到 80 端口上面, 地址上使用 kd 和 zb 来区分 反向代理没问题了,, 但是里面的 css 和 js 无法请求到,,原因是 xxx:80/static.css 地址是没有通过 反向代理来做转发,我该怎么改呢。。 配置如下:

server {
	listen 80;
    server_name: xxx;
    
    location /kd {
    	proxy_pass xxx:8010
    }
    
    location /zb {
    	proxy_pass xxx:8020
    }
}

网上很多是说加这个配置:

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
 {
     proxy_pass xxx:8020
}

但是我有两个项目,,不能只代理一个 8020 呀

2761 次点击
所在节点    NGINX
9 条回复
ninjachen
2019-07-23 16:24:32 +08:00
xxx:80/static.css 改成两个 url.
比如 xxx:80/static1.css ,xxx:80/static2.css
akira
2019-07-23 16:26:18 +08:00
要么用子域名来区分
要么 /static.css 也挪到二级目录下面
cominghome
2019-07-23 16:29:05 +08:00
配置方法都是一样的啊,但是入口合并后你必须将分属于两个应用的静态资源重新设置路径。
a494836960
2019-07-23 16:42:31 +08:00
@akira @cominghome @ninjachen 是否可以通过$http_referer 来判断是 kd 还是 zb ; 我看到有这种写法
```
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
if ($http_referer ~* kd ){
proxy_pass xxx:8010
}

if ($http_referer ~* zb){
proxy_pass xxx:8020
}
}
```
ninjachen
2019-07-23 18:02:04 +08:00
不行,第一次访问这个网页没有 http_referer
jamesliu96
2019-07-23 18:02:53 +08:00
佛了,再加一个 directory 识别`location ~ \.(js|css)$`,关键是俩项目用不一样的根目录的 js 和 css ?为什么不做相对目录让各自项目用自己的?用 referer 可以,但是如果请求不带 referer 就完犊子。最好就单独放或者实在必须放在请求根目录的话就像一楼说的可以改个名然后独立 location 然后可能需要再 rewrite 一下
234747005
2019-07-23 21:34:21 +08:00
其实做好就是做一个静态资源分开请求,譬如这样,
server {
listen 80;
server_name: xxx;

location / {
index html;
}

location /kd {
proxy_pass xxx:8010
}

location /zb {
proxy_pass xxx:8020
}
}
234747005
2019-07-23 21:35:25 +08:00
然后把你的 css,js,image 之类的文件放在 nginx 的 html 里面。
whl619969187
2019-07-24 09:43:45 +08:00
为啥就不能再多写一层 路径?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/585481

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX