版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/jt102605/article/details/86304591
在使用docker进行项目开发时,往往需要使用多个container对项目进行模块化,这就涉及到对多个容器创建,管理及维护.docker compose 工具为此而产生,它扮演了一个"批处理"工具,可以通过一个文件来完成对多个容器的批处理过程.
通俗来讲,docker compose是一个基于docker的工具,它可以通过一个 yml 文件定义多容器的docker应用,通过一条命令就可以 yml 文件的定义去创建或者管理应用中的多个容器.
yml 文件
docker compose的 yml 文件的默认名字为 "docker-compose.yml", 其中有三个重要的概念 Services, Networks, Volumes
1.Services
- 一个service代表一个container,这个container可以从DockerHub的image来创建,也可以从本地的Dockerfile中build出来的image来创建;
- service的启动类似与 docker run, 我们可以为其指定 network, volume, 所以可以给service指定network和volume的引用
services:
db: //container名字为"db"
image:postgres:9.4 //产生container的image来自外部仓库
volumes: //来自于volumes指定的对象
-"db-data:/var/lib/postgresql/data"
networks:
-back-tier //来自于networks中指定的对象
//类似于
docker run -d -network back-tier -v db-data:/var/lib/postgresql/data postgres:9.4
services:
worker: //container名字
build:./worker //container来自本地./worker文件夹中的Dockerfile文件build出的image
links:
-db
-redis
networks:
-back-tier
2.Networks
用于指定service所需要的network具体对象
3.Volumes
用于指定service所需要的volume具体对象
一份完整的yml文件:
扫描二维码关注公众号,回复:
5033572 查看本文章
version: '3'
services:
wordpress:
image: wordpress
ports:
- 8080:80
environment:
WORDPRESS_DB_HOST: mysql
WORDPRESS_DB_PASSWORD: root
networks:
- my-bridge
mysql:
image: mysql
environment:
MYSQL_ROOT_PASSWORD: root
MYSQL_DATABASE: wordpress
volumes:
- mysql-data:/var/lib/mysql
networks:
- my-bridge
volumes:
mysql-data:
networks:
my-bridge:
driver: bridge
docker compose的安装
linux系统下需要另外安装docker-compose工具(mac, windows下在安装docker时会自动安装上docker-compose工具)
sudo curl -L "https://github.com/docker/compose/releases/download/1.23.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose