-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcelerybeat_entrypoint.sh
executable file
·43 lines (36 loc) · 1.12 KB
/
celerybeat_entrypoint.sh
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
#!/bin/bash
set -e
function help_text() {
cat << 'END'
Docker entrypoint script for Celery Beat. Unless specified, all commands
will wait for the database to be ready.
Usage:
help - print this help text and exit
start - start the celery worker
(anything else) - run the command provided
END
}
function header() {
size=${COLUMNS:-80}
# Print centered text between two dividers of length $size
printf '#%.0s' $(seq 1 $size) && echo
printf "%*s\n" $(( (${#1} + size) / 2)) "$1"
printf '#%.0s' $(seq 1 $size) && echo
}
if [ "$1" == help ] || [ "$1" == --help ]; then help_text && exit 0; fi
sleep 0.1; # The $COLUMNS variable takes a moment to populate
# Wait for database
header "WAITING FOR DATABASE"
python wait_for_db.py
case "$1" in
start|"")
header "Starting celert beat"
# Start scheduler and webserver in same container
celery -A backend beat -l info --scheduler django_celery_beat.schedulers:DatabaseScheduler
;;
*)
# The command is something like bash. Just run it in the right environment.
header "RUNNING \"$*\""
exec "$@"
;;
esac