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 #重新启动