前两篇文章我们介绍了Dockerfile的使用Docker(二):Dockerfile使用介绍,我们知道使用一个Dockerfile模板文件可以定义一个单独的应用容器,如果需要定义多个容器就需要服务编排。服务编排有很多种技术方案,今天给大家介绍Docker官方产品Docker Compose。
Dockerfile可以让用户管理一个单独的应用容器;而Compose则允许用户在一个模板(YAML格式)中定义一组相关联的应用容器(被称为一个项目,即项目),例如一个Web服务容器再加上后端的数据库服务容器等。
通过Docker-Compose用户可以很容易地用一个配置文件定义一个多容器的应用,然后使用一条指令安装这个应用的所有依赖,完成构建.Docker-Compose解决了容器与容器之间如何管理编排的问题。
Docker Compose工作原理图
撰写中有两个重要的概念:
一个项目可以由多个服务(容器)关联而成,Compose面向项目进行管理,通过子命令对项目中的一组容器进行便捷地生命周期管理。
Compose项目由Python编写,实现上调用了Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API,就可以在其上利用Compose进行编排管理。
Docker Compose是Docker的独立产品,因此需要安装Docker之后在单独安装Docker Compose。
方法一:
#下载
sudo curl -L https://github.com/docker/compose/releases/download/1.20.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
#安装
chmod +x /usr/local/bin/docker-compose
#查看版本
docker-compose version
方法二:
#安装pip
yum -y install epel-release
yum -y install python-pip
#确认版本
pip --version
#更新pip
pip install --upgrade pip
#安装docker-compose
pip install docker-compose
#查看版本
docker-compose version
推荐使用方法一进行安装,安装成功后输入docker-compose version
会返回docker-compose的版本信息,如下:
[root@localhost ~]# docker-compose version
docker-compose version 1.19.0, build 9e633ef
docker-py version: 2.7.0
CPython version: 2.7.13
OpenSSL version: OpenSSL 1.0.1t 3 May 2016
出现以上信息,表明docker-compose安装成功
安装补全工具(可选)
为了方便我们输入命令,也可以安装Docker的补全提示工具帮忙我们快速输入命令
#安装
yum install bash-completion
#下载docker-compose脚本
curl -L https://raw.githubusercontent.com/docker/compose/$(docker-compose version --short)/contrib/completion/bash/docker-compose > /etc/bash_completion.d/docker-compose
没有什么比来一个小例子练练手更好的学习方法了,我们以官网上的简单示例来看看docker compose的使用方法。
我们设计这么一个场景,使用Python启动一个Web服务,输出一个hello()
方法,每次访问的时候在Redis缓存中进行计数,并且将统计的结果打印到页面中。
创建项目路径:
mkdir composetest
cd composetest
在目录下创建app.py
文件
import time
import redis
from flask import Flask
app = Flask(__name__)
cache = redis.Redis(host='redis', port=6379)
def get_hit_count():
retries = 5
while True:
try:
return cache.incr('hits')
except redis.exceptions.ConnectionError as exc:
if retries == 0:
raise exc
retries -= 1
time.sleep(0.5)
@app.route('/')
def hello():
count = get_hit_count()
return 'Hello World! I have been seen {} times.\n'.format(count)
if __name__ == "__main__":
app.run(host="0.0.0.0", debug=True)
在这个例子中, redis 使用了容器内的网络默认端口是6379。这段 Python 程序的内容就是,启动后连接 Redis 并且输出 hello()
方法,当每次访问的时候累计访问次数并且将结果放回到页面。
在同目录下创建requirements.txt
文件,添加项目依赖的python包:
flask
redis
Flask 是 Python 中一个微型的 Web 开发框架。
我们来写一个 Dockerfile 来定义 Docker 镜像,此镜像包含了 Python 的依赖包和 Python 环境。
同样在此目录下,我们创建一个 Dockerfile 文件。
FROM python:3.4-alpine
ADD . /code
WORKDIR /code
RUN pip install -r requirements.txt
CMD ["python", "app.py"]
这段代码表示:
/code
目录下/code
app.py
程序在当期目录下,我们创建一个 docker-compose.yml 文件,内容如下:
version: '2'
services:
web:
build: .
ports:
- "5000:5000"
redis:
image: "redis:alpine"
这个 Compose 文件定义了两个服务, 一个 Pyhon Web 服务和 redis 服务。
使用命令docker-compose up
启动
version: '2'
services:
web:
build: .
command: python app.py
ports:
- "5000:5000"
volumes:
- .:/code
redis:
image: "redis:alpine"
启动成功之后,在浏览器访问:http://ipaddress:5000/
,返回如下:
Hello World! I have been seen 1 times.
刷新再次访问返回
Hello World! I have been seen 2 times.
不断的刷新数字会不断的增长。
使用docker-compose up -d
在后台启动服务
[root@localhost composetest]# docker-compose up -d
Starting composetest_web_1 ...
Starting composetest_web_1 ... done
使用docker-compose ps
命令查看启动的服务
[root@localhost composetest]# docker-compose ps
Name Command State Ports
-------------------------------------------------------------------------------------
composetest_redis_1 docker-entrypoint.sh redis ... Up 6379/tcp
composetest_web_1 python app.py Up 0.0.0.0:5000->5000/tcp
使用docker-compose stop
停止服务。
[root@localhost composetest]# docker-compose stop
Stopping composetest_web_1 ... done
Stopping composetest_redis_1 ... done
其它常用命令
#查看帮助
docker-compose -h
# -f 指定使用的 Compose 模板文件,默认为 docker-compose.yml,可以多次指定。
docker-compose -f docker-compose.yml up -d
#启动所有容器,-d 将会在后台启动并运行所有的容器
docker-compose up -d
#停用移除所有容器以及网络相关
docker-compose down
#查看服务容器的输出
docker-compose logs
#列出项目中目前的所有容器
docker-compose ps
#构建(重新构建)项目中的服务容器。服务容器一旦构建后,将会带上一个标记名,例如对于 web 项目中的一个 db 容器,可能是 web_db。可以随时在项目目录下运行 docker-compose build 来重新构建服务
docker-compose build
#拉取服务依赖的镜像
docker-compose pull
#重启项目中的服务
docker-compose restart
#删除所有(停止状态的)服务容器。推荐先执行 docker-compose stop 命令来停止容器。
docker-compose rm
#在指定服务上执行一个命令。
docker-compose run ubuntu ping docker.com
#设置指定服务运行的容器个数。通过 service=num 的参数来设置数量
docker-compose scale web=3 db=2
#启动已经存在的服务容器。
docker-compose start
#停止已经处于运行状态的容器,但不删除它。通过 docker-compose start 可以再次启动这些容器。
docker-compose stop
开始使用Docker Compose
使用Docker-Compose编排容器
(转载本站文章请注明作者和出处纯洁的微笑-ityouknow)
文章浏览阅读1k次。spring cloud 中间件_springcloud中间件
文章浏览阅读3.3k次。自己试了vxe-table的官方文档方法,没有成功。最后使用了原生的方法scrollTo()实现了,加入计时器效果更明显 setTimeout(() => { document .getElementsByClassName("vxe-table--body-wrapper")[0] .scrollTo(0, this.$refs.xTable2.tableHeight); }, 500);..._vxe-table 滚动到某一行
文章浏览阅读426次。Apk文件的格式Android application package文件。每个要安装到android平台的应用都要被编译打包为一个单独的文件,后缀名为.apk,其中包含了应用的二进制代码、资源、配置文件等。apk文件实际是一个zip压缩包,可以通过解压缩工具解开。可以用zip解开*.apk文件,下面是一个helloword的apk示例文件。|– AndroidManifest.xml |– ME..._@ref/0x7f070000是什么意思
文章浏览阅读1w次,点赞8次,收藏3次。Python、unittest_python 测试套加载环境文件
文章浏览阅读725次。今天又一次搞Linux生产环境搭建。这是种步骤很多,很繁琐而且又不得不做的事情。虽然做过很多次,但还是有很多步骤、命令不记得,每一次到处找资料很麻烦,于是将一些步骤记下,以便查找。登录远程MySQLmysql -h 192.168.1.100 -u root -p给MySQl非root账户分配权限给账号user1 密码为123456 的用户testDB数据库的所有表的select,insert,u..._dt命令
文章浏览阅读85次。In computer science, aheapis a specialized tree-based data structure that satisfies the heap property: if P is a parent node of C, then the key (the value) of P is either greater than or equal to (i..._该数的立方分解为一串连续奇数的和 样例输入 13 样例输出 13*13*13=2197=157+159+
文章浏览阅读1.1k次。IBM3650自带的raid10卡型号是8k-l,在IBM主站下载以下程序:1 ibm_sw_srapp_9.30-17006_anyos_32-64.iso中抽取RaidMan-9.30-17006.i386.rpm2 ibm_fw_aacraid_8k-8kl-5.2.0-17003_linux_32-64.bin3 ibm_fw_bios_gge149a-1.19_linux_i386.sh..._ibm3650m4升级bios
文章浏览阅读1w次。NanoPi NEO3上手日记第二天——装个WiFi_rtl8811cu openwrt
文章浏览阅读852次。故事的开始一个咖啡劲儿已经消退了的午后,业务大大突然笑眯眯的对我说:"Presto insert Mysql 特别慢,跑了几十分钟了,一直 13% 左右, 你,帮忙看看?"。第一反应就是: "嗯?难道出大问题了?",老实讲,有一点点小兴奋。一顿操作猛如虎紧接着,大概进行了如下几个猛如虎的操作:Presto 监控看起来,嗯~有一个 Stage 很慢,但是又没有死,大概十几K Row/s 的速度在爬..._presto insert
文章浏览阅读5.3k次。用nvm安装的node使用很正常,突然有天npm报错npm -vnpm不存在node -vnode不存在_error: cannot find module 'e:\devtools\nodejs\node_modules\npm\bin\npm-cli.j
文章浏览阅读930次。由于系统总是偶然出问题,记录此文以便快速恢复环境。基本环境设置密码$ sudo passwd root$ sudo passwd 用户名更换源为清华源 or else系统更新$ apt update$ apt fullupgrade$ apt autoremove$ apt autoclean配置SSH$ apt install openssh-server$ /etc/init.d/ssh start支持32位$ dpkg --add-archite_ctf实验机的输入法换出来
文章浏览阅读2.7w次,点赞189次,收藏1.4k次。题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。_c语言代码