25.17 用docker compose部署服务html
25.18 docker compose示例python
25.17 用docker compose部署服务mysql
好比咱们用dockerfile作了一些镜像,这些景象有nginx的,有mysql的,有redis的,如今要把这三个镜像,让他们同时启动批量的管理。我要跑一个服务,就可能要docker run 第一个,docker run第二个等等,可是这样很繁琐。固然能够写一个脚本,而这个docker compose就相似与shell脚本,他能够批量的管理几个容器linux
就像jumpserver,那新版的jumpserver用到了一个高版本的python,他的环境不是很好部署,因此他就借助于docker,自动的把这个环境部署好。也及时说,把jumpserver放到有docker的服务器上,他就能够运行了,只不过咱们跑的是一个docker容器,他用到的就是composenginx
docker compose能够方便咱们快捷高效地管理容器的启动、中止、重启等操做,它相似于linux下的shell脚本,基于yaml语法,在该文件里咱们能够描述应用的架构,好比用什么镜像、数据卷、网络模式、监听端口等信息。咱们能够在一个compose文件中定义一个多容器的应用(好比jumpserver),而后经过该compose来启动这个应用。git
安装compose方法以下github
1.curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-composeweb
#就是去官方下载最新版本的docker composeredis
2.chmod 755 !$sql
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 #从新启动