设为首页 收藏本站
查看: 776|回复: 0

[经验分享] docker compose的简单使用

[复制链接]

尚未签到

发表于 2018-5-26 10:09:05 | 显示全部楼层 |阅读模式
  笔记内容:docker compose的简单使用
笔记日期:2018-02-08


  • 25.17 安装docker compose
  • 25.18 docker compose示例


安装docker compose
  docker compose可以方便我们快捷高效地管理容器的启动、停止以及重启等操作,和批量管理容器,它类似于linux下的shell脚本,基于yaml语法,在该文件里我们可以描述应用的架构,比如用什么镜像、数据卷、网络模式、监听端口等信息。我们可以在一个compose文件中定义一个多容器的应用(比如jumpserver),然后通过该compose来启动这个应用。
  安装compose的方法如下,下载docker-compose然后放到/usr/local/bin/目录下,再更改一下权限即可:

[root@server ~]# curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
[root@server ~]# chmod 755 !$  # 指定权限
chmod 755 /usr/local/bin/docker-compose
[root@server ~]#
  docker compose的安装就这么简单,安装完后,我们来查看一下版本信息:

[root@server ~]# docker-compose version
docker-compose version 1.17.0-rc1, build a0f95af
docker-py version: 2.5.1
CPython version: 2.7.13
OpenSSL version: OpenSSL 1.0.1t  3 May 2016
[root@server ~]#
  说明:Compose区分Version 1和Version 2(Compose 1.6.0+,Docker Engine 1.10.0+)。Version 2支持更多的指令。Version 1没有声明版本默认是"version 1"。Version 1将来会被弃用。


docker compose示例
  以上我们已经安装好了docker compose ,下面用一个简单的示例演示一下如何使用docker compose,编辑.yml文件,内容如下:

[root@server ~]# vim docker-compose.yml
version: "2"  # 使用Version 2
services:  # 包含需要操作的容器
app1: # 容器的名称
image: centos_nginx  # 指定基于哪个镜像
ports:  # 指定映射的端口
- "8080:80"
networks:  # 指定使用哪个网络模式
- "net1"
volumes:  # 指定挂载的的目录
- /data/:/data
app2:
image: test_centos
networks:
- "net2"
volumes:
- /data/:/data1
entrypoint: tail -f /etc/passwd  # 这一句是为了让这个容器不会被关闭
networks:
net1:
driver: bridge
net2:
driver: bridge
  编辑完之后就可以启动了:

[root@server ~]# docker-compose up -d  # -d是丢到后台运行
Creating network "root_net2" with driver "bridge"
Creating network "root_net1" with driver "bridge"
Creating root_app2_1 ...
Creating root_app1_1 ...
Creating root_app2_1
Creating root_app1_1 ... done
[root@server ~]#
  然后docker ps看一下是否已启动成功:

  如果你没有加 entrypoint: tail -f /etc/passwd 这样的语句的话,那么app2被启动之后就会马上关闭了,所以加这一句没别的作用,就是为了不被马上关闭。不信的话,我现在删除掉那两个容器,然后再把 docker-compose.yml 文件里的那句命令给注释掉,再启动:

[root@server ~]# docker rm -f df21c6ec7
df21c6ec7
[root@server ~]# docker rm -f c2dda49
c2dda49
[root@server ~]# vim docker-compose.yml
[root@server ~]# docker-compose up -d
Creating root_app2_1 ...
Creating root_app1_1 ...
Creating root_app2_1
Creating root_app1_1 ... done
[root@server ~]#
  如上,可以看到,启动是成功的,但是我dicker ps -a查看却只有app1是在启动状态,而app2是在Exited状态:

  所以要加上 entrypoint: tail -f /etc/passwd 的原因就在这,这个语句的唯一作用就是防止容器被关闭,这是docker的一个特性,说实话我也不知道为嘛要加这样的一句话,但是不加的话末尾启动的那个容器就会被关闭,不过不一定非要写 tail -f /etc/passwd ,也可以是其他可正常执行的命令。
  docker-compose --help 可以查看该命令的文档,下面介绍几个常用的命令参数:
  停止已有的容器:

[root@server ~]# docker-compose stop
Stopping root_app1_1 ... done
Stopping root_app2_1 ... done
[root@server ~]#
  启动已有的容器:

[root@server ~]# docker-compose start
Starting app2 ... done
Starting app1 ... done
[root@server ~]#
  查看容器的状态:

[root@server ~]# docker-compose ps
Name                  Command                State     Ports
---------------------------------------------------------------
root_app1_1   /bin/sh -c /usr/local/ngin ...   Exit 137        
root_app2_1   tail -f /etc/passwd              Exit 137        
[root@server ~]#
  删除容器:

[root@server ~]# docker-compose rm -f
Going to remove root_app1_1, root_app2_1
Removing root_app1_1 ... done
Removing root_app2_1 ... done
[root@server ~]#
  停止并删除运行中的容器:

[root@server ~]# docker-compose down
Stopping root_app1_1 ... done
Stopping root_app2_1 ... done
Removing root_app1_1 ... done
Removing root_app2_1 ... done
Removing network root_net2
Removing network root_net1
[root@server ~]# docker-compose ps
Name   Command   State   Ports
------------------------------
[root@server ~]#
  关于docker-compose语法的参考文档:

  http://www.web3.xin/index/article/182.html


运维网声明 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-481248-1-1.html 上篇帖子: Docker中通过模板创建镜像,Docker容器、仓库及数据管理 下篇帖子: Docker数据卷备份恢复、桥接网络设置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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