安装
sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
docker-compose --version
文件结构(yaml)
version: "3.8" //书写规则版本,根据docker engine设定
services: # 容器
flask-demo: # 服务名字,这个名字也是内部 bridge网络可以使用的 DNS name
image: flask-demo:latest # 镜像的名字
environment:
- REDIS_HOST=redis-server # 可选,相当于 docker run里的 --env
networks:
- demo-network # 可选,相当于 docker run里的 --network
ports:
- 8080:5000 # 可选,相当于 docker run里的 -p
#command: 可选,如果设置,则会覆盖默认镜像里的 CMD命令
#volumes: 可选,相当于docker run里的 -v
redis-server:
image: redis:latest
networks:
- demo-network
networks:
demo-network:
#volumes: 可选,相当于 docker volume create
如果出现目前没有指定image的情况使用以下代码
build:
context:./
dockerfile:Dockerfile.dev #在此文件夹下寻找指定名字Dockerfile.dev
build: ./ #在此文件夹下寻找dockerfile
image: flask-demo:latest #指定image名
1.Compose基础命令
docker-compose build #构建
docker-compose pull #拉取
docker-compose up #拉取+启动 yml文件有变动时自动更新
docker-compose up -d --remove-orphans #删除yaml中已删除容器
docker-compose restart #重启
docker-compose stop #停止
docker-compose rm #删除
#假设更新了某个镜像的内容则需重新build
docker-compose build flask-demo
docker-compose up
#或者
docker-compose up -d --build
2.compose 水平扩展
scale水平扩展时,将会自动进行负载均衡,访问同名服务时自动负载到各个服务。
docker-compose up -d --scale servicename=3 #启动3个servicename的容器
3.服务依赖和健康检查
yaml文件中使用depends_on关键字指定启动顺序,如下的flask容器需等redis-server启动后启动。
flask:
depends_on:
- redis-server
在dockerfile中设置健康检查,下面Dockerfili里的HEALTHCHECK 就是定义了一个健康检查。 会每隔30秒检查一次,如果失败就会退出,退出代码是1
HEALTHCHECK --interval=30s --timeout=3s \
CMD curl -f http://localhost:5000/ || exit 1
在docker-compose.yml中创建健康检查 ,healthcheck语法基本一致,但在depends_on时可以添加条件为只有依赖健康时,才会启动。默认情况为不管依赖是否健康,都将启动。
healthcheck:
test: ["CMD", "mysql" ,"-h", "mysql", "-P", "3306", "-u", "root", "-e", "SELECT 1", "cache"]
interval: 1s
timeout: 3s
retries: 3
depends_on:
flask:
condition:service_healthy