开发者社区 > 云原生 > 容器服务 > 正文

为什么Docker Compose不会等待容器准备就绪,然后继续以依赖顺序启动下一个服务?

为什么Docker Compose不会等待容器准备就绪,然后继续以依赖顺序启动下一个服务?

展开
收起
游客5k6m7fein3w74 2021-10-21 15:36:24 2023 0
1 条回答
写回答
取消 提交回答
  • Compose按照依赖顺服启动和停止容器,决定依赖关系语句有 depends_on, links, volumes_from, 和network_mode: "service:...".

    但是,对于启动,Compose不会等到容器“准备好它运行“。这里有一个很好的理由:

    等待数据库(例如)准备就绪的问题实际上只是分布式系统更大问题的一个子集。在生产中,您的数据库可能随时变得不可用或移动主机。您的应用程序需要能够适应这些类型的故障。 要处理此问题,请将应用程序设计为在发生故障后尝试重新建立与数据库的连接。如果应用程序重试连接,它最终可以连接到数据库。 最佳解决方案是在启动时以及出于任何原因丢失连接时,在应用程序代码中执行此检查。

    2021-10-21 15:36:51
    赞同 展开评论 打赏

国内唯一 Forrester 公共云容器平台领导者象限。

相关电子书

更多
应用 Docker 进行持续交付:用技术改变交付路程 立即下载
从Docker到容器服务 立即下载
Docker@Alibaba——超大规模Docker化的实战经验 立即下载