首页 » web服务器

docker-compose命令

   发表于:web服务器评论 (0)   热度:297

帮助文档

docker@default:~$ docker-compose --help

Define and run multi-container applications with Docker.

Usage:
  docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...]
  docker-compose -h|--help

Options:
  -f, --file FILE             Specify an alternate compose file
                              (default: docker-compose.yml)
  -p, --project-name NAME     Specify an alternate project name
                              (default: directory name)
  --verbose                   Show more output
  --log-level LEVEL           Set log level (DEBUG, INFO, WARNING, ERROR, CRITICAL)
  --no-ansi                   Do not print ANSI control characters
  -v, --version               Print version and exit
  -H, --host HOST             Daemon socket to connect to

  --tls                       Use TLS; implied by --tlsverify
  --tlscacert CA_PATH         Trust certs signed only by this CA
  --tlscert CLIENT_CERT_PATH  Path to TLS certificate file
  --tlskey TLS_KEY_PATH       Path to TLS key file
  --tlsverify                 Use TLS and verify the remote
  --skip-hostname-check       Don't check the daemon's hostname against the
                              name specified in the client certificate
  --project-directory PATH    Specify an alternate working directory
                              (default: the path of the Compose file)
  --compatibility             If set, Compose will attempt to convert keys
                              in v3 files to their non-Swarm equivalent

Commands:
  build              构建或重建服务
  bundle             从compose配置文件中产生一个docker绑定
  config             验证并查看compose配置文件
  create             创建服务
  down               停止并移除容器、网络、镜像和数据卷
  events             从容器中接收实时的事件
  exec               在一个运行中的容器上执行一个命令
  help               获取命令的帮助信息
  images             列出所有镜像
  kill               通过发送SIGKILL信号来停止指定服务的容器
  logs               从容器中查看服务日志输出
  pause              暂停服务
  port               打印绑定的公共端口
  ps                 列出所有运行中的容器
  pull               拉取并下载指定服务镜像
  push               Push service images
  restart            重启YAML文件中定义的服务
  rm                 删除指定已经停止服务的容器
  run                在一个服务上执行一条命令
  scale              设置指定服务运行容器的个数
  start              在容器中启动指定服务
  stop               停止已运行的服务
  top                显示各个服务容器内运行的进程
  unpause            恢复容器服务
  up                 创建并启动容器
  version            显示Docker-Compose版本信息

命令解析

docker-compose

docker-compose [-f <args>...] [options] [COMMAND] [ARGS...]

命令选项[-f <args>...]

  • -f, --file FILE 指定Compose模板文件,默认为docker-compose.yml可多次指定。
$ docker-compose -f docker-compose.yml up -d
  • -p, --project-name NAME 指定项目名称,默认使用当前所在目录名称作为项目名称。
  • -x-network-driver 使用Docker可拔插网络后端特性,需Docker1.9+版本支持。
  • -x-network-driver DRIVER 指定网络后端驱动,默认为bridge,需Docker1.9+版本支持。
  • -verbose 输出更多调试信息
  • -v, --version 打印版本并退出

docker-compose up

启动所有服务

docker-compose up [options] [--scale SERVICE=NUM...] [SERVICE...]

命令选项[options]

  • -d 指定在后台以守护进程方式运行服务容器
  • -no-color 设置不使用颜色来区分不同的服务器的控制输出
  • -no-deps 设置不启动服务所链接的容器
  • -force-recreate 设置强制重新创建容器,不能与--no-recreate选项同时使用。
  • --no-create 若容器已经存在则不再重新创建,不能与--force-recreate选项同时使用。
  • --no-build 设置不自动构建缺失的服务镜像
  • --build 设置在启动容器前构建服务镜像
  • --abort-on-container-exit 若任何一个容器被停止则停止所有容器,不能与选项-d同时使用。
  • -t, --timeout TIMEOUT 设置停止容器时的超时秒数,默认为10秒。
  • --remove-orphans 设置删除服务中没有在compose文件中定义的容器
  • --scale SERVICE=NUM 设置服务运行容器的个数,此选项将会负载在compose中通过scale指定的参数。

docker-compose ps

列出项目中当前的所有容器

docker-compose ps [options] [SERVICE...]
docker@default:~$ docker-compose ps
ERROR:
        Can't find a suitable configuration file in this directory or any
        parent. Are you in the right directory?

        Supported filenames: docker-compose.yml, docker-compose.yaml
docker@default:~$ docker-compose ps
    Name         Command    State    Ports
------------------------------------------
swoft_swoft_1   /bin/bash   Exit 0

docker-compose -h

查看docker-compose帮助

docker-compose down

停止和删除容器、网络、卷、镜像

docker-compose down [options]

命令选项 [options]

  • --rmi type 删除镜像类型,类型可选:
    • --rmi all 删除compose文件中定义的所有镜像
    • --rmi local 删除镜像名为空的镜像
  • -v, --volumes 删除已经在compose文件中定义的和匿名的附在容器上的数据卷
  • --remove-orphans 删除服务中没有在compose中定义的容器

