【Docker】Docker Compose的配置与部署

本文详细介绍了Docker Compose,包括其概述、YAML文件格式、配置与命令,以及具体部署httpd和LNMP的步骤。Docker Compose提供了一种使用YAML文件定义和管理多容器Docker应用的便捷方式,简化了容器集群的编排管理。


一、Docker Compose

1. Docker Compose 的概述

  Docker-Compose项目是基于Python开发的Docker官方开源项目,负责实现对Docker容器集群的快速编排。Docker-Compose项目由Python编写,调用Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API, 就可以在其上利用Compose来进行编排管理。

  Docker Compose 是一个用于定义和运行多容器Docker应用程序的工具。它允许用户使用YAML文件来定义应用程序的配置,包括容器的数量、容器之间的依效关系、环境变量、端口映射以及其他设置。然后,用户可以使用docker-compose命令来启动和管理这些容器。

  使用 Docker Compose 可以方便地管理多个容器,例如,可以同时启动一个Web服务器容器和一个数据库容器,并在它们之间建立网络连接。Docker Compose 还支持自定义网络,使得容器可以在不同的网络中进行通信。

  Docker Compose文件通常包含一个或多个服务,每个服务都由一个或多个容器组成。服务定义了容器应该执行的任务,以及容器之间的依赖关系。例如,一个Web服务器服务可以包含一个或多个web 服务器容器,而这些容器又依赖于一个数据库容器。

2. Docker Compose 三大的概念

  Docker-Compose 将所管理的容器分为三层,分别是项目(project)、服务(service)以及容器(container) 。

  • Docker-Compose 运行目录下的所有文件组成一个项目,若无特殊指定项目名即为当前目录名。
  • 一个工程当中可包含多个服务,每个服务都包含一个名称、镜像、端口映射、环境变量、挂载点等信息。
  • Docker-Compose 的项目配置文件默认为 docker-compose.yml,可通过环境变量 COMPSE_FILE-f 参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。

  Compose 允许用户通过一个单独的 docker-compose.yml 模板文件(AM格式)来定义一组相关联的应用容器为一个项目(project)。

3. Docker Compose 环境安装

  Docker Compose 是 Docker 的独立产品,因此需要安装 Docker 之后在单独安装 Docker Compose。

#下载
curl - "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$ (uname -s)-$(uname m)" -o /usr/Local/bin/docker-compose
#安装
chmod +x /usr/local/bin/docker-compose
#查看版本
docker-compose --version

在这里插入图片描述

二、YAML 文件格式及编写注意事项

1. YAML 文件格式

  YAML 是一种标记语言,它可以很直观的展示数据序列化格式,可读性高。类似于 json数据描述语言,语法比 json简单的很多。YAML 数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号 [ ] 括起来, hash 用花括号 { } 括起来。

2. YAML 格式的注意事项

  • 大小写敏感;
  • 通过缩进表示层级关系;
  • 不支持制表符 tab 键缩进,只能使用空格缩进;
  • 缩进的空格数目不重要,只要相同层级左对齐,通常开头缩进2个空格;
  • # 号注释;
  • 符号字符后缩进1个空格,如冒号 : 、逗号 , 、横杠 -
  • 如果包含特殊字符可以用单引号或者双引号来引用处理,其中单引号 '' 引起来会作为普通字符串处理,双引号""会将特殊字符作为本身想表示的意思。

3. YAML 数据结构

3.1 基本类型

对象映射: 键值对的字典			  #冒号后面有空格
animal: pets


数组: 一组按次序排列的列表
pests:						 	#纵向列表
- Cat
- Dog
- Goldfish

pet: ["Cat", "Dog", "Goldfish"]	#横向列表


布尔值
debug: true 					#布尔值类型使用true或者false不需要加引号
debug: false

3.2 实例

#Yaml格式
languages:					#序列的映射
  - Java
  - Golang 
  - Python
 
websites:   				#映射的映射
  cpu: 2
  memory: 1024M
  swap: 2048M
  dosk: 60G
#Json格式						
{
  languages: [
    'Java',
    'Golong',
    'Python',
  ], 
  websites: {				#Json是通过大括号表示层级关系
 	cpu: ['2'],
  	memory: 
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我的宝贝大唐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值