Docker Compose 中如何控制启动顺序和关闭顺序

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"]
发布了455 篇原创文章 · 获赞 1357 · 访问量 238万+

猜你喜欢

转载自blog.csdn.net/qq_15071263/article/details/104807684
今日推荐