gpt4 book ai didi

reactjs - 问题在网站的子路由上托管 react 应用程序 - 多个网站一个 IP 地址 NGINX

转载 作者:行者123 更新时间:2023-12-03 21:04:48 25 4
gpt4 key购买 nike

我是 NGINX 的新手,所以这可能是一个简单的修复,但我找不到任何关于我在这里尝试做什么的好文档。

所以我有一个网站,它由 nginx 和 pm2 托管在 ubuntu aws 服务器上。我的问题是我想在 www.mysite.com 上提供网站服务和 www.mywebsite.com/app 的 react 应用程序.这似乎不应该是最难做的事情。但是,我一直遇到问题,无法按照我的意愿工作。 (部分原因是我还希望在 www.mywebsite.com/api 上托管一个 API 服务器,但这是之后的问题)。我能够首先在 www.mysite.com 上托管 react 应用程序使用以下 nginx 配置:

server {
listen 80;
server_name 18.191.56.251;
root /home/ubuntu/app/src;
location / {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_max_temp_file_size 0;
proxy_pass http://127.0.0.1:3000/;
proxy_redirect off;
proxy_read_timeout 240s;
}
}

但是当我通过改变配置将它切换到子路由时:
server {
listen 80;
server_name x.x.x.x;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
proxy_redirect off;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";

proxy_redirect off;
proxy_set_header X-Forwarded-Proto $scheme;

proxy_connect_timeout 600;
proxy_send_timeout 600;
proxy_read_timeout 600;
send_timeout 600;

location /status {
return 200;
}

location /app {
proxy_pass http://127.0.0.1:3000;
}

location / {
proxy_pass http://...:3011/;
}
}

然后我的基本路线 www.mywebsite.com对于静态网站工作正常,但 www.mywebsite.com/app不会并“加载”一个空白页面,但如果您检查,您会发现该应用程序无法加载某些资源:
bundle.js:1
Failed to load resource: the server responded with a status of 404 (Not Found)
0.chunk.js:1
Failed to load resource: the server responded with a status of 404 (Not Found)
main.chunk.js:1
Failed to load resource: the server responded with a status of 404 (Not Found)

编辑更多研究:
如果我检查对资源的请求,我会看到它的 url 是 www.mywebsite.com/static/js/XXX.js但静态文件夹位于 ~/app/build/static .这是托管静态文件的 nginx 还是 pm2 问题?

任何帮助表示赞赏,谢谢

最佳答案

所以我仍然会喜欢与此不同的结果,但我想出了一个解决方法,我在 location /app 之后添加了以下内容:

location /static {
proxy_pass http://127.0.0.1:3000;
}

我不喜欢这个解决方案,因为如果我最终将静态内容作为其他项目的一部分,那么它将无法工作,但不知何故,我网站的所有资源都打包在 / 的正确代理中.所以目前一切正常。

关于reactjs - 问题在网站的子路由上托管 react 应用程序 - 多个网站一个 IP 地址 NGINX,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54987003/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com