docker系列:docker-compose用法详解

简介: docker-compose是Docker官方提供的用于定义和管理运行多个Docker容器的开源容器编排工具。可以使用YML文件来配置应用程序需要的所有服务,然后使用docker-compose运行命令,就可以解析YML文件配置创建并启动文件中配置的所有docker服务。

image_c47df9b0.png

今天给大家介绍一下docker-compose的用法,大家可以互相交流!

1、简介

docker-compose是Docker官方提供的用于定义和管理运行多个Docker容器的开源容器编排工具。

可以使用YML文件来配置应用程序需要的所有服务,然后使用docker-compose运行命令,就可以解析YML文件配置创建并启动文件中配置的所有docker服务。

可以把docker-compose理解为一个自动化运维命令的打包脚本集合,只要脚本编写的没问题,就可以执行一条命令启动所关联的所有服务。

GitHub:https://github.com/docker/compose

2、docker-compose的好处

降低运维成本:部署效率高、可控制容器的启动顺序、项目快速迁移、开发生产环境保持一致等。

一般一个系统的部署可能涉及到tomcat、mysql、redis、nginx、mongodb等应用,如果采用容器部署的话可能涉及十多个容器(中小项目),每个容器都单独维护的话,会非常繁琐,可能每个容器需要执行几十个命令,效率非常低。通过docker-compose可以提前编写好脚本,等上线部署的时候几分钟就可以搞定了。比起传统的项目部署方式效率大大提升了。还可以达到一次编写脚本,达到多次部署的效果。

开源项目推广:开源项目作者可以编写docker-compose脚本,让使用者可以快速搭建环境、也可以避免因为硬件环境造成项目各种报错的情况。也方便了开源项目的推广。

3、原理

image_dd07a4f0.png

docker-compose项目是由Python编写的,其实就是调用了Docker服务提供的API来对容器进行管理,因此,只要所在的操作系统的平台支持Docker API,就可以在其上利用Compose来进行编排管理。

流程:利用Dockerfile定义运行环境→使用docker-compose.yml定义组成应用的各服务→运行docker-compose up启动应用

4、安装教程

4.1 二进制方式安装(推荐国内镜像)

这个是官方地址,可能比较慢,推荐使用国内镜像地址

sudo curl -L "https://github.com/docker/compose/releases/download/1.29.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

国内镜像地址

sudo curl -L https://get.daocloud.io/docker/compose/releases/download/1.29.1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

验证方法

下载完之后可以看下 /usr/local/bin 这个目录有没有 docker-compose 这个文件

# 查看一下version,显示有版本号那就说明安装成功了
 docker-compose -version

卸载

sudo rm /usr/local/bin/docker-compose

4.2 通过python的pip方式安装

yum -y install epel-release yum -y install python-pip pip install --upgrade pip pip -V pip install docker-compose docker-compose -version

卸载

sudo pip uninstall docker-compose

5、常用命令

下面给大家整理常用的docker-compose命令

注意:大部分的compose命令都需要到docker-compose.yml文件所在的目录下才能执行

docker-compose -h                           # 查看帮助
docker-compose up                           # 创建并运行所有容器
docker-compose up -d                        # 创建并后台运行所有容器
docker-compose -f docker-compose.yml up -d  # 指定模板
docker-compose down                         # 停止并删除容器、网络、卷、镜像。
docker-compose logs       # 查看容器输出日志
docker-compose logs -f 容器名    查看容器实时日志
docker-compose pull       # 拉取依赖镜像
dokcer-compose config     # 检查配置
dokcer-compose config -q  # 检查配置,有问题才有输出
docker-compose restart   # 重启服务
docker-compose start     # 启动服务
docker-compose stop      # 停止服务
docker-compose up -d nginx    构建建启动nignx容器
docker-compose exec nginx bash    登录到nginx容器中
docker-compose ps    显示所有容器
docker-compose build nginx    构建镜像
docker-compose build --no-cache nginx    不带缓存的构建
docker-compose config  -q    验证(docker-compose.yml)文件配置,当配置正确时,不输出任何内容,当文件配置错误,输出错误信息。
docker-compose events --json nginx    以json的形式输出nginx的docker日志
docker-compose pause nginx    暂停nignx容器
docker-compose unpause nginx    恢复ningx容器
docker-compose rm nginx    删除容器(删除前必须关闭容器)

