【Docker技术】docker-compose.yml与Dockerfile解析

Dockerfiledocker-compose.yml 是 Docker 生态中相互协作的两个核心文件,它们共同定义并启动了您的整个应用环境。

如以下Dockerfile

bash 复制代码
# Use lightweight Python image
FROM python:3.11-slim

# Set working directory
WORKDIR /app

# Install system dependencies (minimal)
RUN apt-get update && apt-get install -y --no-install-recommends \
    gcc \
    && rm -rf /var/lib/apt/lists/*

# Copy requirements first for better caching
COPY requirements.txt .

# Install Python dependencies
RUN pip install --no-cache-dir -r requirements.txt

# Copy application code
COPY . .

# Create directory for database
RUN mkdir -p /app/data

# Expose port
EXPOSE 8000

# Run the application
CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8000"]

docker-compose.yml

bash 复制代码
version: '3.8'

services:
  web:
    build: .
    ports:
      - "8000:8000"
    volumes:
      - ./data:/app/data
    environment:
      - DATABASE_URL=sqlite:///./data/reservoir_emissions.db
    restart: unless-stopped
    container_name: reservoir-emissions-tool

1. 执行命令

bash 复制代码
docker compose up --build -d

--build (强制重建): Docker 忽略本地已有的镜像缓存,重新执行 Dockerfile 中的所有指令,构建一个新的镜像。

up (服务启动): 使用新构建的镜像,创建名为 reservoir-emissions-tool 的容器实例,并设置好端口映射和数据卷挂载。

-d (后台运行): 容器在后台(detached mode)启动并运行,将控制台释放给您,让您可以继续使用命令行。

|--------------------|---------|-----------------|
| 文件 | 角色 | 关键指令 |
| docker-compose.yml | 服务定义与配置 | build: . |
| Dockerfile | 镜像构建步骤 | FROM、RUN、COPY 等 |

当您运行 docker compose up --build -d 时,Compose 工具会读取 docker-compose.yml 文件。它看到 web 服务下的:

bash 复制代码
build: .

这条指令告诉 Docker Compose:"要运行这个服务,你必须先在当前目录(.)下找到 Dockerfile,并用它来构建一个镜像。"

2. Dockerfile 执行制造任务

Docker 接收到构建任务后,开始执行 Dockerfile 中的所有步骤:

  1. 拉取基础系统: FROM python:3.11-slim

  2. 安装依赖: RUN ... gccRUN pip install ...

  3. 复制代码: COPY . .

  4. 声明入口: CMD ["uvicorn", ...]

这一系列步骤的结果,就是一个名为 reservoir-emissions-tool_web (默认名称) 的 Docker 镜像,这个镜像就是您应用的"可执行包"。

默认自动命名规则:

当您在 docker-compose.yml 中使用 build: . 而没有明确指定 image: 字段时,Docker Compose 会自动生成一个名称,格式通常是:

<项目目录名>_<服务名>

  • 项目目录名: 假设您的 docker-compose.yml 位于 IPCC-Tier-2 文件夹下。

  • 服务名:docker-compose.yml 中,您服务的名字是 web

所以,当您运行 docker compose up --build -d 时,生成的镜像名称通常会是:ipcc-tier-2_web

3. docker-compose.yml 运行配置环境

镜像构建完成后,Docker Compose 使用这个新镜像来启动容器,同时应用 docker-compose.yml 中定义的运行时环境配置

|-------------------------------|-------------------------------|------------------------------------------------------|---|---|---|
| 配置项 | 作用 | 对应 Dockerfile 的声明 | | | |
| ports: "8000:8000" | 外部访问:将容器的 8000 端口映射到宿主机。 | 对应 Dockerfile 中的 EXPOSE 8000 声明(让外部知道容器会用到这个端口)。 | | | |
| volumes: ./data:/app/data | 数据持久化:将本地目录挂载到容器内的 /app/data。 | 对应 Dockerfile 中的 RUN mkdir -p /app/data(确保容器内存在该目录)。 | | | |
| environment: DATABASE_URL=... | 配置注入:告诉应用数据库在哪。 | 应用的 CMD 命令启动后,会读取这个变量来连接数据库。 | | | |

相关推荐
兔兔爱学习兔兔爱学习32 分钟前
Spring Al学习7:ImageModel
java·学习·spring
chinesegf1 小时前
Docker篇4-本地项目app.py与docker加载项目镜像的开发顺序
运维·docker·容器
CyreneSimon1 小时前
Docker 拉取配置教程:解决镜像拉取连接超时问题
运维·docker·容器
lang201509282 小时前
Spring远程调用与Web服务全解析
java·前端·spring
m0_564264182 小时前
IDEA DEBUG调试时如何获取 MyBatis-Plus 动态拼接的 SQL?
java·数据库·spring boot·sql·mybatis·debug·mybatis-plus
崎岖Qiu2 小时前
【设计模式笔记06】:单一职责原则
java·笔记·设计模式·单一职责原则
Hello.Reader3 小时前
Flink ExecutionConfig 实战并行度、序列化、对象重用与全局参数
java·大数据·flink
熊小猿3 小时前
在 Spring Boot 项目中使用分页插件的两种常见方式
java·spring boot·后端
paopaokaka_luck4 小时前
基于SpringBoot+Vue的助农扶贫平台(AI问答、WebSocket实时聊天、快递物流API、协同过滤算法、Echarts图形化分析、分享链接到微博)
java·vue.js·spring boot·后端·websocket·spring
老华带你飞4 小时前
机器人信息|基于Springboot的机器人门户展示系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·机器人·论文·毕设·机器人门户展示系统