Ubuntu 21.04のPostgresql 12を13へバージョンアップする

提供:FirstWiki
ナビゲーションに移動 検索に移動

アップグレード前の状態

$ sudo pg_lsclusters 
Ver Cluster Port Status Owner    Data directory              Log file
12  main    5432 online postgres /var/lib/postgresql/12/main /var/log/postgresql/postgresql-12-main.log
13  main    5433 online postgres /var/lib/postgresql/13/main /var/log/postgresql/postgresql-13-main.log
  • Ver 12, Port 5432 - アップグレード前からあるデータ
  • Ver 13, Port 5433 - Ubuntuのアップグレードで作成されたデータ

Ubuntu のアップグレード時に作成されたクラスターを削除する

$ sudo pg_dropcluster 13 main --stop
$ sudo pg_lsclusters 
Ver Cluster Port Status Owner    Data directory              Log file
12  main    5432 online postgres /var/lib/postgresql/12/main /var/log/postgresql/postgresql-12-main.log

アップグレードする

$ sudo pg_upgradecluster 12 main
$ sudo pg_lsclusters 
Ver Cluster Port Status Owner    Data directory              Log file
12  main    5433 down   postgres /var/lib/postgresql/12/main /var/log/postgresql/postgresql-12-main.log
13  main    5432 online postgres /var/lib/postgresql/13/main /var/log/postgresql/postgresql-13-main.log

アップグレードが完了すると

  • 旧バージョンのデータベースはポート 5433 で停止状態
  • 新バージョンがポート 5432 で動作中

旧バージョンの削除

新バージョンの動作が確認できたら以下のように旧バージョンを取り除く

$ sudo pg_dropcluster 12 main
$ sudo pg_lsclusters
Ver Cluster Port Status Owner    Data directory              Log file
13  main    5432 online postgres /var/lib/postgresql/13/main /var/log/postgresql/postgresql-13-main.log

旧パッケージも削除できる

$ sudo apt purge postgresql-12 postgresql-client-12