DE EN EN (Google)

PostgreSQL Upgrade

Since release 5.62 we recommend to upgrade PostgreSQL from version 9 to 11. Depending on the size of your databases, this may consume a lot of time.

On each of your servers (typically just one) which uses the docker-image docker.easydb.de/pf/postgresql but not yet docker.easydb.de/pf/postgresql-11, do all the following steps.

Get our docker image for PostgreSQL 11:

docker pull docker.easydb.de/pf/postgresql-11

Get the list of your databases:

docker exec easydb-pgsql psql -U postgres -l

From this list, ignore postgres, template0 and template1. In our example we then have the databases eas and easydb5.

stop data input

We assume that the names of your docker containers are as following… (adjust to your situation, but these names are typical)

docker stop easydb-webfrontend easydb-server easydb-eas

Note that the container easydb-pgsql is not stopped. It is needed for the following step.

export the data to files

docker exec -ti easydb-pgsql pg_dump -U postgres -v -Fc -f /backup/eas.pgdump eas
docker exec -ti easydb-pgsql pg_dump -U postgres -v -Fc -f /backup/easydb5.pgdump easydb5

stop the old PostgreSQL version

docker stop easydb-pgsql
docker rm easydb-pgsql

remove the old postgres data directory

If you have enough free storage, you may delay this step.

We assume that /srv/easydb is the directory of your easydb installation.

rm -rf /srv/easydb/pgsql/var/9.4

make the new PostgreSQL version the default

In the file defining the container easydb-pgsql, e.g. /srv/easydb/run-pgsql.sh, use the new docker image:

Before: (showing only the relevant part of the file)

docker.easydb.de/pf/postgresql

After:

docker.easydb.de/pf/postgresql-11

Please also take care to adjust other scripts and init-mechanisms that refer to the PostgreSQL image. For example, in installations made by Programmfabrik, /srv/easydb/maintain also uses /pf/postgresql and now needs to use /pf/postgresql-11.

create the docker container with the new PostgreSQL version

/srv/easydb/run-pgsql.sh

migrate custom PostgreSQL config

If you did PostgreSQL tuning in the old version, e.g. inside /srv/easydb/pgsql/etc/9.4/main/postgresql.conf, then now also do these changes in the new PostgreSQL version, e.g. in /srv/easydb/pgsql/etc/11/main/postgresql.conf.

import the data into the new PostgreSQL version

docker exec -ti easydb-pgsql psql -U postgres -c 'CREATE DATABASE "eas"'
docker exec -ti easydb-pgsql pg_restore -U postgres -v -d eas /backup/eas.pgdump

docker exec -ti easydb-pgsql psql -U postgres -c 'CREATE DATABASE "easydb5"'
docker exec -ti easydb-pgsql pg_restore -U postgres -v -d easydb5 /backup/easydb5.pgdump

The error message ERROR: schema "public" already exists can be safely ignored.

start the rest of the easydb

We assume that the names of your docker containers are as following… (adjust to your situation)

docker start easydb-eas easydb-server easydb-webfrontend

cleanup

After a few days and after your tests you should finally delete the exported files and the obsolete docker image:

docker exec easydb-pgsql rm /backup/eas.pgdump /backup/easydb5.pgdump
docker image rm docker.easydb.de/pf/postgresql

Also left over directories from the old version can be deleted now:

rm -rf /srv/easydb/pgsql/etc/9.4 /srv/easydb/pgsql/var/9.4

… assuming your data storage is /srv/easydb.