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 wait-for之类的工具。这些是小的包装脚本,您可以在应用程序的映像中包括这些脚本,以轮询给定的主机和端口,直到它接受TCP连接为止
例如,使用wait-for-it.sh或wait-for包装服务的命令:
version: "2"
services:
web:
build: .
ports:
- "80:8000"
depends_on:
- "db"
command: ["./wait-for-it.sh", "db:5432", "--", "python", "app.py"]
db:
image: postgres
5、自己定义包装器脚本
或者根据实际情况,自己写一个包装器脚本,进行检查
#!/bin/sh
# wait-for-postgres.sh
set -e
host="$1"
shift
cmd="$@"
until PGPASSWORD=$POSTGRES_PASSWORD psql -h "$host" -U "postgres" -c '\q'; do
>&2 echo "Postgres is unavailable - sleeping"
sleep 1
done
>&2 echo "Postgres is up - executing command"
exec $cmd
那么通过如下的方式进行编排。
command: ["./wait-for-postgres.sh", "db", "python", "app.py"]