4.4. 外部データベースへの移行
既存のデータをバックアップおよび転送してから、satellite-installer
コマンドを使用して、外部の PostgreSQL データベースに接続するように Satellite を設定します。
前提条件
- Red Hat Enterprise Linux サーバーに PostgreSQL サーバーをインストールおよび設定していること。
手順
Satellite Server で、PostgreSQL 以外の Satellite サービスをすべて停止します。
# satellite-maintain service stop --exclude postgresql
内部データベースのバックアップを作成します。
# satellite-maintain backup online \ --preserve-directory \ --skip-pulp-content \ /var/migration_backup
データを新規外部データベースに転送します。
PGPASSWORD='Foreman_Password' pg_restore -h postgres.example.com -U foreman -d foreman < /var/migration_backup/foreman.dump PGPASSWORD='Candlepin_Password' pg_restore -h postgres.example.com -U candlepin -d candlepin < /var/migration_backup/candlepin.dump PGPASSWORD='Pulpcore_Password' pg_restore -h postgres.example.com -U pulp -d pulpcore < /var/migration_backup/pulpcore.dump
satellite-installer
コマンドを使用して Satellite が新規データベースを参照するように更新します。# satellite-installer \ --katello-candlepin-manage-db false \ --katello-candlepin-db-host postgres.example.com \ --katello-candlepin-db-name candlepin \ --katello-candlepin-db-user candlepin \ --katello-candlepin-db-password Candlepin_Password \ --foreman-proxy-content-pulpcore-manage-postgresql false \ --foreman-proxy-content-pulpcore-postgresql-host postgres.example.com \ --foreman-proxy-content-pulpcore-postgresql-db-name pulpcore \ --foreman-proxy-content-pulpcore-postgresql-user pulp \ --foreman-proxy-content-pulpcore-postgresql-password Pulpcore_Password \ --foreman-db-manage false \ --foreman-db-host postgres.example.com \ --foreman-db-database foreman \ --foreman-db-username foreman \ --foreman-db-password Foreman_Password
Satellite Server 上の PostgreSQL パッケージを削除します。
# satellite-maintain packages remove postgresql-server
PostgreSQL データディレクトリーを削除します。
# rm -fr /var/lib/pgsql/data