6、示例

新建docker-compose.yml文件,这里只是简单举例。更深入的案例大家可以自己研究一下。

version: '1'
services:
  web1:
    image: nginx
    ports: 
      - "8081:80"
    container_name: "test1"
    networks:
      - dev
  web2:
    image: nginx
    ports: 
      - "8082:80"
    container_name: "test2"
    networks:
      - dev
      - pro
  networks:
  dev:
    driver: bridge
  pro:
    driver: bridge


yaml语法检查:在线yaml转properties-在线properties转yaml-ToYaml.com

创建webapp目录,将docker-compose.yaml文件拷贝到webapp目录下,使用docker-compose启动应用。

docker-compose up -d

访问测试

http://127.0.0.1:8081

http://127.0.0.1:8082

7、总结

docker-compose 适合中小项目的部署,如果要搭建分布式部署环境的话建议使用swam、k8s。如果只是针对单机环境部署用来学习研究的项目还是不错的选择。

相关文章
|
3月前
|
关系型数据库 TensorFlow 算法框架/工具
Docker技术概论(4):Docker CLI 基本用法解析
Docker技术概论(4):Docker CLI 基本用法解析
230 1
|
20天前
|
负载均衡 监控 开发者
深入浅出:掌握 Docker Compose 的高级用法
【10月更文挑战第22天】本文深入探讨了 Docker Compose 的高级用法,包括环境变量、服务扩展、网络配置和数据卷管理。通过实例详细介绍了如何利用这些功能提升开发效率和应用部署的灵活性。适合希望深入了解 Docker Compose 的开发者阅读。
|
1月前
|
消息中间件 NoSQL Kafka
Flink-10 Flink Java 3分钟上手 Docker容器化部署 JobManager TaskManager Kafka Redis Dockerfile docker-compose
Flink-10 Flink Java 3分钟上手 Docker容器化部署 JobManager TaskManager Kafka Redis Dockerfile docker-compose
38 4
|
1月前
|
缓存 Kubernetes 应用服务中间件
1分钟了解什么是docker和docker-compose?前后端必知必会技能GET啦
1分钟了解什么是docker和docker-compose?前后端必知必会技能GET啦
|
6月前
|
NoSQL Unix MongoDB
【docker 】docker-compose 部署mongoDB
【docker 】docker-compose 部署mongoDB
194 1
|
6月前
|
应用服务中间件 Shell Linux
docker 基本用法-操作镜像
docker 基本用法-操作镜像
519 6
|
6月前
|
Ubuntu Shell 网络安全
【专栏】在Ubuntu 22.04上安装KubeSphere的指南:确保系统至少有4GB内存和2核CPU,安装Docker和docker-compose
【4月更文挑战第28天】在Ubuntu 22.04上安装KubeSphere的指南:确保系统至少有4GB内存和2核CPU,安装Docker和docker-compose。下载安装脚本`curl -sSL https://kubesphere.io/install.sh | bash`,根据提示选择安装选项,等待完成。安装后,通过访问控制台验证安装效果。解决可能出现的错误、网络问题和性能问题,利用KubeSphere提升容器管理效率。本文为顺利安装和使用提供参考。
280 0
|
NoSQL Redis Docker
【Redis从头学-12】Redis主从复制和读写分离的多种部署方式解析(普通方式、Docker搭建方式、Docker-Compose搭建方式)下
【Redis从头学-12】Redis主从复制和读写分离的多种部署方式解析(普通方式、Docker搭建方式、Docker-Compose搭建方式)
236 0
|
存储 NoSQL Redis
【Redis从头学-12】Redis主从复制和读写分离的多种部署方式解析(普通方式、Docker搭建方式、Docker-Compose搭建方式)上
【Redis从头学-12】Redis主从复制和读写分离的多种部署方式解析(普通方式、Docker搭建方式、Docker-Compose搭建方式)
210 0
|
消息中间件 关系型数据库 MySQL
从零玩转Docker之docker-compose快捷部署中间件2
从零玩转Docker之docker-compose快捷部署中间件
1128 0