docker 部署nginx 静态文件挂载踩坑

先上一条命令:

docker run -di -p 80:80 --name=nginx-pro -v /data/nginx/www:/usr/share/nginx/html -v /data/nginx/img:/home/doc/uploads -v /data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v/data/nginx/logs:/var/log/nginx nginx

在之前的配置中,conf文件挂载成功,静态页面挂载成功,log日志挂载成功

唯独静态资源文件访问404

经过一番调试

首先第二个参数-v 冒号前面的代表宿主机静态文件目录,冒号后面的代表docker容器中的图片资源目录

之前图片404的原因在于conf中的配置

#正确的配置(/home/doc/uploads/)需要配置docker 容器中的静态资源路径,不应该配置本地静态文件路径
location /app/img {
                    alias /home/doc/uploads/;
              }

#错误的配置(配置成宿主机中的静态文件路径,找不到图片,因为请求是打到docker中的)

location /app/img {
                    alias /data/nginx/img;
              }

请求是访问docker 容器的,所以静态资源目录要填写docker 容器中的,而不是宿主机中的静态资源路径

当我在客户端上传两张图片到宿主机的静态资源目录中,就会自动同步到docker容器中的静态资源目录 ,这样当访问打到docker的静态资源目录,就会查看到刚才上传的图片了

坑二:配置https证书

docker run -di -p 80:80  -p 443:443 --name=nginx-pro -v /data/nginx/www:/usr/share/nginx/html -v /data/nginx/img:/home/doc/uploads -v /data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v /data/nginx/ssl:/etc/nginx/cert -v /data/nginx/logs:/var/log/nginx nginx

/etc/nginx/cert目录对应的是docker容器中的证书存放目录

对应的nginx.conf中的 ssl_certificate和ssl_certificate_key也要配置docker容器中的目录

worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  debug; 

#pid logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include mime.types;
    default_type application/octet-stream;

        log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    #access_log logs/access.log main;
    sendfile on;
    #tcp_nopush on;
    #keepalive_timeout 0;
    keepalive_timeout 65;
    #gzip on;
    #负载均衡配置
    upstream lbs{
        #ip_hash;
        server 119.23.57.241:8080 max_fails=2 fail_timeout=60s;
        server 119.23.57.241:8081 max_fails=2 fail_timeout=60s;
    }

    server {
              listen 80;
              listen 443 ssl;
              server_name dylqs.xyz;
              ssl_certificate /etc/nginx/cert/7158086_www.xxx.xyz.pem;
              ssl_certificate_key /etc/nginx/cert/7158086_www.xxx.xyz.key;
              ssl_session_cache shared:SSL:1m;
              ssl_session_timeout 5m;
              ssl_ciphers HIGH:!aNULL:!MD5;
              ssl_prefer_server_ciphers on;
              location / {
                    root /usr/share/nginx/html/;
                    index xdclass.html index.htm;
              }
              location /app/img {
                    alias /home/doc/uploads/;
              }
              location /api/ {
                    proxy_pass http://lbs;
                    proxy_redirect default;
              }
    }

  • 1
    点赞
  • 2
    收藏
  • 打赏
    打赏
  • 0
    评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:编程工作室 设计师:CSDN官方博客 返回首页
评论

打赏作者

daiyuenlong110

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值