一 Docker Compose概述
Compose是一个用于定义和运行多容器Docker应用程序的工具。使用Compose,您可以使用YAML文件来配置应用程序的服务。然后,使用单个命令,您可以从配置中创建并启动所有服务。
Compose适用于所有环境:生产,登台,开发,测试以及CI工作流程。
使用Compose基本上是一个三步过程:
- 在Dockerfile中定义您的应用程序环境,以便可以在任何地方进行再生产。
- 定义构成应用程序的服务,docker-compose.yml 以便它们可以在隔离环境中一起运行。
- 运行docker-compose up和Compose start并运行整个应用程序。
一个docker-compose.yml格式示例如下::
version: '3' services: web: build: . ports: - "5000:5000" volumes: - .:/code - logvolume01:/var/log links: - redis redis: image: redis volumes: logvolume01: {}
Compose具有管理应用程序整个生命周期的命令:
- 启动,停止和重建服务
- 查看正在运行的服务的状态
- 流式传输运行服务的日志输出
- 在服务上运行一次性命令
二 Docker Compose安装
2.1 二进制下载安装
root@docker01:~# sudo curl -L "https://github.com/docker/compose/releases/download/1.22.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose root@docker01:~# sudo chmod +x /usr/local/bin/docker-compose
2.2 pip安装(推荐)
root@docker01:~# apt-get -y install python root@docker01:~# curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py root@docker01:~# python get-pip.py #安装PIP root@docker01:~# pip install docker-compose #安装docker compose root@docker01:~# docker-compose version #验证安装
三 Docker Compose示例
3.1 构建应用程序
root@docker01:~# mkdir composetest #创建Docker Compose目录 root@docker01:~# cd composetest/ root@docker01:~/composetest# vi app.py
提示:使用Python构建一个简单应用,具体应用内容参考官方示例即可。
https://docs.docker.com/compose/gettingstarted/#step-1-setup
3.2 创建Dockerfile
root@docker01:~/composetest# vi Dockerfile #使用Dockerfile构建镜像 FROM python:3.4-alpine RUN mkdir /root/.pip #创建pip源配置目录 ADD pip.conf /root/.pip/pip.conf #将国内pip源添加至需要构建的镜像中 ADD . /code WORKDIR /code RUN pip install -r requirements.txt #根据文件列表使用pip安装 CMD ["python", "app.py"]
提示:以上Dockerfile相关命令参考《004.docker镜像管理》。
root@docker01:~/composetest# vi requirements.txt #创建安装软件列表文件 flask redis root@docker01:~/composetest# vi pip.conf #创建基于国内pip源的文件 [global] index-url = https://mirrors.aliyun.com/pypi/simple/ [install] trusted-host=mirrors.aliyun.com
Dockerfile解释:
- 从Python 3.4映像开始构建映像。
- 创建pip配置目录。
- 将国内pip源配置文件添加到/root/.pip/映像中的路径中。
- 将当前目录添加.到/code映像中的路径中。
- 将工作目录设置为/code。
- 安装Python相关包。
- 将容器的默认命令设置为python app.py。
3.3 使用Docker Compose构建服务
root@docker01:~/composetest# vi docker-compose.yml version: '3' services: web: build: . ports: - "5000:5000" redis: image: "redis:alpine"
Docker Compose解释:
此Compose文件定义了两个服务,web和redis。
web服务:
- 使用从Dockerfile当前目录中构建的图像。
- 将容器上的公开端口5000转发到主机上的端口5000。即使用Flask Web服务器的默认端口5000。
redis服务:
使用从Docker Hub拉取的公共Redis映像。
root@docker01:~/composetest# docker-compose up -d #开始构建
四 验证确认
浏览器访问:http://172.24.8.111:5000/
root@docker01:~/composetest# docker-compose ps root@docker01:~/composetest# docker ps
root@docker01:~/composetest# docker image ls
提示:
使用Docker Compose构建的容器名称规则为:【构建时所在目录】_【yml构建文件定义服务名】_【容器启动序号】。
使用Docker Compose构建的镜像名称规则为:【构建时所在目录】_【yml构建文件定义服务名】,其tag为latest。
五 挂载卷构建
root@docker01:~/composetest# vi docker-compose.yml version: '3' services: web: build: . ports: - "5000:5000" volumes: - .:/code redis: image: "redis:alpine" root@docker01:~/composetest# docker-compose up -d #再次构建 root@docker01:~/composetest# vi app.py …… return 'Hello Docker! I have been seen {} times.\n'.format(count) ……
浏览器访问:http://172.24.8.111:5000/
提示:挂载本地卷至容器后,可快速修改本地文件,从而达到动态修改容器而无需重建image作用。
六 Docker Compose其他常用命令
docker-compose up -d:在后台运行服务; docker-compose ps:查看当前正在运行的容器; docker-compose run:运行一次性命令,如docker-compose run web env。
docker-compose stop:停止服务,如docker-compose stop web
提示:docker-compose以yaml中服务名作为参数,而非容器名称或ID。
docker-compose down --volumes:完全删除容器同时删除容器使用的数据卷。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
更新日志
- 张艾嘉1997《滚石24K》24K金碟珍藏版系列[低速原抓WAV+CUE][1.1G]
- 宝可梦大集结开服有哪些免费时装获取 大集结免费时装获取大全
- 宝可梦大集结国服新手宝可梦怎么选 新手公测宝可梦推荐
- 宝可梦大集结国服公测福利获取方法大全 大集结开服福利有哪些
- AminaFigarova-SuiteForAfrica(2024)[24-96]FLAC
- 黑鸭子VS绿色森林2007-男女情歌对唱[首版][WAV+CUE]
- 群星《半个月亮爬上来》[DTS-WAV]
- 日本大雷少女COS赏
- 《怪猎荒野》PS5Pro性能表现一般 外媒:会有专门优化
- 《碟中谍8》首支预告公布!阿汤哥手扒飞机惊心动魄
- 孙露《忘不了》1:1黄金母盘直刻珍藏版[低速原抓WAV分轨][1G]
- 试音宝典《试机二十六号》K2HD母盘直刻[低速原抓WAV+CUE][1.1G]
- 群星《唱给女人的歌》24K德国HD金碟[WAV+CUE]
- 孙燕姿.2011-是时候【美妙音乐】【WAV+CUE】
- 苏芮.2003-回首·时代全经典2CD【华纳】【WAV+CUE】