一个使用Docker容器的应用,一般由多个容器组成。使用Docker Compose,再也不须要使用shell脚原本启动容器。在配置文件中,全部的容器经过services来定义,而后使用docker-compose脚原本启动,中止和重启应用,和应用中的服务以及全部依赖服务的容器 Compose 经过一个配置文件来管理多个Docker容器,很是适合组合使用多个容器进行开发的场景。java
服务编排工具使得Docker应用管理更为方便快捷。mysql
Docker Compose网站:docs.docker.com/composegit
使用Compose
基本上是三个步骤:github
1.定义Dockerfile
web
2.编写docker-compose.yml
redis
3.最后运行 docker-compose up
启动服务spring
Ubuntu 17.04 x64
Docker CE: 17.12.0-ce
Docker Compose: 1.18.0sql
参考-https://docs.docker.com/compose/install/#prerequisitesdocker
在Linux上,您能够从GitHub上的Compose存储库版本页面下载Docker Compose 最新二进制文件shell
运行此命令下载最新版本的Docker Compose
$ curl -L https://github.com/docker/compose/releases/download/1.18.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
复制代码
对二进制文件应用可执行权限
$ chmod +x /usr/local/bin/docker-compose
复制代码
验证
$ docker-compose --version
docker-compose version 1.16.1, build 6d1ac21
复制代码
卸载
要卸载 Docker Compose,若是使用 curl 如下安装:
$ rm /usr/local/bin/docker-compose
复制代码
使用Docker Compose
能够轻松地在Docker
容器中,构建独立环境运行的WordPress
,在开始以前必须安装Docker Compose
。
1.建立一个空的项目目录。
新建一个你能记住的目录,这个目录是应用镜像的上下文,该目录用于存放构建该镜像的资源
在这个目录里面将会新建一个docker-compose.yml
文件
$ mkdir my_wordpress
复制代码
2.进入my_wordpress
目录
$ cd my_wordpress
复制代码
3.建立一个docker-compose.yml
文件,将启动您的 WordPress
博客和一个单独的MySQL
实例并挂载数据持久化到宿主机
$ touch docker-compose.yml
$ vi docker-compose.yml
复制代码
内容以下
version: '3'
services:
db:
image: mysql:5.7
volumes:
- db_data:/var/lib/mysql
restart: always
environment:
MYSQL_ROOT_PASSWORD: somewordpress
MYSQL_DATABASE: wordpress
MYSQL_USER: wordpress
MYSQL_PASSWORD: wordpress
wordpress:
depends_on:
- db
image: wordpress:latest
ports:
- "8000:80"
restart: always
environment:
WORDPRESS_DB_HOST: db:3306
WORDPRESS_DB_USER: wordpress
WORDPRESS_DB_PASSWORD: wordpress
volumes:
db_data:
复制代码
image
image:
指定服务的镜像名称或镜像 ID
image: mysql
,image: wordpress:latest
。若是镜像在本地不存在,Compose 将会尝试拉取这个镜像。
因此咱们不须要先拉取镜像
volumes
- db_data:
指MySQL
实例挂载数据持久化到宿主机/var/lib/docker/volumes/mywordpress_db_data/_data
PS
$ docker run -v /var/lib/mysql --name mywordpress_db_data -e MYSQL_ROOT_PASSWORD=wordpress -d mysql
$ docker run --name some-wordpress --link mywordpress_db_data:mysql -p 8002:80 -d wordpress
复制代码
以上命令的意思是新建mywordpress_db_data
和some-wordpress
容器。等同于:docker-compose.yml
内容
root@souyunku:/opt/my_wordpress# docker-compose up -d
复制代码
若是看到以下信息就证实没毛病
Pulling db (mysql:5.7)...
5.7: Pulling from library/mysql
f49cf87b52c1: Pull complete
78032de49d65: Pull complete
837546b20bc4: Pull complete
9b8316af6cc6: Pull complete
1056cf29b9f1: Pull complete
86f3913b029a: Pull complete
f98eea8321ca: Pull complete
3a8e3ebdeaf5: Pull complete
4be06ac1c51e: Pull complete
920c7ffb7747: Pull complete
Digest: sha256:7cdb08f30a54d109ddded59525937592cb6852ff635a546626a8960d9ec34c30
Status: Downloaded newer image for mysql:5.7
Pulling wordpress (wordpress:latest)...
latest: Pulling from library/wordpress
e7bb522d92ff: Pull complete
75651f247827: Pull complete
dbcf8fd0150f: Pull complete
de80263f26f0: Pull complete
65be8ad4c5fd: Pull complete
239d5fed0dda: Pull complete
5ab39b683a9f: Pull complete
4a3f54f2d93a: Pull complete
28c970ad99e9: Pull complete
5d1e20c7c396: Pull complete
05f877a23903: Pull complete
e0a5c61bdaa6: Pull complete
d27d2d70a072: Pull complete
ba039fef4b7e: Pull complete
fd026e22f5c3: Pull complete
a523c6d55ab4: Pull complete
025590874132: Pull complete
d1f0ca983d7b: Pull complete
40d597c8be8b: Pull complete
Digest: sha256:573257b41e1c3554cfe3a856d3c329030a821194172e2aeb1d3a7f5dd896ccb4
Creating mywordpress_db_1 ... done
Creating mywordpress_db_1 ...
Creating mywordpress_wordpress_1 ... done
root@souyunku:/opt/my_wordpress#
复制代码
root@souyunku:/opt/my_wordpress# docker container ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d715012934dc wordpress:latest "docker-entrypoint.s…" 2 hours ago Up 19 seconds 0.0.0.0:8000->80/tcp mywordpress_wordpress_1
ce956cf8d74b mysql:5.7 "docker-entrypoint.s…" 2 hours ago Up 2 hours 3306/tcp mywordpress_db_1
复制代码
root@souyunku:/opt/my_wordpress# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mysql 5.7 f008d8ff927d 2 days ago 409MB
wordpress latest 28084cde273b 9 days ago 408MB
root@souyunku:/opt/my_wordpress#
复制代码
每一个docker-compose.yml
必须定义image
或者build
中的一个,其它的是可选的。
image
指定镜像tag
或者ID
。示例:
image: mysql
image: redis
image: ubuntu:14.04
image: tutum/influxdb
image: example-registry.com:4000/postgresql
image: a4bc65fd
复制代码
注意,在version 1
里同时使用image和build是不容许的,version 2
则能够,若是同时指定了二者,会将build
出来的镜像打上名为image
标签。
用来指定一个包含Dockerfile
文件的路径。通常是当前目录.build
并生成一个随机命名的镜像。
实例
├── app
│ ├── Dockerfile
│ └── docker-spring-boot-demo-maven-plugin-0.0.1-SNAPSHOT.jar
├── docker-compose.yml
复制代码
Dockerfile 内容
root@souyunku:/opt/app# cat Dockerfile
FROM java:8
VOLUME /tmp
ADD docker-spring-boot-demo-maven-plugin-0.0.1-SNAPSHOT.jar app.jar
RUN bash -c 'touch /app.jar'
EXPOSE 9000
复制代码
**docker-compose.yml ** 内容
root@souyunku:/opt# cat docker-compose.yml
app:
build: ./app
ports:
- "9090:80"
expose:
- 80
复制代码
./app
是放Dockerfile
的路径
ports
用于暴露端口 同docker run -p
用来覆盖缺省命令。示例:
command: bundle exec thin -p 3000
复制代码
command
也支持数组形式
command: [bundle, exec, thin, -p, 3000]
复制代码
用于连接另外一容器服务,如须要使用到另外一容器的mysql服务。能够给出服务名和别名;也能够仅给出服务名,这样别名将和服务名相同。
同docker run --link
。示例:
links:
- db
- db:mysql
- redis
复制代码
使用了别名将自动会在容器的/etc/hosts文件里建立相应记录:
172.17.2.186 db
172.17.2.186 mysql
172.17.2.187 redis
复制代码
因此咱们在容器里就能够直接使用别名做为服务的主机名。
用于暴露端口。同docker run -p
。
示例:
ports:
- "3000"
- "8000:8000"
- "49100:22"
- "127.0.0.1:8001:8001"
复制代码
expose
提供container
之间的端口访问,不会暴露给主机使用。同docker run --expose
。
expose:
- "3000"
- "8000"
复制代码
挂载数据卷。同docker run -v
。
示例:
volumes:
- /var/lib/mysql
- cache/:/tmp/cache
- ~/configs:/etc/configs/:ro
复制代码
进入MySQL容器
查看容器ID
root@souyunku:# docker container ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
559e49f8dc01 wordpress:latest "docker-entrypoint.s…" 18 minutes ago Up 18 minutes 0.0.0.0:8000->80/tcp mywordpress_wordpress_1
3c207b3e16bd mysql:5.7 "docker-entrypoint.s…" 18 minutes ago Up 18 minutes 3306/tcp mywordpress_db_1
复制代码
经过容器ID进入MySQL容器
root@souyunku:# docker exec -it 3c207b3e16bd bash
复制代码
进入MySQL容器的存储目录
root@3c207b3e16bd:/# cd var/lib/mysql
root@3c207b3e16bd:/var/lib/mysql# ls
auto.cnf ca.pem client-key.pem ib_logfile0 ibdata1 mysql private_key.pem server-cert.pem sys wordpress
ca-key.pem client-cert.pem ib_buffer_pool ib_logfile1 ibtmp1 performance_schema public_key.pem server-key.pem test.txt
root@3c207b3e16bd:/var/lib/mysql# cat test.txt
1234
复制代码
新建一个文本,用于测试MySQL容器的挂载目录,有没有同步到宿主机
root@3c207b3e16bd:/var/lib/mysql# touch test.txt
root@3c207b3e16bd:/var/lib/mysql# echo '1234' >test.txt
复制代码
宿主机查看容器挂载是否同步
root@souyunku:/var/lib/docker/volumes/mywordpress_db_data/_data# pwd
/var/lib/docker/volumes/mywordpress_db_data/_data
root@souyunku:/var/lib/docker/volumes/mywordpress_db_data/_data# ls
auto.cnf ca.pem client-key.pem ibdata1 ib_logfile1 mysql private_key.pem server-cert.pem sys wordpress
ca-key.pem client-cert.pem ib_buffer_pool ib_logfile0 ibtmp1 performance_schema public_key.pem server-key.pem test.txt
root@souyunku:/var/lib/docker/volumes/mywordpress_db_data/_data# cat test.txt
1234
root@souyunku:/var/lib/docker/volumes/mywordpress_db_data/_data#
复制代码
挂载数据卷容器,挂载是容器。同docker run --volumes-from
。示例:
volumes_from:
- service_name
- service_name:ro
- container:container_name
- container:container_name:rw
复制代码
container:container_name
格式仅支持version 2
。
添加环境变量。同docker run -e
。能够是数组或者字典格式:
environment:
RACK_ENV: development
SESSION_SECRET:
environment:
- RACK_ENV=development
- SESSION_SECRET
复制代码
用于指定服务依赖,通常是mysql、redis
等。 指定了依赖,将会优先于服务建立并启动依赖。
links
也能够指定依赖。
连接搭配docker-compose.yml
文件或者Compose
以外定义的服务,一般是提供共享或公共服务。格式与links
类似:
external_links:
- redis_1
- project_db_1:mysql
- project_db_1:postgresql
复制代码
注意,external_links
连接的服务与当前服务必须是同一个网络环境。
添加主机名映射。
extra_hosts:
- "somehost:162.242.195.82"
- "otherhost:50.31.209.229"
复制代码
将会在/etc/hosts
建立记录:
162.242.195.82 somehost
50.31.209.229 otherhost
复制代码
继承自当前yml
文件或者其它文件中定义的服务,能够选择性的覆盖原有配置。
extends:
file: common.yml
service: webapp
复制代码
service
必须有,file
可选。service
是须要继承的服务,例如web
、database
。
设置网络模式。同docker
的--net
参数。
net: "bridge"
net: "none"
net: "container:[name or id]"
net: "host"
复制代码
自定义dns服务器。
dns: 8.8.8.8
dns:
- 8.8.8.8
- 9.9.9.9
复制代码
cpu_shares, cpu_quota, cpuset, domainname, hostname, ipc, mac_address, mem_limit, memswap_limit, privileged, read_only, restart, shm_size, stdin_open, tty, user, working_dir
这些命令都是单个值,含义请参考
编写 docker-compose 请参考官方文档
Compose file version 3
Compose file version 2
Compose file version 1
参考