docker-compose 如何安排容器启动的顺序

概述

在使用docker-compose进行容器部署的时候,时常是需要对容器的启动顺序进行编排,比如在应用容器启动前,需要先启动数据库的容器。通过对官方文档的阅读,发现在docker-compose中,可以使用depends_on配合健康检查healthcheck来实现。

参考链接:

https://docs.docker.com/compose/compose-file/#depends_on

测试

假设有个应用需要等待ElasticSearch启动完成后,才开始启动,那么我们可以使用以下方式来编写docker-compose文件。

version: '3.3'
services:
  elasticsearch:
    image: docker.elastic.co/elasticsearch/elasticsearch:7.6.2
    environment:
      discovery.type: single-node
      TZ: Asia/Shanghai
    healthcheck:
      test: ["CMD","curl","-f","http://localhost:9200"]
      interval: 5s
      timeout: 10s
      retries: 3
      start_period: 30s
  app:
    image: nginx
    depends_on:
      elasticsearch:
        condition: service_healthy

注意,这个需要更新到docker-compose版本为v2.5.0以上才支持。

在服务elasticsearch没有进入healthy状态时,app服务是不会启动的

# docker-compose -f test.yaml ps
NAME                  COMMAND                  SERVICE             STATUS               PORTS
tmp-app-1             "/docker-entrypoint.…"   app                 created              
tmp-elasticsearch-1   "/usr/local/bin/dock…"   elasticsearch       running (starting)   9300/tcp

在服务elasticsearch启动完成时,并且健康状态为healthy,app服务才启动

# docker-compose -f test.yaml ps
NAME                  COMMAND                  SERVICE             STATUS              PORTS
tmp-app-1             "/docker-entrypoint.…"   app                 running             80/tcp
tmp-elasticsearch-1   "/usr/local/bin/dock…"   elasticsearch       running (healthy)   9300/tcp

总结

在使用百度的搜索这个问题的时候,发现大家也遇到类似的问题,但绝大多数采用的是wait-for的解决方法,这个可能应该是旧版本不支持healthcheck检查,但现在官方已经支持,这种解决方式就应该退出了,所以在遇到问题的过程中,还是阅读最新的官方文档才比较靠谱。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值