码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • DockerCompose常用命令及演示


    容器的批量管理

    • 一,
    • 1.前言
    • 2.Compose安装
    • 3.Compose命令
      • 小小实现一下
        • 3.启动容器
        • 4.停止并删除容器
    • 二:
    • docker-Compose命令大全:
      • config
      • pull:`docker-compose pull`拉取服务依赖的镜像。
      • up:`docker-compose up`创建并启动所有服务的容器。指定多个yml加-f选项。以守护进程模式运行加-d选项。
      • logs:`docker-compose logs`查看服务容器的输出日志。默认情况下,`docker-compose`将对不同的服务输出使用不同的颜色来区分。可以通过`--no-color`来关闭颜色。
      • ps:`docker-compose ps`列出工程中所有服务的容器。
      • run:`docker-compose run`在指定服务容器上执行一个命令。
      • exec:`docker-compose exec`进入服务容器。
      • pause:`docker-compose pause`暂停服务容器
      • unpause:`docker-compose pause`暂停服务容器
      • restart:`docker-compose restart`重启服务容器。
      • start:`docker-compose start`启动服务容器。
      • stop:`docker-compose stop`停止服务容器。
      • kill:`docker-compose kill`通过发送`SIGKILL`信号停止指定服务的容器。
      • rm:`docker-compose rm `删除服务(停止状态)容器。
      • down: 停止并删除所有服务的容器、网络、镜像、数据卷。
      • images:`docker-compose images`打印服务容器所对应的镜像。
      • port:`docker-compose port`打印指定服务容器的某个端口所映射的宿主机端口。
      • top:`docker-compose top`显示正在运行的进程。

    一,

    1.前言

    • 在开发中,可能存在同一环境中出现多个程序的情况,这些程序都会单独的作为容器启动,比如说:
      container-order 订单程序
      container-user 用户程序
      container-redis redis
      container-mysql mysql
    • 这些容器需要同时启动,同时停止,如果我们一个个的去操作,就会变的很麻烦,这时候我们就需要一个批量操作容器的工具
    • Compose是Docker的服务编排工具,主要用来构建基于Docker的复杂应用
    • Compose通过一个配置文件来管理多个Docker容器,非常适合组合使用多个容器进行开发的场景

    2.Compose安装

    # 安装docekr compose 工具
    curl -L https://github.com/docker/compose/releases/download/1.22.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
    
    # 设置权限
    chmod +x /usr/local/bin/docker-compose
    
    # 查看版本 
    docker-compose -version
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    3.Compose命令

    docker-compose主要是通过一个配置文件和几个命令来管理多个容器的
    配置文件用于配置多个容器信息
    命令用于控制多个容器的行为
    在这里插入图片描述
    上面两条命令执行位置必须跟docker-compose.yml位于同一个目录

    小小实现一下

    通过docker compose进行容器批量管理:一次性启动三个容器(nginx,tomcat,redis)

    1.创建docker-compose目录

    mkdir ~/docker-compose
    cd ~/docker-compose
    
    • 1
    • 2

    2.创建docker-compose.yml文件,内容如下

    version: '3'
    services: 
      nginx:
       container_name: my_nginx
       image: nginx
       ports:
        - 80:80
      tomcat:
       container_name: my_tomcat
       image: tomcat:8.5
       ports:
        - 8080:8080    
      redis:
       container_name: my_redis
       image: redis:5.0
       ports:
        - 6379:6379
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    3.启动容器

    # 为了演示效果更佳明显,我们使用下面命令先停止并删除所有容器
    docker stop $(docker ps -q)
    docker rm $(docker ps -aq)
    
    # 执行命令,启动容器
    # 执行此命令的时候,需要和配置文件在同一个目录下
    docker-compose up -d
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    4.停止并删除容器

    # 执行此命令的时候,需要和配置文件在同一个目录下
    docker-compose down
    
    • 1
    • 2

    在这里插入图片描述

    二:

    docker-Compose命令大全:

    部分命令选项如下:

    -f,–file:指定使用的 Compose 模板文件,默认为 docker-compose.yml,可以多次指定,指定多个 yml;
    -p, --project-name:指定工程名称,默认使用 docker-compose.yml 文件所在目录的名称;
    -v:打印版本并退出;
    –log-level:定义日志等级(DEBUG, INFO, WARNING, ERROR, CRITICAL)。
    help
    docker-compose -help查看帮助。

    config

    docker-compose config -q验证docker-compose.yml文件。当配置正确时,不输出任何内容,当配置错误时,输出错误信息。

    pull:docker-compose pull拉取服务依赖的镜像。

    # 拉取工程中所有服务依赖的镜像
    docker-compose pull
    # 拉取工程中 nginx 服务依赖的镜像
    docker-compose pull nginx
    # 拉取镜像过程中不打印拉取进度信息
    docker-compose pull -q
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    up:docker-compose up创建并启动所有服务的容器。指定多个yml加-f选项。以守护进程模式运行加-d选项。

    # 前台启动
    docker-compose up
    # 后台启动
    docker-compose up -d
    # -f 指定使用的 Compose 模板文件,默认为 docker-compose.yml,可以多次指定,指定多个 yml
    docker-compose -f docker-compose.yml up -d
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    logs:docker-compose logs查看服务容器的输出日志。默认情况下,docker-compose将对不同的服务输出使用不同的颜色来区分。可以通过--no-color来关闭颜色。

    # 输出日志,不同的服务输出使用不同的颜色来区分
    docker-compose logs
    # 跟踪日志输出
    docker-compose logs -f
    # 关闭颜色
    docker-compose logs --no-color
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    ps:docker-compose ps列出工程中所有服务的容器。

    # 列出工程中所有服务的容器
    docker-compose ps
    # 列出工程中指定服务的容器
    docker-compose ps nginx
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    run:docker-compose run在指定服务容器上执行一个命令。

    # 在工程中指定服务的容器上执行 echo "helloworld"
    docker-compose run nginx echo "helloworld"
    
    
    • 1
    • 2
    • 3

    exec:docker-compose exec进入服务容器。

    # 进入工程中指定服务的容器
    docker-compose exec nginx bash
    # 当一个服务拥有多个容器时,可通过 --index 参数进入到该服务下的任何容器
    docker-compose exec --index=1 nginx bash
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    pause:docker-compose pause暂停服务容器

    # 暂停工程中所有服务的容器
    docker-compose pause
    # 暂停工程中指定服务的容器
    docker-compose pause nginx
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    unpause:docker-compose pause暂停服务容器

    # 暂停工程中所有服务的容器
    docker-compose pause
    # 暂停工程中指定服务的容器
    docker-compose pause nginx
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    restart:docker-compose restart重启服务容器。

    # 重启工程中所有服务的容器
    docker-compose restart
    # 重启工程中指定服务的容器
    docker-compose restart nginx
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    start:docker-compose start启动服务容器。

    # 启动工程中所有服务的容器
    docker-compose start
    # 启动工程中指定服务的容器
    docker-compose start nginx
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    stop:docker-compose stop停止服务容器。

    # 停止工程中所有服务的容器
    docker-compose stop
    # 停止工程中指定服务的容器
    docker-compose stop nginx
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    kill:docker-compose kill通过发送SIGKILL信号停止指定服务的容器。

    # 通过发送 SIGKILL 信号停止工程中指定服务的容器
    docker-compose kill nginx
    
    
    • 1
    • 2
    • 3

    rm:docker-compose rm 删除服务(停止状态)容器。

    # 删除所有(停止状态)服务的容器
    docker-compose rm
    # 先停止所有服务的容器,再删除所有服务的容器
    docker-compose rm -s
    # 不询问是否删除,直接删除
    docker-compose rm -f
    # 删除服务容器挂载的数据卷
    docker-compose rm -v
    # 删除工程中指定服务的容器
    docker-compose rm -sv nginx
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    down: 停止并删除所有服务的容器、网络、镜像、数据卷。

    # 停止并删除工程中所有服务的容器、网络
    docker-compose stop
    # 停止并删除工程中所有服务的容器、网络、镜像
    docker-compose down --rmi all
    # 停止并删除工程中所有服务的容器、网络、数据卷
    docker-compose down -v
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    images:docker-compose images打印服务容器所对应的镜像。

    # 打印所有服务的容器所对应的镜像
    docker-compose images
    # 打印指定服务的容器所对应的镜像
    docker-compose images nginx
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    port:docker-compose port打印指定服务容器的某个端口所映射的宿主机端口。

    docker-compose port nginx 80
    
    
    • 1
    • 2

    top:docker-compose top显示正在运行的进程。

    # 显示工程中所有服务的容器正在运行的进程
    docker-compose top
    # 显示工程中指定服务的容器正在运行的进程
    docker-compose top nginx
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
  • 相关阅读:
    计算机组成原理---第四章指令系统---指令的寻址方式---选择题
    宝塔面板建站
    C++11实现日期和时间相关编程
    spring+mybatis+多数据源(mysql+oracle)配置
    【深入浅出imx8企业级开发实战 | 03】imx8qxp一键独立编译指南
    利用 AOP 记录接口日志
    Python中的三元运算符详解
    广播风暴的分析和解决方法(STP配置)
    6年测试,面试大放厥词,最后竟.....
    shiro框架04会话管理+缓存管理+Ehcache使用
  • 原文地址:https://blog.csdn.net/apple_69693064/article/details/126922918
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号