009.Docker Compose部署及基础使用

一 Docker Compose概述

Compose是一个用于定义和运行多容器Docker应用程序的工具。使用Compose,您能够使用YAML文件来配置应用程序的服务。而后,使用单个命令,您能够从配置中建立并启动全部服务。
Compose适用于全部环境:生产,登台,开发,测试以及CI工做流程。
使用Compose基本上是一个三步过程:
  1. 在Dockerfile中定义您的应用程序环境,以即可以在任何地方进行再生产。
  2. 定义构成应用程序的服务,docker-compose.yml 以便它们能够在隔离环境中一块儿运行。
  3. 运行docker-compose up和Compose start并运行整个应用程序。
一个docker-compose.yml格式示例以下::
 1 version: '3'
 2 services:
 3   web:
 4     build: .
 5     ports:
 6     - "5000:5000"
 7     volumes:
 8     - .:/code
 9     - logvolume01:/var/log
 10     links:
 11     - redis
 12   redis:
 13     image: redis
 14 volumes:
 15   logvolume01: {}
Compose具备管理应用程序整个生命周期的命令:
  • 启动,中止和重建服务
  • 查看正在运行的服务的状态
  • 流式传输运行服务的日志输出
  • 在服务上运行一次性命令

二 Docker Compose安装

2.1 二进制下载安装

 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
 2 root@docker01:~# sudo chmod +x /usr/local/bin/docker-compose
 

2.2 pip安装(推荐)

 1 root@docker01:~# apt-get -y install python
 2 root@docker01:~# curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py
 3 root@docker01:~# python get-pip.py			#安装PIP
 4 root@docker01:~# pip install docker-compose		#安装docker compose
 5 root@docker01:~# docker-compose version		#验证安装
 

三 Docker Compose示例

3.1 构建应用程序

 1 root@docker01:~# mkdir composetest			#建立Docker Compose目录
 2 root@docker01:~# cd composetest/
 3 root@docker01:~/composetest# vi app.py
 
提示:使用Python构建一个简单应用,具体应用内容参考官方示例便可。
https://docs.docker.com/compose/gettingstarted/#step-1-setup

3.2 建立Dockerfile

 1 root@docker01:~/composetest# vi Dockerfile		#使用Dockerfile构建镜像
 2 FROM python:3.4-alpine
 3 RUN mkdir /root/.pip				#建立pip源配置目录
 4 ADD pip.conf /root/.pip/pip.conf			#将国内pip源添加至须要构建的镜像中
 5 ADD . /code
 6 WORKDIR /code
 7 RUN pip install -r requirements.txt			#根据文件列表使用pip安装
 8 CMD ["python", "app.py"]
 
提示:以上Dockerfile相关命令参考《004.docker镜像管理》。
 1 root@docker01:~/composetest# vi requirements.txt	#建立安装软件列表文件
 2 flask
 3 redis
 4 root@docker01:~/composetest# vi pip.conf		#建立基于国内pip源的文件
 5 [global]
 6 index-url = https://mirrors.aliyun.com/pypi/simple/
 7 [install]
 8 trusted-host=mirrors.aliyun.com
 
Dockerfile解释:
  • 从Python 3.4映像开始构建映像。
  • 建立pip配置目录。
  • 将国内pip源配置文件添加到/root/.pip/映像中的路径中。
  • 将当前目录添加.到/code映像中的路径中。
  • 将工做目录设置为/code。
  • 安装Python相关包。
  • 将容器的默认命令设置为python app.py。

3.3 使用Docker Compose构建服务

 1 root@docker01:~/composetest# vi docker-compose.yml
 2 version: '3'
 3 services:
 4   web:
 5     build: .
 6     ports:
 7      - "5000:5000"
 8   redis:
 9     image: "redis:alpine"
 
Docker Compose解释:
此Compose文件定义了两个服务,web和redis。
web服务:
  • 使用从Dockerfile当前目录中构建的图像。
  • 将容器上的公开端口5000转发到主机上的端口5000。即便用Flask Web服务器的默认端口5000。
redis服务:
使用从Docker Hub拉取的公共Redis映像。
 1 root@docker01:~/composetest# docker-compose up -d		#开始构建

四 验证确认

浏览器访问:http://172.24.8.111:5000/
81_thumb1
 1 root@docker01:~/composetest# docker-compose ps
 2 root@docker01:~/composetest# docker ps
 
82_thumb1
 1 root@docker01:~/composetest# docker image ls
83_thumb1
提示:
使用Docker Compose构建的容器名称规则为:【构建时所在目录】_【yml构建文件定义服务名】_【容器启动序号】。
使用Docker Compose构建的镜像名称规则为:【构建时所在目录】_【yml构建文件定义服务名】,其tag为latest。

五 挂载卷构建

 1 root@docker01:~/composetest# vi docker-compose.yml
 2 version: '3'
 3 services:
 4   web:
 5     build: .
 6     ports:
 7      - "5000:5000"
 8     volumes:
 9      - .:/code
 10   redis:
 11     image: "redis:alpine"
 12 root@docker01:~/composetest# docker-compose up -d		#再次构建
 13 root@docker01:~/composetest# vi app.py
 14 ……
 15 return 'Hello Docker! I have been seen {} times.\n'.format(count)
 16 ……
 
浏览器访问:http://172.24.8.111:5000/
84_thumb1
提示:挂载本地卷至容器后,可快速修改本地文件,从而达到动态修改容器而无需重建image做用。

六 Docker Compose其余经常使用命令

 1 docker-compose up -d:在后台运行服务;
 2 docker-compose ps:查看当前正在运行的容器;
 3 docker-compose run:运行一次性命令,如docker-compose run web env。
 
85_thumb1
 1 docker-compose stop:中止服务,如docker-compose stop web
提示:docker-compose以yaml中服务名做为参数,而非容器名称或ID。
 1 docker-compose down --volumes:彻底删除容器同时删除容器使用的数据卷。
提示:更多Docker Compose命令参考《附004.Docker Compose命令详解》。

原文出处:https://www.cnblogs.com/itzgr/p/10171046.htmlhtml

相关文章
相关标签/搜索