-
什么是Docker compose
Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。Compose的定位是定义和运行多个Docker容器的应用,同时指定多个容器的启动顺序。
Dockerfile能让用户方便的定义一个单独的容器,如果碰到需要多个容器互相配合的应用场景,就不太方便了。而Docker compose可以实现,它允许用户通过一个单独的docker-compose.yaml模版文件,来定义一组相关联的应用容器为一个项目。 -
Docker compose核心概念
服务:对应一个应用的容器,服务可以存在多个。
项目:一组关联的容器,组成一个项目,对应一个docker-compose.yaml -
安装及运行
由于笔者之前安装Docker时,安装的是Docker for mac。根据官网说明,这个版本里已经包含了docker compose,所以不用另行安装了。
$ docker-compose -v
docker-compose version 1.11.2, build dfed245
- 用docker compose构建一个程序,仅运行一个容器
4.1 创建一个docker-compose.yaml,用它定义包含哪些服务
$ cat docker-compose.yaml
version: "3.0"
services:
tomcat: #服务名唯一
image: tomcat:latest #创建当前这个服务使用的镜像是谁
ports:
- 8080:8080
4.2 运行docker-compose
docker-compose up 启动这个项目的所有服务,必须保证当前目录存在docker-compose.yaml
$ docker-compose up
Starting docker_tomcat_1
Attaching to docker_tomcat_1
tomcat_1 | NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.concurrent=ALL-UNNAMED --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED
.....
tomcat_1 | 11-Mar-2021 23:28:19.624 INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-nio-8080"]
tomcat_1 | 11-Mar-2021 23:28:19.677 INFO [main] org.apache.catalina.startup.Catalina.start Server startup in [237] milliseconds
- 构建一个多容器的程序
5.1 docker-compose.yaml
$ cat docker-compose.yaml
version: "3.0"
services:
tomcat: #服务名唯一
image: tomcat:latest #创建当前这个服务使用的镜像是谁
ports:
- 8080:8080
tomcat0002: #服务名唯一
image: tomcat:latest #创建当前这个服务使用的镜像是谁
ports:
- 8081:8080
5.2 运行docker-compose,可以看到两个tomcat都启动了
docker $ docker-compose up
Starting docker_tomcat_1
Creating docker_tomcat0002_1
Attaching to docker_tomcat_1, docker_tomcat0002_1
tomcat0002_1 | NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.concurrent=ALL-UNNAMED --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED
tomcat_1 | NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.concurrent=ALL-UNNAMED --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED
......
5.3 docker ps查看,两个tomcat在运行
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
214d25869bd6 tomcat:latest "catalina.sh run" 10 hours ago Up About a minute 0.0.0.0:8081->8080/tcp docker_tomcat0002_1
60593f71ddb5 tomcat:latest "catalina.sh run" 10 hours ago Up About a minute 0.0.0.0:8080->8080/tcp docker_tomcat_1
- docker-compose常见命令
6.1 up:用来启动所有docker-compose服务,-d 后台启动
6.2 down:关闭所有docker-compose服务
6.3 exec:进入容器,例如docker-compose exec redis(yaml中声明服务id) bash
6.4 ps:展示当前docker-compose运行的所有容器
6.5 restart:重启所有服务,加 服务id 则重启某个服务
6.6 rm:删除所有服务,加 服务id 删除某个服务
6.7 start:启动所有服务,加 服务id 启动某个服务
6.8 stop:停止所有服务,加 服务id 停止某个服务
6.9 top:查看compose容器内运行的进程 docker-compose top - docker-compose.yaml中命令介绍
7.1 常用命令
services:
服务id:
images: #使用镜像是谁 image:tag image image:@digest
container_name: #服务启动之后容器名称 相当于docker run之后的 --name
ports: #用来指定宿主机与容器端口映射 相当于docker run之后的 -p
- “8080:8080”
networks: #用来指定容器使用的是哪个网桥 docker run --network
- ems #(网桥名称自动创建) 注意,一旦指定网桥必须通过network进行声明
environment: #用来给容器中某些环境进行赋值操作
- MYSQL_ROOT_PASSWORD=root
env_file: #用来给容器中某些环境进行赋值操作,将环境变量赋值转移到配置文件中
- mysql.env
cmd: redis-server /usr/redis/conf/redis.conf #用来覆盖容器启动默认指令
depends_on: #用来指定当前服务启动依赖哪些服务
- mysql
network:
ems:
7.2 docker-compose.yaml中的build命令
作用:用来将指定dockerfile打包成对应镜像,然后运行该镜像。
version: "3.1"
services:
demo:
build:
context: demo #指定上下文目录dockerfile所在相对目录
dockerfile: Dockerfile
container_name: demo
ports:
- "8081:8081"
networks:
- hello
depends_on:
- tomcat01
网友评论