seafile-containerized/seahub/scripts/start.sh
Gerrit Gogel bfeaa2188f seahub: improved lifecycle management
Exits container if seahub or socat exits or if connection to seafile-server is lost. It is recommended to set the restart policy for the container to "unless-stopped".
2024-02-14 10:59:03 +01:00

58 lines
1.5 KiB
Bash

#!/bin/bash
function init_seahub {
/scripts/create_data_links.sh
echo "{ \"email\": \"${SEAFILE_ADMIN_EMAIL}\",\"password\": \"${SEAFILE_ADMIN_PASSWORD}\"}" >/opt/seafile/conf/admin.txt
sed -i 's@bind =.*@bind = "0.0.0.0:8000"@' /opt/seafile/conf/gunicorn.conf.py
}
function start_seahub {
/opt/seafile/seafile-server-latest/seahub.sh start
}
function start_socat {
mkdir -p /opt/seafile/seafile-server-latest/runtime
while true; do
while ! nc -z ${SEAFILE_SERVER_HOSTNAME} 8001 2>/dev/null; do
sleep 1
done
echo "Starting socat..."
socat -d -d UNIX-LISTEN:/opt/seafile/seafile-server-latest/runtime/seafile.sock,fork,unlink-early TCP:${SEAFILE_SERVER_HOSTNAME}:8001,forever,keepalive,keepidle=10,keepintvl=10,keepcnt=2
done
}
function watch_server {
while true; do
sleep 1
if ! nc -z ${SEAFILE_SERVER_HOSTNAME} 8082 2>/dev/null; then
echo "Lost connection to seafiler-server. Stopping seahub..."
/opt/seafile/seafile-server-latest/seahub.sh stop
fi
done
}
function watch_seahub {
while true; do
sleep 1
if ! pgrep -f "seahub.wsgi:application" >/dev/null; then
echo "Seahub process was stopped. Exiting container..."
break
fi
done
}
function logger {
tail -f /opt/seafile/logs/seahub.log | tee
}
init_seahub
start_seahub
start_socat &
watch_server &
watch_seahub &
logger &
wait -n
exit $?