docker-compose简介

docker-compose简介

注:本文部分内容由类似GPT的AI生成,若有侵权请联系删除;

  1. #Docker Compose
    1. ##概述

Docker Compose是一个用来定义和运行复杂应用的Docker工具;

一个使用Docker容器的应用,通常由多个容器组成。使用Docker Compose不再需要使用shell脚本来启动容器

Compose 通过一个配置文件来管理多个Docker容器,在配置文件中,所有的容器通过services来定义,然后使用docker-compose脚本来启动,停止和重启应用,和应用中的服务以及所有依赖服务的容器,非常适合组合使用多个容器进行开发的场景.

            • Compose 使用的三个步骤:

使用 Dockerfile 定义应用程序的环境

使用 docker-compose.yml 定义构成应用程序的服务,这样它们可以在隔离环境中一起运行

最后,执行 docker-compose up 命令来启动并运行整个应用程序

            • 为什么需要docker-compose

Docker帮助我们解决服务的打包安装的问题,随着而来的问题就是服务过多的带来如下问题:

1、多次使用 Dockerfile、Build、Image 命令或者 DockerHub 拉取 Image;

2、需要创建多个Container,多次编写启动命令;

3、Container互相依赖的如何进行管理和编排;

当我们服务数量增多的时候,上面三个问题就会更加的被放大,如果这三个问题不解决,其实从虚拟机到容器化除了机器减少一些浪费以外,好像没有更多的变化

Docker有没有什么好的方法,可以让我们通过一个配置就搞定容器编排和运行呢?

Docker Compose可以做到以下几点:

①提供工具用于定义和运行多个docker容器应用;

②使用yaml文件来配置应用服务(docker-compse.yml);

③可以通过一个简单的命令docker-compse up可以按照依赖关系启动所有服务;

④可以通过一个简单的命令docker-compose down停止所有服务;

⑤当一个服务需要的时候,可以很简单地通过--scale进行扩容;

            • Docker Compose有以下特征:

更高的可移植性,Docker Compose仅需一个docker-compse up可以完成按照依赖关系启动所有服务,然后使用docker-compose down轻松将其拆解。帮助我们更轻松地部署复杂的应用程序;

单个主机上的多个隔离环境,Compose可以使用项目名称将环境彼此隔离,这可以在一台计算机上运行同一环境的多个副本,它可以防止不同的项目和服务相互干扰;

            • Docker Compose版本介绍

Docker Compose版本与引擎的对应关系如下,可以看到中间主要有两个版本2和版本3两种格式,目前大家使用比较多也就是这两种,对于这两个版本的差别给大家介绍一下:

1、v3 版本不支持 volume_from 、extends、group_add等属性;

2、cpu 和 内存属性的设置移到了 deploy 中;

3、v3 版本支持 Docker Swarm,而 v2 版本不支持;

Docker的linux发行版的软件仓库,目前为https://download.docker.com, 软件包名字为docker-ce和docker-ee;

    1. ##参数

Docker Compose是一个用于定义和运行多个Docker容器的工具,它使用YAML文件来配置应用程序的服务、网络和数据卷等。docker-compose.yml文件是Compose工具使用的配置文件,它包含了应用程序的所有服务和它们的配置信息:

version:指定Compose文件的版本,目前主流的版本是3.x,支持Docker 1.13.0及以上版本。

services:定义所有的服务信息,每个服务都是一个独立的容器,可以包括多个容器实例。services下面的第一级别的key就是一个服务的名称。

build:指定包含构建上下文的路径,或作为一个对象,该对象具有context和指定的dockerfile文件以及args参数值。

image:指定服务所使用的镜像名称。

ports:指定容器与主机之间的端口映射关系。

volumes:指定容器与主机之间的数据卷映射关系。

networks:指定容器所使用的网络。

environment:指定容器的环境变量。

depends_on:指定服务之间的依赖关系。

restart:指定容器在退出时是否自动重启。

command:指定容器启动时要执行的命令。

除了以上列出的常用参数外,docker-compose.yml文件还可以包含其他参数,具体可以参考Compose官方文档。需要注意的是,docker-compose.yml文件中的配置信息可以被覆盖,如果在docker-compose.override.yml文件中定义了相同的服务,Compose会使用override进行合并配置。

  1. #docker-compose是什么

Docker Compose是一个用于定义和管理多容器Docker应用程序的工具。它允许使用YAML文件来定义应用程序的服务,并且所有的服务将在一个隔离的环境中一起运行。

Docker Compose文件通常命名为docker-compose.yml,在这个文件中,你可以定义你的服务、网络和卷等配置。

以下是一个简单的Docker Compose文件示例:

yaml
version: '3'
services:
  web:
    image: nginx:latest
    ports:
      - "80:80"
  db:
    image: postgres:latest
    volumes:
      - ./data:/var/lib/postgresql/data
 

