Mercurial > libervia-backend
view docker/pubsub/entrypoint.sh @ 3582:71516731d0aa
core (memory/sqla): database migration using Alembic:
Alembic database migration tool, which is the recommended one for SQLAlchemy has been
integrated. When a database is created, it will be used to stamp to current (head)
revision, otherwise, DB will be checked to see if it needs to be updated, and upgrade will
be triggered if necessary.
author | Goffi <goffi@goffi.org> |
---|---|
date | Fri, 25 Jun 2021 17:55:23 +0200 |
parents | 73e04040d577 |
children | 31c84a32c897 |
line wrap: on
line source
#!/bin/bash # we first need to wait for PostgreSQL # cf. https://stackoverflow.com/a/39028690 (thanks!) RETRIES=5 until psql -c "select 1" > /dev/null 2>&1 || [ $RETRIES -eq 0 ]; do echo "Waiting for postgres server, $((RETRIES--)) remaining attempts…" sleep 1 done ori_dir=${PWD} cd /src/sat_pubsub/db # PG should be OK, we now initialize the database. If it's already done, it will fail # with exit code 3 psql -v ON_ERROR_STOP=1 pubsub < pubsub.sql 2>/dev/null case $? in 0) printf "database initialized\n" ;; 3) printf "database already exists\n" ;; *) printf "can't initialize database, please check PostgreSQL container parameters\n" >&2 exit 1 ;; esac cd $ori_dir exec /home/libervia/libervia_env/bin/twistd -n libervia-pubsub "$@"