Docker Compose

1.docker-compose定义

  • docker-compose 是一个可以实现在单机上对容器集群编排管理的工具。
  • 使用python开发的,能运行docker的平台也都能用docker-compose编排管理容器。

本质:就是在yaml格式的docker-compose配置模板文件里定义一个或多个服务及其容器的启动参数和依赖关系,并使用docker-compose命令根据配置模板文件中的参数来启动和管理容器。
传统的容器管理:

Dockerfile文件 -> 手动执行 docker build 一个个镜像的构建 -> 手动执行 docker run 一个个容器的创建和启动

容器编排管理:

Dockerfile文件 -> 在docker-compose.yml配置模板文件里定义容器启动参数和依赖关系

-> 执行docker-compose命令指定配置模板文件,根据模板文件的配置一键完成所有镜像的构建和容器的创建启动

2.docker-compose的三大概念

  • 项目project
  • 服务service
  • 容器container

项目project -> 包含一个或多个服务service -> 包含容器container的镜像、端口映射、数据卷、环境变量、依赖关系等启动参数

默认使用项目的目录名作为project的项目名,也支持使用 -p 或 --project-name 选项指定项目名称

项目目录里要包含一个docker-compose配置模板文件,默认为docker-compose.yml,也支持使用 -f 或 --file 选项指定项目的配置模板文件

在配置模板文件里要包含一个或多个服务及其容器的配置,每个服务要包含容器的名称、镜像、映射端口、数据卷、网络模式、依赖关系等容器的启动参数

3.docker-compose配置模板文件常用的字段

|----------------|---------------------------------|
| image | 使用本地镜像或从仓库拉取镜像创建容器 |
| build | 使用dockerfile现场构建镜像创建容器 |
| context | 指定dockerfile文件所在的目录路径 |
| dockerfile | 指定dockerfile文件名 |
| command | 设置容器的启动命令,会覆盖镜像中的CMD指令 |
| container_name | 设置容器名 --name |
| environment | 设置环境变量 -e -env |
| networks | 设置容器使用的自定义网络和IP --ip |
| network_mode | 设置容器的网络模式 --network |
| ports | 设置容器端口映射 -p |
| volumes | 设置数据卷挂载 -v |
| volumes_from | 设置数据卷容器挂载,版本3不支持 --volumes-from |
| hostname | 设置容器主机名 -h --hostname |
| sysctls | 设置容器的内核参数 --sysctl |
| links | 设置容器互联 --link |
| privileged | 设置容器拥有root权限 --privileged |
| restart | 设置容器重启策略 --restart |
| depends_on | 设置容器的依赖关系 |

复制代码
docker-compose [-f docker-compose.yml] up -d                 根据模板文件创建并后台启动所有容器
                                       down                  根据模板文件删除所有容器
									   ps                    根据模板文件查看所有容器状态
									   start|stop|restart    根据模板文件启动|停止|重启所有容器

4. yaml格式文件

文件名以 .yaml .yml 为后缀,用 空格缩进 表示字段的层级关系

特点:可读性高,易于管理

复制代码
#一级字段
key1: value1              #一个key只有一个值,值的类型为 纯量
key2: 
- value1                        #一个key有多个值的纵向格式,值的类型为 列表
- value2
key3: ["value1", "value2"]      #一个key有多个值的横向格式,值的类型为 数组
key4:
  #二级字段
  subkey1: value1               #用 空格缩进 表示字段的层级关系,同一层字段要靠左对齐
  subkey2:value2
  subkey3:                      #key的值也是键值对,值的类型为 对象
    #三级字段
    sskey1: value1
	sskey2: value2

5.json格式文件

文件名以 .json 为后缀,用 大括号{} 表示字段的层级关系,每层字段除了最后一个字段都要用逗号 , 结尾

特点:易于编程语言的api接口解析

复制代码
#一级字段
{
   "key1": ["value1"],
   "key2": ["value2", "value3"],
   "key3": {
      #二级字段
      "subkey1": ["value1"],
      "subkey2": ["value2"],
      "subkey3": {
         #三级字段
         "sskey1": ["value1"],
         "sskey2": ["value2"]
      }
   }
}

6.docker-compose架构LNMP服务

分别准备nginx、mysql、php配置文件,详细配置可以参考之前的博客Docker构建LNMP环境并运行Wordpress平台-CSDN博客

编写docker-compose.yml 配置文件

复制代码
version: "3"
services:
  web:
    build:
      context: ./nginx/
      dockerfile: Dockerfile
    container_name: nginx
    ports:
    - 80:80
    volumes:
    - ./nginx/html:/usr/local/nginx/html
    networks:
      mynetwork:
        ipv4_address: 172.18.0.10

  db:
    image: mysql:lnmp
    container_name: mysql
    privileged: true
    volumes:
    - db-data:/usr/local/mysql
    networks:
      mynetwork:
        ipv4_address: 172.18.0.20

  php:
    image: php:lnmp
    container_name: php
    ports:
    - 9000:9000
    volumes:
    - db-data:/usr/local/mysql
    - ./nginx/html:/usr/local/nginx/html
    networks:
      mynetwork:
        ipv4_address: 172.18.0.30
    depends_on:
    - web
    - db

networks:
  mynetwork:
    driver: bridge
    ipam:
      config:
      - subnet: 172.18.0.0/16

volumes:
  db-data:

构建镜像

docker-compose up -d

在mysql数据库授权后即可登陆wordpress

相关推荐
K***43062 小时前
IDEA+Docker一键部署项目SpringBoot项目
spring boot·docker·intellij-idea
2501_941799484 小时前
Java高性能微服务架构与Spring Cloud实战分享:服务治理、负载均衡与高可用经验
eureka
2501_941804325 小时前
Go高性能微服务网关与API网关实战分享:请求路由、负载均衡与性能优化经验
eureka
小雪_Snow8 小时前
CentOS 7 测试 docker 镜像源
docker·centos
2501_941801769 小时前
C++高性能网络爬虫与多线程实战分享:大规模网页抓取与数据处理优化经验
eureka
2501_941805939 小时前
Go高性能API网关与负载均衡实战分享:请求路由、流量控制与性能优化经验
eureka
wan_da_ren11 小时前
Docker安装Elasticsearch9.2.1与Kibana9.2.1 保姆教程(带验证版)
运维·docker·jenkins
Hellc00711 小时前
Docker部署BaGet私有NuGet服务器:从入门到备份恢复完整指南 二
服务器·docker·eureka
t***316511 小时前
Docker 之mysql从头开始——Docker下mysql安装、启动、配置、进入容器执行(查询)sql
sql·mysql·docker
2501_9411471113 小时前
Go语言微服务日志收集与监控实践分享:高并发系统的指标与告警优化经验
eureka