简介:Dockerfile 可以让用户管理一个单独的应用容器;而 Compose 则允许用户在一个模板(YAML 格式)中定义一组相关联的应用容器,例如一个 Web 服务容器再加上后端的数据库服务容器等
一 、安装
使用yum安装docker-compose
yum install docker-compose -y
二 、命令说明
Usage:
docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...]
docker-compose -h|--help
Options:
-f, --file FILE 使用特定的 compose 模板文件,默认为 docker-compose.yml
-p, --project-name NAME 指定项目名称,默认使用目录名称
--verbose 输出更多调试信息
-v, --version 打印版本并退出
Commands:
build 构建或重新构建服务
down 停止服务并且移除容器,网络配置
events 从容器中接收实时事件
exec 在运行的容器中执行命令
kill 强行关闭容器
logs 查看服务的输出
pause Pause services
port 打印绑定的公共端口 # docker-compose port nginx 80
ps 列出所有容器
pull 拉取服务镜像
push 上传服务镜像
restart 重启容器
rm 移除停止的容器
run 启动一个容器并执行命令,默认情况下,所有关联的服务将会自动被启动。如果不希望自动启动关联的容器,可以使用 --no-deps 选项
scale 设置同一个服务运行的容器个数
start 启动一个已经存在的服务容器
stop 停止一个已经运行的容器,但不删除它
up 构建,(重新)创建,启动,链接一个服务相关的容器。默认情况,如果该服务的容器已经存在,
docker-compose up 将会停止并尝试重新创建他们。如果不想容器被停止并重新创建
可以使用 docker-compose up --no-recreate
三 、ymal 模板文件
默认的模板文件是 docker-compose.yml,其中定义的每个服务都必须通过 image 指令指定镜像或 build 指令(需要 Dockerfile)来自动构建。其它大部分指令都跟 docker run 中的类似。
如果使用 build 指令,在 Dockerfile 中设置的选项(例如:CMD, EXPOSE, VOLUME, ENV 等) 将会自动被获取,无需在 docker-compose.yml 中再次设置。
- image: 指定为镜像名称或镜像 ID。如果镜像在本地不存在,Compose 将会尝试拉去这个镜像
- build:指定 Dockerfile 所在文件夹的路径。 Compose 将会利用它自动构建这个镜像,然后使用这个镜像。
- command:覆盖容器启动后默认执行的命令。(执行的命令不能退出,不然的话容器会自动关闭)
- links:链接到其它服务中的容器。使用服务名称(同时作为别名)或服务名称:服务别名 (SERVICE:ALIAS) 格式都可以。
- ports:暴露端口到宿主机。当使用 HOST:CONTAINER 格式来映射端口时,如果你使用的容器端口小于 60 你可能会得到错误得结果,因为 YAML 将会解析 xx:yy 这种数字格式为 60 进制。所以建议采用字符串格式
- expose:暴露端口,但不映射到宿主机,只被连接的服务访问
- volumes:卷挂载路径设置。可以设置宿主机路径 (HOST:CONTAINER) 或加上访问模式 (HOST:CONTAINER:ro)
- environment:设置环境变量。你可以使用数组或字典两种格式
- env_file:从文件中获取环境变量,可以为单独的文件路径或列表。
如果通过docker-compose -f FILE
指定了模板文件,则env_file
中路径会基于模板文件路径。如果有变量名称与environment
指令冲突,则以后者为准。 - env_file 文件中的内容
$ cat .env # 变量值不要加引号
SERVICE=nginx
REDIS=redis.test.com
MYSQL=mysql mysql
working_dir, entrypoint, user, hostname, domainname, mem_limit, privileged, restart, stdin_open, tty, cpu_shares,这些都是和 docker run 支持的选项类似。
cpu_shares: 73
working_dir: /code
entrypoint: /code/entrypoint.sh
user: postgresql
hostname: foo
domainname: foo.com
mem_limit: 1000000000
privileged: true
stdin_open: true
tty: true
- 示例
version: "3"
services:
test:
# build 时 image 参数值为 build 的镜像名和tag
build: ./
image: alpine:v1
# docker ps 时显示的 name
container_name: alpine
# 容器的主机名
hostname: alpine
restart: always
# 映射到宿主机的端口,前面为宿主机端口,后面为容器端口
ports:
- "1194:1194"
- "1195:1195"
# 暴露到容器内部的端口
expose:
- "1194"
- "1195"
# 挂载宿主机目录到容器中
volumes:
- /etc/localtime:/etc/localtime
- /tmp:/tmp
# 设置环境变量
environment:
TZ: "Asia/Shanghai"
ENV: 'develop'
# 在 /etc/hosts 文件中添加主机名映射
extra_hosts:
- "mysql:5.6.7.8"
# 以文件的形式添加容器内部的环境变量
# 文件内容如下:
# ENV=develop #变量值不要加引号
env_file:
- .env
command: tail -f /etc/passwd
nginx:
image: nginx
# 连接同一个docker-compose文件中的容器
links:
- test
# 依赖容器启动后改容器才会继续启动
depends_on:
- test
command: tail -f /etc/passwd
四、docker-compose实践:创建LANMP镜像,并用docker-compose管理
- docker-compose.yml 文件内容
version: '2'
services:
nginx:
image: nginx-1.10.3:v1
depends_on:
- apache
volumes:
- ./nginx/conf:/usr/local/nginx/conf
- ./nginx/logs:/usr/local/nginx/logs
- ./html:/usr/local/nginx/html
- /etc/localtime:/etc/localtime
links:
- apache
ports:
- "8088:80"
- "443:443"
command: /usr/local/nginx/sbin/nginx
tty: true
privileged: true
container_name: nginx
hostname: nginx
apache:
image: php7-httpd24:v1
volumes:
- /etc/localtime:/etc/localtime
- ./html:/usr/local/httpd-2.4.25/htdocs
- ./php-http/httpd/conf:/usr/local/httpd-2.4.25/conf
- ./php-http/httpd/logs:/usr/local/httpd-2.4.25/logs
- ./php-http/php/php.ini:/etc/php.ini
command: /usr/local/httpd-2.4.25/bin/httpd -D FOREGROUND
tty: true
privileged: true
container_name: apache
hostname: apache
mysql:
image: mysql-5.7:v2
volumes:
- /etc/localtime:/etc/localtime
- ./mysql/my.cnf:/etc/mysql/my.cnf
- ./mysql/data:/var/lib/mysql
environment:
MYSQL_ROOT_PASSWORD: 123456
tty: true
privileged: true
container_name: mysql
hostname: mysql
ports:
- "33006:3306"
- 创建使用Dockerfile创建镜像后使用docker-compose up启动容器