docker+nginx部署的第二个前端项目返回的不是页面却是一堆后端数据是怎么回事?

新手上路,请多包涵

docker+nginx部署的前端访问成功但就是没有返回页面而是返回了后端一堆数据
image.png
image.png
image.png
image.png
image.png
怎么修改才能返回页面呢,我这样配置应该没问题把,我前面还配置了一个前端项目,现在配置的是前端的后台 会不会冲突了什么?
已经把前端打包放在nginx上去了,第一个dist是已经部署上去了,现在部署的是后台,也已经把包放上去了然后页面不出来的,而且我这个代理felix是后端没有的

阅读 1.4k
avatarAI BotBETA

首先,这个问题涉及到Docker、Nginx和后端数据返回,可能是由于配置问题或者某些设置没有正确地配置。下面是一些可能的解决方案和排查步骤:

  1. 检查Nginx配置:确保Nginx的配置文件正确地指向了前端项目的静态文件目录,并且正确地代理到了后端服务器。如果你使用的是Docker Compose,你可能需要检查Nginx和后端服务器的网络设置是否正确。
  2. 检查后端数据:确保后端服务器返回的是正确的数据。你可以尝试直接访问后端服务的API,看看返回的数据是否正确。如果后端返回的数据不正确,那么可能是后端代码的问题。
  3. 检查Docker配置:确保你的Docker容器正确地运行,并且Nginx和后端服务器都在正确的端口上监听。你可以使用docker ps命令来查看正在运行的容器,以及docker logs <container>命令来查看容器的日志。
  4. 检查浏览器控制台:打开浏览器的开发者工具(通常按F12键可以打开),然后查看控制台中的错误信息。这可能会给你一些线索,告诉你为什么页面没有返回。
  5. 尝试清理缓存:有时候,浏览器可能会缓存旧的页面版本,导致新的页面无法正常显示。你可以尝试清理浏览器缓存,然后重新加载页面。
  6. 查看网络请求:在浏览器的开发者工具中,查看网络请求,看看请求的URL是否正确,以及响应的状态码是否为200。

如果以上步骤都没有解决问题,那么你可能需要提供更多的信息,例如Nginx的配置文件、后端服务的代码、Docker Compose的配置文件等,以便更好地诊断问题。

3 个回答

你把 /felix 这个地址代理到那个ip上了. 这个ip应该是后端的接口吧.

你应该指定一个你的前端项目的访问地址, 或者直接把你的前端项目放到 nginx的那个 html目录下.

代理到后端服务了吧 那个proxy_pass 访问下看跟你上面的输出一样不

新手上路,请多包涵

1.location里的alias和index都属于无效配置,匹配"/felix"全部都会被反向代理转发,并不会访问到你nginx的本地文件
2.因为proxy_pass的结尾带了“/”,那么访问"/felix",实际访问的是后端"http://10.240.12.21:1212/",并不会帮你把"felix"拼接进去
3.如果我没有理解错你的意思,你需要对location进行细化,“/”用来转发给后端,而“/felix”只访问本地路径,同时你需要确保alias路径的正确性,根据提供的截图所示,即使取消proxy_pass的反向代理,在例如访问地址是"http://example.com/felix"的情况下,那么实际访问到本地路径是“/usr/share/nginx/html/admin/dist/index.html(或index.htm)”,这与你后续提供的文件系统截图并不相符。
4.如果你不想细化Location,则需要要try_files优先判断是否可以访问本地文件,再做反向代理转发,当然一样需要确保路径的准确性

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