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检查,但现在官方已经支持,这种解决方式就应该退出了,所以在遇到问题的过程中,还是阅读最新的官方文档才比较靠谱。
上一篇:
多线程四大经典案例
下一篇:
用一行代码高效的求一个列表的平方和