Debian中PostgreSQL版本升级

在Debian系统上升级PostgreSQL数据库可以按照以下步骤进行:

备份数据

在进行任何升级操作之前,务必备份您的数据库。可以使用 pg_dump 工具进行备份:

sudo -u postgres pg_dumpall -U your_username -f backup.sql

更新软件包列表

确保系统已更新到最新版本:

sudo apt update

安装新版本的PostgreSQL

  1. 添加PostgreSQL官方PPA(适用于Debian 10及更高版本):
    sudo add-apt-repository "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main"
    sudo apt update
    
  2. 查看可用的PostgreSQL版本并选择要升级到的版本
    sudo apt list --upgradable | grep postgresql
    sudo apt install postgresql-
    

    替换为您想要安装的版本号。

停止旧版本的PostgreSQL服务

停止当前运行的PostgreSQL服务:

sudo systemctl stop postgresql

使用pg_upgrade进行升级

小版本升级

sudo /usr/pgsql-/bin/pg_upgrade --old-bindir /usr/pgsql-/bin --new-bindir /usr/pgsql-/bin --old-datadir /var/lib/pgsql//data --new-datadir /var/lib/pgsql//data --link --check

大版本升级

pg_dumpall -U postgres -f /home/postgres/dumpall_data.sql
pg_config --print-configure
tar zxvf postgresql-.tar.gz
cd postgresql-
./configure --prefix=/usr/local/pgsql-
make && make install
/usr/local/pgsql-/bin/initdb -D /usr/local/pgsql-/data -E UTF8
/usr/local/pgsql-/bin/pg_ctl -D /usr/local/pgsql-/data stop
/usr/local/pgsql-/bin/pg_upgrade --old-bindir /usr/local/pgsql-/bin --new-bindir /usr/local/pgsql-/bin --old-datadir /usr/local/pgsql-/data --new-datadir /usr/local/pgsql-/data --link --check

验证升级

升级完成后,检查PostgreSQL版本是否已成功更新:

psql -V