游牧任务被杀

时间:2018-12-17 20:59:41

标签: database delayed-job nomad

任务组中有两个任务  1)一个数据库任务来调出一个数据库并且  2)需要数据库启动的应用程序。

两者都是并行启动的,并且db任务花费了一点时间,但是到那时,应用程序意识到db没有启动,并杀死了db任务。有什么办法吗?请告知。

1 个答案:

答案 0 :(得分:0)

通常有一个入口点脚本来检查数据库是否正常。这是我以前使用过的脚本:

#!/bin/sh

set -e
cmd="$*"

postgres_ready() {
    if test -z "${NO_DB}"
    then
        PGPASSWORD="${RDS_PASSWORD}" psql -h "${RDS_HOSTNAME}" -U "${RDS_USERNAME}" -d "${RDS_DB_NAME}" -c '\l'
        return $?
    else
        echo "NO_DB Postgres will pretend to be up"
        return 0
    fi
}


until postgres_ready
do
    >&2 echo "Postgres is unavailable - sleeping"
    sleep 1
done

>&2 echo "Postgres is up - continuing..."

exec "${cmd}"

您可以将其另存为entrypoint.sh,并以应用程序启动脚本作为参数来运行它。例如:entrypoint.sh python main.py