美文网首页k8s那点事儿「实战篇」从docker走向k8s进阶Docker
「走进k8s」Docker三剑客之Docker Compose(

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

作者: IT人故事会 | 来源:发表于2019-08-02 09:26 被阅读5次

    原创文章,欢迎转载。转载请注明:转载自IT人故事会,谢谢!
    原文链接地址:「走进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是容器的开发编排的利器,希望老铁们在工作上能使用起来它,真心好用。

    相关文章

      网友评论

        本文标题:「走进k8s」Docker三剑客之Docker Compose(

        本文链接:https://www.haomeiwen.com/subject/ncnnlctx.html