Docker Compose 挂载 Nginx 配置的正确姿势(90%的人都踩过这个坑)

大家好我是舒一笑不秃头,喜欢写作和分享,更多精彩内容

在实际部署前端项目时,我们经常会用到这样的镜像:

sql 复制代码
FROM nginx:stable-alpine
COPY default.conf /etc/nginx/conf.d/default.conf
COPY dist /usr/share/nginx/html
EXPOSE 8000

看起来很简单对吧?

👉 但一旦你想动态修改 nginx 配置,问题就来了:

❓ 难道每改一次配置都要重新 build 镜像?

当然不需要!正确方式是:使用 docker-compose 挂载外部配置文件

今天这篇文章,带你彻底搞懂 👇


🧠 一、核心原理(一定要搞懂)

Docker 镜像里这句:

arduino 复制代码
COPY default.conf /etc/nginx/conf.d/default.conf

👉 本质只是"拷贝一次"

而 Docker 提供了更高级的能力:

volume 挂载可以直接覆盖容器内文件

优先级:

复制代码
volume > 镜像内文件

所以:

👉 我们可以用宿主机的 default.conf 覆盖容器里的配置


🛠 二、正确写法(docker-compose)

假设你的配置文件在:

arduino 复制代码
/data/docker_export_zhonghui/nginx/default.conf

那么 docker-compose.yml 写法如下:

javascript 复制代码
services:
  torchv_web:
    image: harbor.torchv.com/ais/rag-web:202603250947-master
    container_name: torchv_web
    ports:
      - "80:80"
    volumes:
      - /data/docker_export_zhonghui/nginx/default.conf:/etc/nginx/conf.d/default.conf:ro

📁 三、推荐目录结构

arduino 复制代码
/data/docker_export_zhonghui/
└── nginx/
    └── default.conf

⚠️ 四、90%的人都会踩的坑

❌ 坑1:路径写成相对路径

错误写法:

javascript 复制代码
- ./nginx/default.conf:/etc/nginx/conf.d/default.conf

👉 在服务器部署时,经常路径不对!

✅ 正确:

javascript 复制代码
- /data/docker_export_zhonghui/nginx/default.conf:/etc/nginx/conf.d/default.conf

❌ 坑2:文件不存在(最常见)

如果宿主机文件不存在:

👉 Docker 会自动创建一个目录!

结果:

复制代码
nginx 启动失败 ❌

检查方式:

bash 复制代码
ls /data/docker_export_zhonghui/nginx/default.conf

❌ 坑3:端口对不上(隐蔽坑)

Dockerfile 写:

yaml 复制代码
EXPOSE 8000

但 nginx 默认是:

arduino 复制代码
listen 80;

👉 EXPOSE 没任何实际作用(只是声明)

所以你必须确认:

✅ 推荐统一:

arduino 复制代码
listen 80;

然后:

makefile 复制代码
ports:
  - "80:80"

❌ 坑4:权限问题

如果 nginx 报错:

复制代码
permission denied

解决:

bash 复制代码
chmod 644 /data/docker_export_zhonghui/nginx/default.conf

❌ 坑5:改了配置不生效

很多人改完文件发现:

👉 页面没变化

原因:

👉 容器没重建

正确操作:

css 复制代码
docker compose up -d --force-recreate

或者:

复制代码
docker compose down
docker compose up -d

🔥 五、进阶玩法(推荐)

如果你有多个配置文件,可以直接挂整个目录:

javascript 复制代码
volumes:
  - /data/docker_export_zhonghui/nginx:/etc/nginx/conf.d:ro

👉 优点:

  • 支持多站点
  • 配置更灵活
  • 更接近生产环境

🧪 六、验证是否生效

进入容器:

bash 复制代码
docker exec -it torchv_web sh

查看配置:

bash 复制代码
cat /etc/nginx/conf.d/default.conf

测试 nginx:

复制代码
nginx -t

✅ 七、总结一句话

👉 Docker 修改 nginx 配置的最佳实践:永远用 volume 挂载,而不是重新 build 镜像

相关推荐
云飞云共享云桌面2 小时前
共享云主机告别传统电脑——制造工厂研发部门2台三维设计云主共享给20个设计师并发用
大数据·运维·服务器·自动化·电脑·制造
航Hang*2 小时前
Windows Server 配置与管理——第10章:配置FTP服务器
运维·服务器·网络·windows·学习·vmware
手揽回忆怎么睡2 小时前
win11使用Docker隔离comfyui,避免每次python地狱依赖
docker
kevin_水滴石穿2 小时前
Docker 运行一段时间后,/var/lib/docker/overlay2目录占用空间过大的处理方案
运维·docker·容器
东北甜妹3 小时前
Redis 知识总结
运维·nginx·安全
牛奶咖啡133 小时前
Docker容器实践——docker的安装与加速器配置
docker·docker与虚拟机对比·docker是什么·docker容器的发展方向·docker容器的两种安装方法·docker配置国内加速器·普通用户添加docker用户组
小夏子_riotous3 小时前
Docker学习路径——1、简介
linux·运维·服务器·docker·容器·云计算
航Hang*3 小时前
Windows Server 配置与管理——第9章:配置DHCP服务器
运维·服务器·windows·学习
walkerLing3 小时前
Docker Day2
运维·docker·容器