我的 OpenProject 管理软件安装了默认的 postgresql 10。目前 postgresql DB 是 12,它有很多新功能。
我想升级我的 Postgres 数据库而不丢失数据库中的数据。我的系统是 ubuntu 18.04 并托管了 openproject。
我搜索了互联网,找不到逐步升级postgresql的步骤。
你能指导我安装新数据库吗?所有数据都应该在新数据库中。谢谢你的帮助。
我的 OpenProject 管理软件安装了默认的 postgresql 10。目前 postgresql DB 是 12,它有很多新功能。
我想升级我的 Postgres 数据库而不丢失数据库中的数据。我的系统是 ubuntu 18.04 并托管了 openproject。
我搜索了互联网,找不到逐步升级postgresql的步骤。
你能指导我安装新数据库吗?所有数据都应该在新数据库中。谢谢你的帮助。
A)首先为此创建所有数据库的备份(如果不需要备份,您可以从 B 继续)
sudo su postgres
pg_dumpall > backup.sql
B) 升级到 PostgreSQL12
sudo apt-get update
sudo apt-get install postgresql-12 postgresql-server-dev-12
sudo systemctl stop postgresql.service
/usr/lib/postgresql/12/bin/pg_upgrade \
--old-datadir=/var/lib/postgresql/10/main \
--new-datadir=/var/lib/postgresql/12/main \
--old-bindir=/usr/lib/postgresql/10/bin \
--new-bindir=/usr/lib/postgresql/12/bin \
--old-options '-c config_file=/etc/postgresql/10/main/postgresql.conf' \
--new-options '-c config_file=/etc/postgresql/12/main/postgresql.conf'
exit
#change port to 5432
sudo vim /etc/postgresql/12/main/postgresql.conf
#change port to 5433
sudo vim /etc/postgresql/10/main/postgresql.conf
sudo systemctl start postgresql.service
sudo su postgres
psql -c "SELECT version();"
./analyze_new_cluster.sh
#uninstalls postgres packages
sudo apt-get remove postgresql-10 postgresql-server-dev-10
#removes the old postgresql directory
sudo rm -rf /etc/postgresql/10/
#login as postgres user
sudo su postgres
#delete the old cluster data
./delete_old_cluster.sh
注意:根据您的要求更改 postgresql.conf 和 pg_hba.conf
PS:请随意评论您的问题、建议或您想提出的任何其他修改
psql --version sudo -u postgres psql pg_dumpall > alldbs.sql
(此命令将从 postgresql db 备份所有数据库)然后从 postgres 用户退出,然后:
在终端内运行以下命令:
sudo systemctl stop postgres
sudo apt-get install -y postgresql-12 postgresql-server-dev-12 postgresql-contrib-12 libpq-dev postgresql-12-hypopg
sudo pg_dropcluster 12 main --stop
sudo pg_upgradecluster 10 main
sudo pg_dropcluster 10 main --stop
重启 postgresql 服务:
sudo systemctl restart postgresql
登录到 postgres:
su - postgres
检查版本:
psql --version
我已经完成了上述步骤,我可以更新数据库并恢复所有数据。
SHOW LC_COLLATE;
$ sudo systemctl list-units | grep postgres
$ sudo service postgresql-<source-version>.service stop
$ /usr/pgsql-<target-version>/bin/initdb -D /var/lib/pgsql/<target-version>/data --locale=<add-your-encoding>
$sudo su postgres
$ /usr/pgsql-<target-version>/bin/pg_upgrade --old-bindir /usr/pgsql-<source-version>/bin --new-bindir /usr/pgsql-<target-version>/bin --old-datadir /var/lib/pgsql/<source-version>/data --new-datadir /var/lib/pgsql/12/data --link --jobs=2 --check
如果没问题,我们可以进行下一步,如果没有在继续下一步之前解决问题预期输出:集群兼容
$sudo su postgres
$ /usr/pgsql-<target-version>/bin/pg_upgrade --old-bindir /usr/pgsql-<source-version>/bin --new-bindir /usr/pgsql-<target-version>/bin --old-datadir /var/lib/pgsql/<source-version>/data --new-datadir /var/lib/pgsql/<target-version>/data --link
预期输出:升级完成
谢谢。请享用 !!!