为什么Docker Compose不会等待容器准备就绪,然后继续以依赖顺序启动下一个服务?
Compose按照依赖顺服启动和停止容器,决定依赖关系语句有 depends_on, links, volumes_from, 和network_mode: 'service:...'.
但是,对于启动,Compose不会等到容器“准备好它运行“。这里有一个很好的理由:
等待数据库(例如)准备就绪的问题实际上只是分布式系统更大问题的一个子集。在生产中,您的数据库可能随时变得不可用或移动主机。您的应用程序需要能够适应这些类型的故障。 要处理此问题,请将应用程序设计为在发生故障后尝试重新建立与数据库的连接。如果应用程序重试连接,它最终可以连接到数据库。 最佳解决方案是在启动时以及出于任何原因丢失连接时,在应用程序代码中执行此检查。
赞0
踩0