Docker + Nginx 部署配置

下面这 4 个文件通常是一套 Docker + Nginx 部署配置 。它们各司其职:Dockerfile 负责"怎么构建镜像",docker-compose.yml 负责"怎么编排和启动容器",nginx.conf 负责"Nginx 怎么转发/服务请求",.dockerignore 负责"构建镜像时哪些文件不要带进去"。

文件 主要作用 可以理解为
Dockerfile 定义 Docker 镜像如何构建 应用的"镜像制作说明书"
nginx.conf 定义 Nginx 的运行配置 Web 服务器 / 反向代理的"路由规则"
docker-compose.yml 定义多个容器如何一起运行 本地/服务器部署的"一键启动配置"
.dockerignore 排除不需要参与镜像构建的文件 Docker 版 .gitignore

1. Dockerfile

Dockerfile 是一个文本文件,里面写的是构建 Docker 镜像的指令。Docker 官方文档说,Docker 会读取 Dockerfile 中的指令来自动构建镜像;它本质上包含了你原本可能在命令行里一步步执行的构建命令。(Docker Documentation)

常见作用包括:

dockerfile 复制代码
FROM node:20-alpine
WORKDIR /app
COPY package*.json ./
RUN npm install
COPY . .
RUN npm run build
CMD ["npm", "start"]

它通常负责:

  1. 指定基础环境,比如 nodepythonnginx
  2. 拷贝项目代码到镜像中。
  3. 安装依赖。
  4. 执行构建命令。
  5. 指定容器启动后运行什么命令。

在你的这组文件里,Dockerfile 很可能用于构建前端项目、后端项目,或者自定义 Nginx 镜像。

2. nginx.conf

nginx.conf 是 Nginx 的主配置文件。Nginx 官方文档说明,Nginx 及其模块的行为由配置文件中的指令决定;默认配置文件通常叫 nginx.conf,可能位于 /usr/local/nginx/conf/etc/nginx/usr/local/etc/nginx。(Nginx)

它常用于配置:

nginx 复制代码
server {
    listen 80;

    location / {
        root /usr/share/nginx/html;
        index index.html;
    }

    location /api/ {
        proxy_pass http://backend:3000/;
    }
}

常见作用包括:

  1. 配置监听端口,例如 80443
  2. 配置静态资源目录,例如前端打包后的 dist
  3. 配置反向代理,例如把 /api 请求转发给后端服务。
  4. 配置 HTTPS、缓存、压缩、日志。
  5. 配置多站点、多域名、多路径转发。

Nginx 本身可以作为 HTTP Web 服务器、反向代理、缓存、负载均衡器、TCP/UDP 代理等。(Nginx)

在 Docker 项目里,nginx.conf 经常配合 Dockerfiledocker-compose.yml 使用,比如把本地的 nginx.conf 挂载到容器里的 /etc/nginx/nginx.conf/etc/nginx/conf.d/default.conf

3. docker-compose.yml

docker-compose.yml 是 Docker Compose 的配置文件,用 YAML 格式描述一个应用由哪些服务组成。Docker 官方文档说明,Compose 文件用于配置 Docker 应用的 servicesnetworksvolumes 等内容。(Docker Documentation)

一个典型例子:

yaml 复制代码
services:
  nginx:
    image: nginx:alpine
    ports:
      - "80:80"
    volumes:
      - ./nginx.conf:/etc/nginx/conf.d/default.conf
    depends_on:
      - app

  app:
    build: .
    expose:
      - "3000"

它通常负责:

  1. 定义有哪些容器服务,比如 nginxfrontendbackendmysqlredis
  2. 指定服务使用哪个镜像,或者从哪个 Dockerfile 构建。
  3. 配置端口映射,比如 80:803000:3000
  4. 配置数据卷挂载,比如挂载配置文件、数据库数据目录。
  5. 配置容器之间的依赖关系。
  6. 配置网络,使服务之间可以通过服务名互相访问。

官方 Compose 规范中也提到,Compose 文件是一个 YAML 文件,核心结构通常包括 services,也可以包括 networksvolumesconfigssecrets 等。(GitHub)

在你的这组文件里,docker-compose.yml 很可能是启动整个项目的入口,例如:

bash 复制代码
docker compose up -d

4. .dockerignore

.dockerignore 用来告诉 Docker:构建镜像时,哪些文件或目录不要发送到构建上下文里。Docker 官方文档说明,构建上下文中可以使用 .dockerignore 文件排除文件和目录。(Docker Documentation)

典型内容:

dockerignore 复制代码
node_modules
.git
.env
dist
.DS_Store
*.log

它的作用主要是:

  1. 减小 Docker 构建上下文。
  2. 加快镜像构建速度。
  3. 避免把无关文件复制进镜像。
  4. 避免泄露敏感文件,比如 .env、私钥、日志。
  5. 避免把本地依赖目录,如 node_modules,带进镜像。

它和 .gitignore 很像,但作用对象不同:

文件 作用对象
.gitignore Git 提交时忽略哪些文件
.dockerignore Docker 构建镜像时忽略哪些文件

这四个文件之间的关系

可以按部署流程这样理解:

text 复制代码
.dockerignore
   ↓
过滤不需要参与构建的文件

Dockerfile
   ↓
根据项目代码构建 Docker 镜像

nginx.conf
   ↓
配置 Nginx 如何访问静态文件、转发 API、监听端口

docker-compose.yml
   ↓
把 Nginx、应用、数据库等服务组合起来,一键启动

一个常见前端项目部署流程可能是:

  1. .dockerignore 排除 node_modules.git、日志等文件。
  2. Dockerfile 构建前端项目,生成 dist
  3. nginx.conf 配置 Nginx,把 dist 作为静态网站目录,并把 /api 转发给后端。
  4. docker-compose.yml 启动 Nginx 容器、后端容器、数据库容器。

简单说:

text 复制代码
Dockerfile:做镜像
docker-compose.yml:跑容器
nginx.conf:管请求
.dockerignore:减负和防泄露
相关推荐
星越华夏7 小时前
计算机视觉:YOLOv12安装环境
人工智能·yolo·计算机视觉
Yolanda949 小时前
【人工智能】《从零搭建AI问答助手项目(九):Prompt优化》
人工智能·prompt
wj3055853789 小时前
课程 9:模型测试记录与 Prompt 策略
linux·人工智能·python·comfyui
小和尚同志9 小时前
深入使用 skill-creator:结合真实生产级实践
人工智能·aigc
DevSecOps选型指南9 小时前
安全419专访悬镜安全 | 穿越周期在 AI 浪潮中定义数字供应链安全新范式
人工智能
沪漂阿龙9 小时前
面试题详解:GraphRAG 全面解析——知识图谱增强 RAG、Local Search、Global Search、社区摘要、工程落地与评估指标一次讲透
人工智能·知识图谱
WangN29 小时前
Unitree RL Lab 学习笔记【通识】
人工智能·机器学习
haina20199 小时前
海纳AI亮相《科创中国》,解码招聘“智”变之路
人工智能·ai面试·ai招聘
阿星AI工作室9 小时前
刘润年中大课笔记:一句话说清AI落地之战的本质
大数据·人工智能·创业创新·商业
qingfeng154159 小时前
企业微信机器人开发:如何实现自动化与智能运营?
人工智能·python·机器人·自动化·企业微信