设为首页 收藏本站
云服务器等爆品抢先购,低至4.2元/月
查看: 1662|回复: 0

[经验分享] docker-单机多容器的编排-compose

[复制链接]

尚未签到

发表于 2017-2-6 09:25:09 | 显示全部楼层 |阅读模式
     docker-compose是定义和运行多容器Docker应用程序的工具。我们可以把特定的几个容器组合起来构建成一个应用向下图一样。看上去有点像我们以前用过的saltstack的使用方式一样,同样compose使用yaml语法,通过这种方式我们可以把就像单机版本(docker版)saltstack.compose也可以yml文件为管理单位进行项目管理。
现在大家是不是很感兴趣啊。

wKioL1iN9ZnxPTAaAAJBEJNcWrM386.jpg
  • composer安装


1
2
3
4
5
6
7
yum-config-manager
--add-repo  https://docs.docker.com/engine/i ... /centos/docker.repo
  
yum -y install
docker-engine
  
centos7下面直接用pip install docker-compose



第一步创建一个自己的Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
$ mkdir composetest
$ cd composetest
  
$ cat app.py
from flask import
Flask
from redis import
Redis
  
app =
Flask(__name__)
redis =
Redis(host='redis', port=6379)
  
@app.route('/')
def hello():
    count = redis.incr('hits')
    return 'Hello World! I have been seen {}
times.\n'.format(count)
  
if __name__ ==
"__main__":
    app.run(host="0.0.0.0",
debug=True)




1
2
3
4
[iyunv@salt-node1
composetest]# cat requirements.txt
flask
redis






创建一个dockerfile
依赖于 python3.4添加本地文件到容器,工作目录当前目录下的code,安装flask和redis'插件,启动flask的一个小app
1
2
3
4
5
6
7
8
9
10
[iyunv@salt-node1
composetest]# cat Dockerfile
FROM
python:3.4-alpine
ADD . /code
WORKDIR /code
RUN pip install -r
requirements.txt
CMD
["python", "app.py"]




第二部写一个docker-compose.yml配置文件,注意名字不要写错。
本services总需要两个镜像分别是当前Dockerfile编译出的镜像和远程redis镜像,
web当前目录下构建出的镜像web自动映射端口月5000,挂载当前目录到镜像内的code目录
redis:直接拉取远程镜像并启动
注意:因为docker非默认网络可以自动解析容器名到对应容器,所以直接使用“redis”就可以访问到启动的redis容器。
1
2
3
4
5
6
7
8
9
10
11
version: '2'
services:
  web:
    build: .
    ports:
     - "5000:5000"
    volumes:
     - .:/code
  redis:
    image:
"registry.cn-hangzhou.aliyuncs.com/forker/redis:latest"





第三部启动compose
整个启动过程包括镜像构建,拉取,启动。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
[iyunv@salt-node1
composetest]# docker-compose up
Creating network
"composetest_default" with the default driver
Building web
Step 1/5 : FROM
python:3.4-alpine
---> 765c483d587c
。。。。。
redis_1  | 1:M 26 Jan 14:25:40.111 * The server is now
ready to accept connections on port 6379
web_1    |  *
Running on http://0.0.0.0:5000/ (Press
CTRL+C to quit)
web_1    |  *
Restarting with stat
web_1    |  *
Debugger is active!
web_1    |  *
Debugger pin code: 301-431-697




现在可以测试访问一下,因为上面flask的脚本每次访问都会写入redis一次
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
[iyunv@salt-node1 ~]#
curl http://0.0.0.0:5000/
Hello World! I have
been seen 1 times.
[iyunv@salt-node1 ~]#
curl http://0.0.0.0:5000/
Hello World! I have
been seen 2 times.
[iyunv@salt-node1 ~]#
curl http://0.0.0.0:5000/
Hello World! I have
been seen 3 times.
[iyunv@salt-node1 ~]#
curl http://0.0.0.0:5000/
Hello World! I have
been seen 4 times.




现在修改下代码在app.py里面修改返回“return 'Hello from Docker! I have been seen {}times.\n'.format(count)”
1
2
3
4
5
6
7
8
9
10
11
12
13
14
[iyunv@salt-node1
composetest]# vim app.py
[iyunv@salt-node1
composetest]# curl http://0.0.0.0:5000/
Hello from Docker! I
have been seen 5 times.
[iyunv@salt-node1
composetest]# curl http://0.0.0.0:5000/
Hello from Docker! I
have been seen 6 times.
[iyunv@salt-node1
composetest]# curl http://0.0.0.0:5000/
Hello from Docker! I
have been seen 7 times.





后台启动
1
2
3
4
5
6
7
8
9
10
11
12
13
[iyunv@salt-node1
composetest]# docker-compose up -d
Recreating
composetest_web_1
Starting
composetest_redis_1
[iyunv@salt-node1
composetest]# docker-compose ps
       Name                      Command               State           Ports         
-------------------------------------------------------------------------------------
composetest_redis_1   /bin/sh -c /usr/local/redi ...   Up     
6379/tcp              
composetest_web_1     python app.py                    Up      0.0.0.0:5000->5000/tcp




查看指定容器的环境变量
1
2
3
4
5
6
7
8
9
10
[iyunv@salt-node1
composetest]# docker-compose run web env
PATH=/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
HOSTNAME=230491939a67
TERM=xterm
LANG=C.UTF-8
GPG_KEY=97FC712E4C024BBEA48A61ED3A5CA953F73C700D
PYTHON_VERSION=3.4.6
PYTHON_PIP_VERSION=9.0.1
HOME=/root




停止服务
1
2
3
4
5
6
[iyunv@salt-node1
composetest]# docker-compose stop
Stopping
composetest_web_1 ... done
Stopping
composetest_redis_1 ... done




删除容器,逻辑卷和网络
1
2
3
4
5
6
7
8
9
10
[iyunv@salt-node1
composetest]# docker-compose down --volumes
Removing
composetest_web_run_1 ... done
Removing
composetest_web_1 ... done
Removing
composetest_redis_1 ... done
Removing network
composetest_defau






运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-338081-1-1.html 上篇帖子: Docker监控及日志采集神器 下篇帖子: docker-docker命令参数 单机
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表