Docker Compose

安装

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值