docker compose入门7—详解build命令

docker-compose build 命令用于根据 Docker Compose 文件中的 build 配置来构建服务的 Docker 镜像。它从指定的 Dockerfile 或构建上下文中构建镜像,这样你可以将定制的镜像用于你的服务。

基本用法

docker-compose build

该命令会查看 docker-compose.yml 文件中所有定义了 build 部分的服务,并为它们构建 Docker 镜像。

详细说明

docker-compose.yml 文件中,如果某个服务需要构建自定义镜像,需要在该服务的定义中包含 build 配置项:

version: '3.8'

services:
  web:
    build:
      context: ./app  # 指定 Dockerfile 的构建上下文
      dockerfile: Dockerfile  # 可选,指定要使用的 Dockerfile(默认为 Dockerfile)
    ports:
      - "8080:80"
  db:
    image: postgres  # 使用现有的镜像而不是构建

在这个示例中,web 服务有一个 build 部分,它告诉 Docker Compose 在 ./app 目录下查找 Dockerfile,并使用该文件构建镜像。db 服务则使用现成的 postgres 镜像,所以不需要构建。

常用选项

  1. 强制重建镜像(--no-cache)

    • 默认情况下,Docker 会使用构建缓存来加快镜像构建速度。使用 --no-cache 选项可以强制不使用缓存。

    • 示例:

      docker-compose build --no-cache
      
  2. 只构建特定服务

    • 如果你只想构建某个特定的服务,可以在 build 后指定服务名称。

    • 示例:

      docker-compose build web
      
  3. 强制拉取基础镜像(--pull)

    • 如果你想确保 Docker 在构建过程中使用最新版本的基础镜像(如 FROM 指定的镜像),可以使用 --pull 选项来强制从镜像仓库拉取最新的镜像。

    • 示例:

      docker-compose build --pull
      
  4. 跳过未更改的服务(--parallel)

    • Docker Compose 3.4+ 版本支持 --parallel 选项,可以并行构建服务。这对于有很多服务的项目可以加速构建过程。

    • 示例:

      docker-compose build --parallel
      

完整示例

下面是一个带有 build 配置的完整示例,包含多个服务,并使用自定义 Dockerfile 构建:

version: '3.8'

services:
  web:
    build:
      context: ./app
      dockerfile: Dockerfile.web
      args:
        - APP_ENV=production  # 可传递构建参数
    ports:
      - "8080:80"

  api:
    build:
      context: ./api
      dockerfile: Dockerfile.api
    environment:
      - API_KEY=myapikey
    ports:
      - "8081:80"

在这个例子中:

  • web 服务和 api 服务都从各自的 Dockerfile 构建镜像。
  • web 服务的 Dockerfile 文件名是 Dockerfile.web,并且传递了构建时的参数 APP_ENV=production
  • api 服务从 Dockerfile.api 构建,设置了环境变量 API_KEY

总结

  • docker-compose build 用于构建 docker-compose.yml 中定义的服务镜像,主要根据 build 部分的配置进行构建。
  • 常用选项包括 --no-cache(不使用缓存)、--pull(拉取最新镜像)、--parallel(并行构建)等。
  • 可以选择构建所有服务或仅构建指定的服务。

通过灵活使用这些选项,可以高效管理和构建项目中的 Docker 镜像。

相关推荐
梅见十柒2 小时前
wsl2中kali linux下的docker使用教程(教程总结)
linux·经验分享·docker·云原生
O&REO4 小时前
单机部署kubernetes环境下Overleaf-基于MicroK8s的Overleaf应用部署指南
云原生·容器·kubernetes
运维小文5 小时前
K8S资源限制之LimitRange
云原生·容器·kubernetes·k8s资源限制
登云时刻5 小时前
Kubernetes集群外连接redis集群和使用redis-shake工具迁移数据(二)
redis·容器·kubernetes
wuxingge13 小时前
k8s1.30.0高可用集群部署
云原生·容器·kubernetes
志凌海纳SmartX14 小时前
趋势洞察|AI 能否带动裸金属 K8s 强势崛起?
云原生·容器·kubernetes
锅总14 小时前
nacos与k8s service健康检查详解
云原生·容器·kubernetes
BUG弄潮儿15 小时前
k8s 集群安装
云原生·容器·kubernetes
意疏15 小时前
【Linux 篇】Docker 的容器之海与镜像之岛:于 Linux 系统内探索容器化的奇妙航行
linux·docker
墨鸦_Cormorant15 小时前
使用docker快速部署Nginx、Redis、MySQL、Tomcat以及制作镜像
redis·nginx·docker