Docker Nginx js,css文件404问题排查解决

1. 问题现象

 如上图所示 静态文件404

2. 问题排查&解决

首先考虑文件本身的引用路径是否匹配nginx的配置

引入路径

<link href="/public/css/bootstrap.css" rel="stylesheet"/>

nginx 配置 (root 配置代替你的域名)

#js模块
​​location ~* \.(ico|css|js|gif|jpe?g|png)(\?[0-9]+)?$ {
        root /www/workspace/static;
        expires max;
        log_not_found off;
}

经过测试 发现nginx配置正确, nginx 配置文件不是问题所在.

考虑nginx容器是否能够读取静态文件

services:
  cgi:
    container_name: php7.2
    image: php:7.2
    restart: always 
    expose:
      - "9000"
    ports:
      - "9000:9000"
    volumes:
      - ../myspace:/www/workspace/
    depends_on:
      - mysql
      - redis
    links:
      - mysql:mysql
      - redis:redis
  nginx:
    container_name: nginx_v1
    image: openresty:v1
    restart: always
    volumes: 
      - ./config/nginx:/etc/nginx/conf.d
      - ./logs/nginx:/var/log/nginx
    ports: 
      - 80:80
      - 443:443

发现 nginx 容器下没有挂载 JS文件所在的目录 

在nginx volumes 下添加只读共享配置

- ../myspace:/www/workspace/:ro

重新compose 安装 运行 

bingo 问题解决!!!!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker中运行Nginx出现404错误的原因可能有很多,下面是一些常见的排查步骤和解决方法: 1. 检查配置文件:确认Nginx的配置文件是否正确,包括监听端口、站点路径、负载均衡策略等。可以使用命令`nginx -t`来检查配置文件的语法是否正确。 2. 检查端口映射:如果Nginx容器和宿主机之间存在端口映射问题,可能导致访问时出现404错误。请确保Nginx容器正确映射了前端页面的端口,并且没有其他进程占用了该端口。 3. 检查Nginx日志:查看Nginx的日志文件,看是否有任何错误信息或异常输出。这些日志文件通常位于容器内的日志目录中,可以使用`docker logs`命令查看。 4. 检查前端页面:确认前端页面是否存在,并且文件路径和文件名是否正确。可以尝试直接访问前端页面的URL,看是否能够正常打开。 5. 检查网络设置:确认Docker网络设置是否正确,特别是容器之间的网络连接和访问控制。如果网络设置不正确,可能导致容器之间的通信出现问题。 6. 检查Docker镜像:确认使用的Nginx Docker镜像是否正确,并且没有出现任何已知的问题。可以尝试使用其他可信赖的Nginx Docker镜像进行测试。 如果以上排查步骤都没有解决问题,可以尝试使用容器调试工具(如Docker Compose)来逐个启动相关容器并进行调试,以找到具体的问题所在。 另外,还可以尝试在Nginx配置文件中添加一个简单的静态页面测试,例如一个简单的HTML文件,以验证Nginx是否能够正常访问和返回数据。 总结:在解决Docker中运行Nginx出现404错误时,需要从多个角度进行排查和调试,包括配置文件、端口映射、日志文件、前端页面、网络设置和Docker镜像等方面。如果使用容器调试工具,可以更方便地逐个排查和调试相关问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值