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:减负和防泄露
相关推荐
做萤石二次开发的哈哈1 小时前
对话城市开发者:萤石亮相CSDN AI智能硬件创新城市行
人工智能·智能硬件
唯创知音1 小时前
产后康复器械语音播报语音识别解决方案
人工智能·语音识别·产后康复器械·语音播报方案·语音方案
冷小鱼1 小时前
Apache Pulsar 深度解析:从入门到精通的开发者指南
人工智能
疯狂的皮卡1 小时前
【AI】从最小 Agent 到向量化 RAG
人工智能
Wanderer X1 小时前
【ML】位置编码
人工智能
搞科研的小刘选手1 小时前
【高届数传感机电会议】第十二届传感器、机电一体化和自动化系统国际学术研讨会(ISSMAS 2026)
运维·人工智能·自动化·控制·传感器·传感·机电
治数有道1 小时前
AI时代下:降本增效的具象化诱惑
人工智能
一次旅行1 小时前
今日AI科技新闻总结
人工智能·科技
这张生成的图像能检测吗1 小时前
(论文速读)Sonnet:多变量时间序列预测的谱算子神经网络
人工智能·深度学习·时序预测·时序模型