Files
docker-deluge-openvpn/root/etc/scripts/healthcheck.sh

56 lines
1.1 KiB
Bash
Executable File

#!/bin/bash
# Handle SIGTERM
sigterm() {
echo "Received SIGTERM, exiting..."
trap - SIGTERM
kill -- -$$
}
trap sigterm SIGTERM
#Network check
# Ping uses both exit codes 1 and 2. Exit code 2 cannot be used for docker health checks,
# therefore we use this script to catch error code 2
HOST=${HEALTH_CHECK_HOST}
if [[ -z "$HOST" ]]
then
echo "Host not set! Set env 'HEALTH_CHECK_HOST'. For now, using default google.com"
HOST="google.com"
fi
# Check DNS resolution works
nslookup $HOST > /dev/null
STATUS=$?
if [[ ${STATUS} -ne 0 ]]
then
echo "DNS resolution failed"
exit 1
fi
ping -c 2 -w 10 $HOST # Get at least 2 responses and timeout after 10 seconds
STATUS=$?
if [[ ${STATUS} -ne 0 ]]
then
echo "Network is down"
exit 1
fi
echo "Network is up"
#Service check
#Expected output is 2 for both checks, 1 for process and 1 for grep
OPENVPN=$(pgrep openvpn | wc -l )
DELUGE=$(pgrep deluged | wc -l)
if [[ ${OPENVPN} -ne 1 ]]; then
echo "Openvpn process not running"
exit 1
fi
if [[ ${DELUGE} -ne 1 ]]; then
echo "deluge-daemon process not running"
exit 1
fi
echo "Openvpn and deluge-daemon processes are running"
exit 0