在这个示例中,定义了两个服务:一个web服务和一个db服务。web服务使用最新的nginx镜像,并将容器的80端口映射到主机的80端口。db服务使用最新的postgres镜像,并将当前目录下的data目录挂载到容器的/var/lib/postgresql/data目录。

要启动这个应用程序,你可以在包含docker-compose.yml文件的目录中运行docker-compose up命令。Docker Compose将会启动你定义的所有服务。

Docker Compose是Docker的一个非常有用的工具,它可以简化Docker应用程序的部署和管理过程。

  1. #Dockerfile和docker-compose的关系

Dockerfile和docker-compose都是Docker的重要组成部分,但它们的用途和功能是不同的。

Dockerfile:Dockerfile是一个文本文件,其中包含了一系列的指令,用于定义如何构建一个Docker镜像。这些指令包括设置工作目录、安装依赖、复制文件和目录、设置环境变量、暴露端口等。当你运行docker build命令时,Docker会读取Dockerfile,并按照其中的指令来构建镜像。

docker-compose:docker-compose是一个工具,用于定义和管理多个Docker容器的应用。你可以在docker-compose.yml文件中定义一组相关的服务,每个服务都是一个容器。这些服务可以包括应用服务器、数据库服务器、消息队列等。你可以使用docker-compose up命令来一次启动所有的服务,docker-compose会处理服务之间的依赖关系,确保服务按照正确的顺序启动。

Dockerfile和docker-compose通常一起使用。你可以在Dockerfile中定义单个服务的构建过程,然后在docker-compose.yml中定义所有服务的运行配置,包括服务之间的网络连接、数据卷、环境变量等。这样,你就可以使用一条命令来启动整个应用,而不需要手动启动每个服务。

  1. #安装docker compose

sudo apt install python3-pip

pip3 install docker-compose

  1. #使用docker-compose构建服务

使用 docker-compose 构建多服务应用的基本步骤如下:

  1. 定义docker-compose.yml文件

在这个yml文件中定义所有的服务,包括使用的镜像,网络端口,数据卷,依赖关系等信息。

  1. 构建服务

在docker-compose.yml目录下,运行:

docker-compose build

这将根据yml文件构建所有的服务镜像。

  1. 启动服务

docker-compose up -d

根据yml文件的定义在后台启动所有服务并建立连接。

docker-compose up -d --remove-orphans

启动Docker Compose文件中定义的服务,并删除所有的孤立容器。

  1. 停止服务

docker-compose down

可以停止并销毁所有服务。

  1. 重启服务:

docker-compose restart

            • 5. 修改配置

编辑yml文件调整配置,然后重建并重新启动可以更新服务。

这样就可以利用docker-compose来编排和管理多个关联的服务,通过yml文件定义可维护的应用栈。

需要理解每种服务的作用,充分利用依赖关系,卷挂载,环境变量等功能将应用拆分为微服务。

  1. #通过docker-compose.yml安装服务,会构建出几个docker?
  1. Claude

使用 docker-compose.yml 文件安装服务时,会根据 yml 文件中定义的服务数量启动等量的 docker 容器。

例如,一个常见的 docker-compose.yml 文件内容如下:

yaml

version: '3'

services:

  db:

    image: mysql

    ...

  cache:

    image: redis

    ...

   

  web:

    image: nginx

    ...

这个文件定义了3个服务:db、cache 和 web。

当我们使用 docker-compose up 命令启动这些服务时,会启动3个docker容器,分别对应 db、cache 和 web 服务。

所以可以得到结论:

使用docker-compose.yml启动服务时,会启动的docker容器数量 = yml文件中定义的service数量

每个service会启动一个docker容器,容器名默认为`项目名_服务名_序号`。

透过组合不同的服务来编排docker容器,是docker-compose的常见用法,这样可以利用yml统一管理多容器应用。

所以理解服务数量与docker容器数量的关系很重要,这有助于更好地使用docker-compose部署服务。

  1. #restart: unless-stopped和 restart: always的区别

在Docker Compose文件中,restart指令用于指定容器在何种情况下应该自动重启。

restart: always:无论容器的退出状态如何,Docker都会自动重启容器。这意味着,即使容器成功退出(退出状态为0),Docker也会重新启动它。此外,当Docker守护进程启动时,它也会启动任何设置为always的容器。

restart: unless-stopped:除非容器被明确地停止,否则Docker都会自动重启容器。这意味着,如果容器因为错误而退出(退出状态非0),或者Docker守护进程启动时,Docker都会重新启动它。但是,如果你明确地停止了容器,Docker就不会自动重启它。

总的来说,always和unless-stopped的主要区别在于,如果你明确地停止了容器,always会在Docker守护进程启动时重新启动它,而unless-stopped则不会。

  • 17
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值