forked from ietf-tools/datatracker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcelery-start.sh
More file actions
52 lines (44 loc) · 1.29 KB
/
celery-start.sh
File metadata and controls
52 lines (44 loc) · 1.29 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#!/bin/bash -e
#
# Run a celery worker
#
echo "Running Datatracker checks..."
./ietf/manage.py check
# Check whether the blobdb database exists - inspectdb will return a false
# status if not.
if ietf/manage.py inspectdb --database blobdb > /dev/null 2>&1; then
HAVE_BLOBDB="yes"
fi
migrations_applied_for () {
local DATABASE=${1:-default}
ietf/manage.py migrate --check --database "$DATABASE"
}
migrations_all_applied () {
if [[ "$HAVE_BLOBDB" == "yes" ]]; then
migrations_applied_for default && migrations_applied_for blobdb
else
migrations_applied_for default
fi
}
if ! migrations_all_applied; then
echo "Unapplied migrations found, waiting to start..."
sleep 5
while ! migrations_all_applied ; do
echo "... still waiting for migrations..."
sleep 5
done
fi
echo "Starting Celery..."
cleanup () {
# Cleanly terminate the celery app by sending it a TERM, then waiting for it to exit.
if [[ -n "${celery_pid}" ]]; then
echo "Gracefully terminating celery worker. This may take a few minutes if tasks are in progress..."
kill -TERM "${celery_pid}"
wait "${celery_pid}"
fi
}
trap 'trap "" TERM; cleanup' TERM
# start celery in the background so we can trap the TERM signal
celery "$@" &
celery_pid=$!
wait "${celery_pid}"