2020-04-13 17:22:06 +02:00
|
|
|
#!/bin/bash
|
|
|
|
set -e
|
|
|
|
|
2020-12-03 18:53:06 +01:00
|
|
|
help () {
|
|
|
|
echo "$0 - start PostHog's Celery worker"
|
|
|
|
echo
|
|
|
|
echo "$0 [options]"
|
|
|
|
echo
|
|
|
|
echo "Options:"
|
|
|
|
echo " --help, -h show this brief help"
|
|
|
|
echo " --with-scheduler start RedBeat, the Celery scheduler (deprecates --with-beat)"
|
|
|
|
echo " --concurrency=<N> start N workers (overrides env var WEB_CONCURRENCY)"
|
|
|
|
echo
|
|
|
|
echo "Advanced Celery options (disabled by default):"
|
|
|
|
echo " --with-gossip start Celery gossip (useful for Prometheus)"
|
|
|
|
echo " --with-heartbeat start Celery internal heartbeat (normally not useful)"
|
|
|
|
echo " --with-mingle start Celery mingle (normally not useful)"
|
|
|
|
exit 0
|
|
|
|
}
|
|
|
|
|
|
|
|
with_scheduler=false
|
|
|
|
with_gossip=false
|
|
|
|
with_heartbeat=false
|
|
|
|
with_mingle=false
|
|
|
|
|
|
|
|
while test $# -gt 0; do
|
|
|
|
case "$1" in
|
|
|
|
-h|--help)
|
|
|
|
help
|
|
|
|
;;
|
|
|
|
--with-scheduler)
|
|
|
|
with_scheduler=true
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--with-beat) # Deprecated since the name is too similar to "heartbeat"
|
|
|
|
echo "⚠️ Using docker-worker-celery with --with-beat. This argument is deprecated. Use --with-scheduler instead!"
|
|
|
|
with_scheduler=true
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--with-gossip)
|
|
|
|
with_gossip=true
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--with-heartbeat)
|
|
|
|
with_heartbeat=true
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--with-mingle)
|
|
|
|
with_mingle=true
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--concurrency*)
|
|
|
|
export WEB_CONCURRENCY=`echo $1 | sed -e 's/^[^=]*=//g'`
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
break
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
if [ "$with_scheduler" == "true" ]; then
|
2020-11-20 10:42:59 +01:00
|
|
|
./bin/docker-worker-beat &
|
|
|
|
fi
|
|
|
|
|
2020-12-03 18:53:06 +01:00
|
|
|
FLAGS=()
|
2021-07-12 12:52:05 +02:00
|
|
|
FLAGS+=("-Ofair")
|
2020-12-03 18:53:06 +01:00
|
|
|
[ "$with_gossip" == "false" ] && FLAGS+=("--without-gossip")
|
|
|
|
[ "$with_mingle" == "false" ] && FLAGS+=("--without-mingle")
|
|
|
|
[ "$with_heartbeat" == "false" ] && FLAGS+=("--without-heartbeat")
|
|
|
|
|
|
|
|
# On Heroku $WEB_CONCURRENCY contains suggested number of forks per dyno type
|
2020-10-30 10:17:55 +01:00
|
|
|
# https://github.com/heroku/heroku-buildpack-python/blob/main/vendor/WEB_CONCURRENCY.sh
|
2020-12-03 18:53:06 +01:00
|
|
|
[[ -n "${WEB_CONCURRENCY}" ]] && FLAGS+=" --concurrency $WEB_CONCURRENCY"
|
|
|
|
|
|
|
|
echo
|
|
|
|
echo "celery -A posthog worker ${FLAGS[*]}"
|
|
|
|
echo
|
|
|
|
celery -A posthog worker ${FLAGS[*]}
|
2020-11-20 10:42:59 +01:00
|
|
|
|
|
|
|
# Stop the beat!
|
|
|
|
trap 'kill $(jobs -p)' EXIT
|