专栏首页编程坑太多「走进k8s」Docker三剑客之Docker Compose(七)

「走进k8s」Docker三剑客之Docker Compose(七)

前面说了5种网络模式:bridge,host,none,自定义网络,container。这次说下docker-compose。

(一)Docker Compose

Docker Compose 是通过python编写的,Docker的服务编排工具,主要用来构建基于Docker的复杂应用,Compose 通过一个配置文件来管理多个Docker容器,非常适合组合使用多个容器进行开发的场景。

  • ①Compose 官网

https://docs.docker.com/compose/

  • ②由来

通过dockerfile只能生成单一的容器(称之为service)。在日常的环境中,没有单独存在的应用,例如mysql,对应tomcat应用,redis内存数据库。多个应用搭建在一起形成一个完整的系统(称之为project)。总不能每次都一个一个创建吧。通过shell脚本的方式可以生成多个容器,但是非常的复杂,首先要精通shell脚本的开发,而且要理清容器间的业务关系。 Compose 恰好满足了这样的需求。它允许用户通过一个单独的 docker-compose.yml模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目。

  • ③安装

其他方式不做介绍,这种我感觉是最稳的。

sudo yum -y install python-pip
sudo pip install docker-compose
  • ④查看版本
docker-compose -version
  • ⑤卸载
sudo pip uninstall docker-compose
  • ⑥测试docker-compose

docker-compose.yml 编写

version: '3'
services:
   db:
     image: mysql:5.7
     volumes:
       - db_data:/var/lib/mysql
     restart: always
     environment:
       MYSQL_ROOT_PASSWORD: root
       MYSQL_DATABASE: wordpress
       MYSQL_USER: wordpress
       MYSQL_PASSWORD: wordpress
   wordpress:
     depends_on:
       - db
     image: wordpress:latest
     volumes:
        - wp_site:/var/www/html
     ports:
       - "80:80"
       - "443:443"
     restart: always
     environment:
       WORDPRESS_DB_HOST: db:3306
       WORDPRESS_DB_USER: wordpress
       WORDPRESS_DB_PASSWORD: wordpress
volumes:
    db_data:
    wp_site:
  • ⑦以守护进程模式运行加-d选项
docker-compose up -d
  • ⑧查看某个service的compose日志
#docker-compose logs <service名称>
docker-compose logs db
  • ⑨停止compose服务
#docker-compose.yml 目录下执行
docker-compose stop
  • ⑩启动compose服务
#docker-compose.yml 目录下执行
docker-compose start
  • ⑪重启compose服务
docker-compose restart
  • ⑫ kill compose服务

kill的服务状态码是Exit137

docker-compose kill
  • ⑬删除compose服务
docker-compose rm

(二)docker-compose常用命令

  • ①build

构建(重新构建) 项目中的服务容器。

docker-compose build [options] [SERVICE...]

--force-rm 删除构建过程中的临时容器。--no-cache 构建镜像过程中不使用 cache(这将加长构建过程) 。--pull 始终尝试通过 pull 来获取更新版本的镜像。

  • ②config

验证 Compose 文件格式是否正确,若正确则显示配置,若格式错误显示错误原因。

#校验当前文件夹下的docker-compose.yml
docker-compose config
  • ③down

此命令将会停止 up 命令所启动的容器,并移除网络

#校验当前文件夹下的docker-compose.yml
docker-compose down
  • ④exec

进入指定的容器。

docker-compose exec <service> /bin/sh
  • ⑤help

获得一个命令的帮助。

docker-compose 命令 help
  • ⑥images

列出 Compose 文件中包含的镜像。

docker-compose images
  • ⑦pause

暂停一个服务容器。

docker-compose pause [SERVICE...]
  • ⑧unpause

恢复处于暂停状态中的服务。

docker-compose unpause [SERVICE...]
  • ⑨port

打印某个容器端口所映射的公共端口。选项:--protocol=proto 指定端口协议,tcp(默认值) 或者 udp。--index=index 如果同一服务存在多个容器,指定命令对象容器的序号(默认为 1) 。

docker-compose port [options] SERVICE PRIVATE_PORT
  • ⑩pull

拉取服务依赖的镜像。选项:--ignore-pull-failures 忽略拉取镜像过程中的错误。

docker-compose pull [options] [SERVICE...]
  • ⑪push

推送服务依赖的镜像到 Docker 镜像仓库。

docker-compose push
  • ⑫run

在指定服务上执行一个命令。默认情况下,如果存在关联,则所有关联的服务将会自动被启动,除非这些服务已经在运行 中。该命令类似启动容器后运行指定的命令,相关卷、链接等等都将会按照配置自动创建。两个不同点:(1)给定命令将会覆盖原有的自动运行命令;(2)不会自动创建端口,以避免冲突。

$ docker-compose run wordpress echo "2222222"
  • ⑬scale

一般的,当指定数目多于该服务当前实际运行容器,将新创建并启动容器;反之,将停止容 器。选项:-t, --timeout TIMEOUT 停止容器时候的超时(默认为 10 秒) 。 docker-compose scale [options] [SERVICE=NUM...]

设置指定服务运行的容器个数。通过 service=num 的参数来设置数量

# 将启动 3 个容器运行 db 服务,2 个容器运行 db 服务。因为端口占用启动不了那么多,但是这样是可行的。
 docker-compose scale db=3 wordpress=2

PS:Docker Compose是容器的开发编排的利器,希望老铁们在工作上能使用起来它,真心好用。

本文分享自微信公众号 - 编程坑太多(idig88),作者:诸葛阿明

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-08-02

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 跟我一起学docker(12)--docker compose的使用

    IT故事会
  • 『中级篇』Docker Compose的安装和基本使用(39)

    PS: docker-compose的概念有直观的理解,包括compose的命令行和使用。

    IT故事会
  • 『中级篇』Docker 水平扩展和负载均衡(40)

    PS:Docker的scale 可以扩展,也可以所有,他们自动来控制的。web=10 可以改成5 其中的6,7,8,9,10就被删除了。

    IT故事会
  • docker-compose

    Docker for Mac 、Docker for Windows 自带 docker-compose 二进制文件,不需要再次安装,这里只介绍Linux 安装...

    羊羽shine
  • Docker 系列五(Docker Compose 项目).

        Docker Compose 是官方编排项目之一,负责快速的部署分布式应用。它允许用户通过一个单独的 docker-compose.yml 模板文件(Y...

    JMCui
  • Docker 常用命令

    兜兜毛毛
  • docker compose

    docker compose是官方编排项目,负责快速在集群中部署分布式应用,负责实现对docker容器集群的快速编排

    dogfei
  • 给开源库提交 pr,让更多人知道你

    我们经常看到一个开源库会有很多人一起去维护,像 vue,webpack 就会有很多大牛去维护。

    石燕平
  • PHP Elasticsearch的基本使用方法

    对于Elasticsearch与Elasticsearch-php的安装,网上有比较多的教程,这里不再累述。只是要注意Elasticsearch、Elastic...

    双面人
  • Match

    Match对象是一次匹配的结果,包含了很多关于此次匹配的信息,可以使用Match提供的可读属性或方法来获取这些信息。

    Jinni

扫码关注云+社区

领取腾讯云代金券