PostgreSQL-Datenbank aktualisieren

Für die Verwendung neuer Versionen von INSYS icom Router Management ist ein Upgrade der PostgreSQL-Datenbank von Version 12 auf Version 14 erforderlich.


Diese Anleitung beschreibt, wie PostgreSQL 12 und PostgreSQL 14 parallel installiert werden können, um anschließend eine Datenmigration durchzuführen.


sudo -u postgres pg_dumpall > /tmp/backup.sql
Bash

Da PostgreSQL 14 nicht nativ in Ubuntu 20.04 enthalten ist, muss das PostgreSQL-Repository manuell eingebunden werden.

sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
Bash
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
Bash
sudo apt-get update
Bash

Hinweis

Soll eine bestimmte Version installiert werden, verwenden Sie postgresql-XX anstelle von postgresql.

sudo apt-get -y install postgresql-14
Bash

sudo systemctl stop postgresql.service
Bash
cd /tmp
Bash
sudo -u postgres /usr/lib/postgresql/14/bin/pg_upgrade \
--old-datadir=/var/lib/postgresql/12/main \
--new-datadir=/var/lib/postgresql/14/main \
--old-bindir=/usr/lib/postgresql/12/bin \
--new-bindir=/usr/lib/postgresql/14/bin \
--old-options '-c config_file=/etc/postgresql/12/main/postgresql.conf' \
--new-options '-c config_file=/etc/postgresql/14/main/postgresql.conf'
Bash

Setzen Sie in den jeweiligen Konfigurationsdateien die Ports wie folgt:

sudo vim /etc/postgresql/14/main/postgresql.conf  # Port auf 5432 setzen
sudo vim /etc/postgresql/12/main/postgresql.conf  # Port auf 5433 setzen
Bash

sudo systemctl start postgresql.service
sudo -u postgres psql -c "SELECT version();"
Bash

sudo -u postgres psql
Bash

Im PostgreSQL-Prompt:

\password u4insysicomroutermgmt
Pgsql

sudo apt remove postgresql-12 postgresql-contrib-12
Bash
sudo rm -rf /etc/postgresql/12
sudo -u postgres /tmp/delete_old_cluster.sh
Bash