🍁博主简介:
🏅云计算领域优质创作者
🏅2022年CSDN新星计划python赛道第一名🏅2022年CSDN原力计划优质作者
🏅阿里云ACE认证高级工程师
🏅阿里云开发者社区专家博主💊交流社区:CSDN云计算交流社区欢迎您的加入!
目录
1、Compose简介
2、安装于卸载
2.1 pip安装
2.2 二进制包
2.3 容器中执行
2.4 卸载
👑👑👑结束语👑👑👑
编排(Orchestration)功能是复杂系统实现灵活可操作性的关键。特别是在Docker应用场景中,编排意味着用户可以灵活地对各种容器资源实现定义和管理。
|
作为Docker官方编排工具,Compose的重要性不言而喻,它可以让用户通过编写一个简单的模板文件,快速地创建和管理基于Docker容器的应用集群。
|
本篇博文将介绍Compose项目的具体情况,以及如何进行安装和使用,最后还通过两个具体案例来展示如何编写Compose模板文件。
|
1、Compose简介
Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。从功能上看,跟OpenStack中的Heat十分类似。其代码目前在
https://github.com/docker/compose
上开源。
|
Compose定位是“定义和运行多个Docker容器的应用”,其前身是开源项目Fig,目前仍然兼容Fig格式的模板文件。
|
通过第一部分中的介绍,我们知道使用一个Dockerfile模板文 件,可以让用户很方便地定义一个单独的应用容器。然而,在日常工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个Web项目,除了Web服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。
|
Compose恰好满足了这样的需求。它允许用户通过一个单独的docker-compose.yml模板文件(YAML格式)来定义一组相关联的应用容器为一个项目(project)。 |
Compose中有两个重要的概念:
·服务(service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。
·项目(project):由一组关联的应用容器组成的一个完整业务单元,在docker-compose.yml文件中定义。
|
Compose的默认管理对象是项目,通过子命令对项目中的一组容器进行便捷地生命周期管理。
Compose项目由Python编写,实现上调用了Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API,就可以在其上利用Compose来进行编排管理。
|
2、安装于卸载
Compose目前支持Linux和Mac OS平台,两者的安装过程大同小异。
安装Compose之前,要先安装Docker(需要Docker Engine 1.7.1+),详细步骤请参考第一部分中的内容。
|
Compose可以通过Python的pip工具进行安装,可以直接下载编译好的二进制文件使用,甚至直接运行在Docker容器中。
|
前两种方式是传统方式,适合本地环境下安装使用;最后一种方式则不破坏系统环境,更适合云计算场景。
|
2.1 pip安装
这种方式是将Compose当作一个Python应用来从pip源中安装。
执行安装命令:
|
$ sudo pip install -U docker-compose
可以看到类似如下输出,说明安装成功 |
Collecting docker-compose
Downloading docker-compose-1.8.0.tar.gz (149kB): 149kB downloaded
...
Successfully installed docker-compose cached-property requests texttable websocketclient docker-py dockerpty six enum34 backports.ssl-match-hostname ipaddress
安装成功后,可以查看docker-compose命令的用法: |
$ docker-compose -h
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)
--x-networking (EXPERIMENTAL) Use new Docker networking
functionality.
Requires Docker 1.9 or later.
--x-network-driver DRIVER (EXPERIMENTAL) Specify a network driver (default:"bridge").
Requires Docker 1.9 or later.
--verbose Show more output
-v, --version Print version and exit
Commands:
build Build or rebuild services
help Get help on a command
kill Kill containers
logs View output from containers
pause Pause services
port Print the public port for a port binding
ps List containers
pull Pulls service images
restart Restart services
rm Remove stopped containers
run Run a one-off command
scale Set number of containers for a service
start Start services
stop Stop services
unpause Unpause services
up Create and start containers
migrate-to-labels Recreate containers to add labels
version Show the Docker-Compose version information
之后,可以添加bash补全命令: |
$ curl -L https://raw.githubusercontent.com/docker/compose/1.8.0/contrib/completion/bash/docker-compose > /etc/bash_completion.d/docker-compose
2.2 二进制包
官方定义编译好二进制包,供大家使用。这些发布的二进制包可以在
https://github.com/docker/compose/releases
页面找到。
|
这些二进制文件,下载后直接放到执行路径下,并添加执行权限即可。例如,在Linux平台上:
|
$ sudo curl -L https://github.com/docker/compose/releases/download/1.8.0/dockercompose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
$ sudo chmod a+x /usr/local/bin/docker-comp
可以使用docker-compose version命令来查看版本信息,以测试是否安装成功 |
$ docker-compose version
docker-compose version 1.8.0, build 94f7016
docker-py version: 1.9.0
CPython version: 2.7.6
OpenSSL version: OpenSSL 1.0.1f 6 Jan 2014
2.3 容器中执行
Compose既然是一个Python应用,自然也可以直接用容器来执行它: |
$ curl -L https://github.com/docker/compose/releases/download/1.8.0/run.sh >/usr/local/bin/docker-compose
$ chmod +x /usr/local/bin/docker-compose
实际上,查看下载的run.sh脚本内容,如下所示: |
set -e
VERSION="1.8.0"
IMAGE="docker/compose:$VERSION"
# Setup options for connecting to docker host
if [ -z "$DOCKER_HOST" ]; then
DOCKER_HOST="/var/run/docker.sock"
fi
if [ -S "$DOCKER_HOST" ]; then
DOCKER_ADDR="-v $DOCKER_HOST:$DOCKER_HOST -e DOCKER_HOST"
else
DOCKER_ADDR="-e DOCKER_HOST -e DOCKER_TLS_VERIFY -e DOCKER_CERT_PATH"
fi
# Setup volume mounts for compose config and context
if [ "$(pwd)" != '/' ]; then
VOLUMES="-v $(pwd):$(pwd)"
fi
if [ -n "$COMPOSE_FILE" ]; then
compose_dir=$(dirname $COMPOSE_FILE)
fi
# TODO: also check --file argument
if [ -n "$compose_dir" ]; then
VOLUMES="$VOLUMES -v $compose_dir:$compose_dir"
fi
if [ -n "$HOME" ]; then
VOLUMES="$VOLUMES -v $HOME:$HOME -v $HOME:/root" # mount $HOME in /root to
share docker.config
fi
# Only allocate tty if we detect one
if [ -t 1 ]; then
DOCKER_RUN_OPTIONS="-t"
fi
if [ -t 0 ]; then
DOCKER_RUN_OPTIONS="$DOCKER_RUN_OPTIONS -i"
fi
exec docker run --rm $DOCKER_RUN_OPTIONS $DOCKER_ADDR $COMPOSE_OPTIONS $VOLUMES
-w "$(pwd)" $IMAGE "$@"
可以看到,它其实是下载了docker/compose镜像并运行。 |
2.4 卸载
如果是二进制包方式安装的,删除二进制文件即可: |
$ sudo rm /usr/local/bin/docker-compose
如果是通过Python pip工具安装的,则可以执行如下命令删除: |
$ sudo pip uninstall docker-compose
下一篇文章将详细讲述Compose命令说明及用法,敬请期待!
|