Docker Compose 容器编排工具,也可以认为是一个构建工具,可以配置并启动多个容器,适合复杂业务场景。

安装:




sudo curl -L "https://github.com/docker/compose/releases/download/1.24.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

sudo chmod +x /usr/local/bin/docker-compose



compose的配置文件使用yaml格式

Docker Compose 官方入门文档:

创建一个项目目录



mkdir composetest

cd composetest



创建一个docker-compose.yml文件,并编写下面的内容



version: "3"
services:
    web1:
        container_name: web1
        image: "centos:httpd"
        ports:
            - "8080:80"
        privileged: true
        volumes:
            - "/app/www/web1/:/var/www/html/"
        command: ['/usr/sbin/init']
    web2:
        container_name: web2
        image: "centos:httpd"
        ports:
            - "8081:80"
        privileged: true
        volumes:
            - "/app/www/web2/:/var/www/html/"
        command: ['/usr/sbin/init']

// services:定义一组服务
// web1:服务名
// container_name:容器名称
// ports:端口映射
// privileged:特权
// volumes:目录挂载

// version:代表当前使用的版本,compose经历了多个版本,每个版本的支持的参数以及一些命令是不一样的

// 关于version介绍的官方文档:https://docs.docker.com/compose/compose-file/



可以将我们编写的yaml格式的文件放入在线检查工具进行效验格式是否正确

yaml在线检查工具:http://www.yamllint.com

使用docker-compose启动容器

启动之前先确认是否有正在运行的容器占用了端口!!!



// 查看docker-compose帮助:docker-compose --help
// docker-compose up:创建并启动容器

docker-compose up -d

// -d 后台运行
// 更多参数帮助:docker-compose up --help



在宿主机的挂载到容器中的目录里面创建html,然后测试容器是否正常访问



echo "web1" > /app/www/web1/index.html

echo "web2" > /app/www/web2/index.html

// 访问web1
curl 127.0.0.1:8080

// 访问web2
curl 127.0.0.1:8081



不出意外的话,正常访问!

我们现在通过一条命令就可以快速创建容器并启动了

关闭运行的容器



// 默认关闭所有
docker-compose stop

// 可以指定关闭其中某个
docker-compose stop web1



删除容器



// 删除所有
docker-compose rm

// 可以指定删除其中某个
docker-compose rm web1



docker-compose的所有操作必须在docker-compose.yml文件所在目录中进行。

以后我们只需要编写compose.yml文件,就可以,不再需要每次输入大量的参数来启动一个容器,害怕输错、输漏了。


docker compose 时区 docker-compose -f_html