103.docker-compose及实例

点点圈 提交于 2019-12-25 09:51:57

【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>

25.17 用docker compose部署服务

25.18 docker compose示例

 

 

 

 

25.17 用docker compose部署服务

 

 

 

比如我们用dockerfile做了一些镜像,这些景象有nginx的,有mysql的,有redis的,现在要把这三个镜像,让他们同时启动批量的管理。我要跑一个服务,就可能要docker run 第一个,docker run第二个等等,但是这样很繁琐。当然可以写一个脚本,而这个docker compose就类似与shell脚本,他可以批量的管理几个容器

就像jumpserver,那新版的jumpserver用到了一个高版本的python,他的环境不是很好部署,所以他就借助于docker,自动的把这个环境部署好。也及时说,把jumpserver放到有docker的服务器上,他就可以运行了,只不过我们跑的是一个docker容器,他用到的就是compose

docker compose可以方便我们快捷高效地管理容器的启动、停止、重启等操作,它类似于linux下的shell脚本,基于yaml语法,在该文件里我们可以描述应用的架构,比如用什么镜像、数据卷、网络模式、监听端口等信息。我们可以在一个compose文件中定义一个多容器的应用(比如jumpserver),然后通过该compose来启动这个应用。

安装compose方法如下

1.curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

#就是去官方下载最新版本的docker compose

2.chmod 755 !$

3.docker-compose version 查看版本信息

Compose区分Version 1和Version 2(Compose 1.6.0+,Docker Engine 1.10.0+)。Version 2支持更多的指令。Version 1没有声明版本默认是"version 1"。Version 1将来会被弃用。

#从compose1.6.0以后就是Version2版本了。在compose编写的配置文件里,格式叫做yaml语法,在这里面如果不声明,就用的version1,声明了就用version2

 

 

 

实例:

[root@axinlinux-01 ~]# curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

% Total % Received % Xferd Average Speed Time Time Time Current

Dload Upload Total Spent Left Speed

100 617 0 617 0 0 313 0 --:--:-- 0:00:01 --:--:-- 313

100 8649k 100 8649k 0 0 212k 0 0:00:40 0:00:40 --:--:-- 271k

[root@axinlinux-01 ~]# du -sh /usr/local/bin/docker-compose #下好的在这个路径里。也可以du -sh !$看一下

8.5M /usr/local/bin/docker-compose

[root@axinlinux-01 ~]# chmod 755 /usr/local/bin/docker-compose

[root@axinlinux-01 ~]# 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

 

 

 

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

 

 

 

 

 

25.18 docker compose示例

 

 

 

 

 

1.vim docker-compose.yml //内容到https://coding.net/u/aminglinux/p/yuanke_centos7/git/blob/master/25docker/docker-compose.yml 查看

docker-compose up -d 可以启动两个容器

docker-compose --help

docker-compose ps/down/stop/start/rm

关于docker-compose语法的参考文档 http://www.web3.xin/index/article/182.html

 

 

实例:

 

version: "2" #使用2版本

services: #接下来的操作是容器或者是镜像的操作。第一级目录

app1: #第二级目录。容器的名字(app1)

image: centos_nginx #对应的镜像

ports: #就是-p,你要映射的哪个端口

- "8080:80"

networks: #使用哪一个网络

- "net1" #net1从下面定义

volumes: #就是-v的那个选项(挂载)。本地的data:容器的data。如果不写冒号只写一个data,就相当于一个数据卷,把data做一个分享

- /data/:/data

app2: #第二个容器

image: centos_with_nettool #基于这个镜像

networks:

- "net2" #当然也可以写成net1

volumes:

- /data/:/data1

entrypoint: tail -f /etc/passwd #写这条是因为,docker run的时候后面为bash的时候,容器是没办法继续运行的。也就是你一旦运行了yaml的脚本之后,前面的容器能启动但是后面的启动不了。

可以先把他注释掉看看有什么提示

networks:

net1:

driver: bridge #driver就是定义哪种模式。其实不写的话默认就是bridge。这样写的话可以写成其他的模式。通常是bridge。需注意pipework不支持,需要的话只能写脚本,这就写none,然后再给他分配在一个ip就行了

net2:

driver: bridge

[root@axinlinux-01 ~]# docker-compose up -d #这样启动起来

Recreating root_app2_1 ...

root_app1_1 is up-to-date

Recreating root_app2_1 ... done

[root@axinlinux-01 ~]# docker ps #看一下,只启动了app1.是因为我们注释了tail -f

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

a703ed9e8005 centos_nginx "/bin/sh -c '/usr/lo…" 2 minutes ago Up 2 minutes 0.0.0.0:8080->80/tcp root_app1_1

[root@axinlinux-01 ~]# docker ps -a #我们找一下app2发现已经为exited了

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

9486bcb736e0 centos_with_net "/bin/bash" 12 seconds ago Exited (0) 11 seconds ago root_app2_1

[root@axinlinux-01 ~]# docker-compose --help #可以看到他的指令有哪些

[root@axinlinux-01 ~]# !vim #将tail -f注释取消

vim docker-compose.yml

[root@axinlinux-01 ~]# docker-compose up -d #重新启动

 

 

 

 

 

 

 

 

 

 

 

 

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!