docker-compose logs

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

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

例如:

root@default:/var/www/swoft# docker-compose logs
Attaching to swoft_swoft_1
swoft_1  | root@cd054651dfcb:/var/www/swoft# exit

docker-compose build

构建或重构项目中的服务容器,服务容器一旦构建后将会带上一个标记名称,可以随时在项目目录下运行docker-compose build来重新构建服务。

docker-compose build [options] [--build-arg key=val...] [SERVICE...]

命令选项[options]

  • --compress 通过gzip压缩构建上下文环境
  • --force-rm 删除构建过程中的临时容器
  • --no-cache 构建镜像过程中不使用缓存
  • --pull 始终尝试通过拉取操作来获取更新版本的镜像
  • -m, --memory MEM为构建的容器设置内存大小
  • --build-arg key=val 为服务设置build-time变量

docker-compose pull

拉取服务依赖的镜像

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

命令选项[options]

  • --ignore-pull-failures 忽略拉取镜像过程中的错误
  • --parallel 同时拉取多个镜像
  • --quiet 拉取镜像过程中不打印进度信息

docker-compose restart

重启项目中的服务

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

命令选项[options]

  • -t, --timeout TIMEOUT指定重启前停止容器的超时时长,默认为10秒。

docker-compose rm

删除所有停止状态的服务容器,推荐先执行docker-compose stop命令来停止容器。

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

命令选项[options]

  • -f, --force 强制直接删除包含非停止状态的容器
  • -v 删除容器所挂载的数据卷

docker-compose start

启动已经存在的服务容器

docker-compose start [SERVICE...]

docker-compose run

在指定服务上执行一条命令

docker-compose run [options] [-v VOLUME...] [-p PORT...] [-e KEY=VAL...] SERVICE [COMMAND] [ARGS...]

例如:在ubuntu容器上运行ping命令10次

$ docker-compose run ubuntu ping www.baidu.com -c 10

docker-compose scale

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

docker-compose scale

例如:

$ docker-compoose scale web=3 db=2

docker-compose pause

暂停一个服务容器

docker-compose pause [SERVICE...]

docker-compose kill

发送SIGKILL信号来强制停止服务容器,支持通过-s参数来指定发送的信号。

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

例如:发送SIGINT信号强制停止服务容器

$ docker-compose kill -s SIGINT

docker-compose config

验证并查看compose文件配置

docker-compose config [options]

选项参数[options]

  • --resolve-image-digests 将镜像标签标记为摘要
  • -q, --quiet 只验证配置不输出,当配置正确时不输出任何容器,当配置错误时输出错误信息。
  • --services 打印服务名称,一行显示一个。
  • --volumes 打印数据卷名称,一行显示一个。

例如:

root@default:/var/www/swoft# docker-compose config
services:
  swoft:
    entrypoint:
    - /bin/bash
    image: swoft/swoft:latest
    ports:
    - 83:83/tcp
    privileged: true
    stdin_open: true
    tty: true
    volumes:
    - /share/swoft:/var/www/swoft:rw
version: '3.0'

docker-compose create

为服务创建容器

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

选项说明[options]

  • --force-recreate 重新创建容器,即使配置和镜像没有改变,不兼容--no-recreate参数。
  • --no-recreate 如果容器已经存在则无需重新创建,不兼容--force-recreate参数。
  • --no-build 不创建镜像即使缺失
  • --build 创建容器前生成镜像

docker-compose exec

docker-compose exec [options] SERVICE COMMAND [ARGS...]

选项参数[options]

  • -d 分离模式,以后台守护进程运行命令。
  • --privileged 获取特权
  • -T 禁用分配TTY,默认docker-compose exec分配TTY。
  • --index=index 当一个服务拥有多个容器时可通过该参数登录到该服务下的任何服务

例如:

$ docker-compose exec --index=1 web /bin/bash

docker-compose port

显示某个容器端口所映射的公共端口

docker-compose port [options] SERVICE PRIVATE_PORT

选项参数[options]

  • --protocol=proto 指定端口协议,默认为TCP,可选UDP。
  • --index=index 若同意服务存在多个容器,指定命令对象容器的索引序号,默认为1。

docker-compose push

推送服务依赖的镜像

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

选项参数[options]

  • --ignore-push-failure 忽略推送镜像过程中的错误

docker-compose stop

显示各个容器运行的进程情况

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

docker-compose unpause

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

docker-compose unpause [SERVICE...]

docker-compose version

打印Docker Compose版本信息

root@default:/var/www/swoft# docker-compose version
docker-compose version 1.24.0, build 0aa59064
docker-py version: 3.7.2
CPython version: 3.6.8
OpenSSL version: OpenSSL 1.1.0j  20 Nov 2018

(。・v・。)
喜欢这篇文章吗?欢迎分享到你的微博、QQ群,并关注我们的微博,谢谢支持。