Docker Compose 中如何控制启动顺序和关闭顺序
1、基础的启动顺序控制
你可以使用 depends_on 选项来控制服务器的启动和关闭顺序
depends_on,links,volumes_from,和network_mode: “service:…” 这几种方式都是可以的,用以控制那个服务先启动,那个服务后启动。
2、关于启动就绪和启动顺序的问题
虽然你可以控制启动顺序,但是不能保证启动早的比启动晚的先准备就绪,比如你的mysql 启动时间画了1秒,你的web 程序启动花了 0.5秒,这个时候,其实mysql 并没有准备就绪,无法向外提供服务,你的web 服务就会启动失败,因为找不到数据库或者无法连接数据库。
3、重试机制和重连
一般情况下,数据连接失败,但是应用如果成功启动了,数据库会在一定时间内进行重连,如果你能够确保数据库容器最终是可以提供服务的,那么,最终还是可以正常运行并连接到数据库的。
要么就是在你的代码中写一段检查代码,保证能在数据库恢复时立马连接到数据库。或者进行故障切换。
如果你不希望这么复杂,而又希望在数据库准备就绪后再启动你的web 应用,那么你可以简单的写一个wait-for 脚本来保证启动顺序
4、使用包装器脚本
使用诸如wait-for-it, dockerize或sh-compatible w