Procedimiento de actualización de PostgreSQL 9.1 a PostgreSQL 9.2 para ALDOS 1.4.
Por motivos de seguridad y sentido común, PostgreSQL se actualizará desde la versión 9.1 que incluía ALDOS 1.4 hacia la versión 9.2. Para ser sinceros el procedimiento correspondiente es un poco complejo, pero familiar para usuarios promedio de PostgreSQL. Si eres usuario de ALDOS y jamás has utilizado Postgres, puedes omitir el procedimiento a continuación. Si eres usuario de ALDOS y utilizas Postgresql, es Indispensable realizar todo lo siguiente al pie de la letra.
- Cambie a root:
su -l
- Respalde todas las bases de datos:
pg_dumpall -Upostgres -W > ~/respaldo_todo.sql
- Detenga Apache y otras aplicaciones o servicios que utilicen PostgreSQL.
- Detenga el servicio postgresql:
service postgresql stop
- Respalde el direcotrio de datos actual:
tar Jcf ~/respaldo-datos-pgsql-9.1.tar.xz /var/lib/pgsql/data
- Mueva el directorio de datos de PostgreSQL 9.1 a otra ruta:
mv /var/lib/pgsql/data /var/lib/pgsql/data-9.1
- Actualice paquetes de ALDOS 1.4:
yum -y update postgresql-*
- Instale el paquete postgresql-upgrade:
yum -y install postgresql-upgrade
- Se requiere un directorio de datos nuevo y limpio, sin bases de datos, roles ni usuarios. Genere éste ejecutando lo siguiente:
service postgresql initdb
- Cambie al usuario postgres:
su -l postgres
- Configure de nuevo los archivos /var/lib/pgsql/data/pg_hba.conf y /var/lib/pgsql/data/postgresql.conf de acuerdo a lo que tengan /var/lib/pgsql/data-9.1/pg_hba.conf y /var/lib/pgsql/data-9.1/postgresql.conf. Utilice diff para determinar qué cambios hay que realizar. Ejemplo:
Por lo general sólo es necesario modificar el nuevo archivo /var/lib/pgsql/data/pg_hba.conf para definir password como el método de autenticación.diff /var/lib/pgsql/data-9.1/pg_hba.conf /var/lib/pgsql/data/pg_hba.conf
diff /var/lib/pgsql/data-9.1/postgresql.conf /var/lib/pgsql/data/postgresql.conf - Edite los archivos /var/lib/pgsql/data-9.1/pg_hba.conf y /var/lib/pgsql/data/pg_hba.conf:
vi /var/lib/pgsql/data-9.1/pg_hba.conf
vi /var/lib/pgsql/data/pg_hba.conf - Mientras se hace la actualización, cambie el método para local a trust en ambos archivos:
local all all trust
- Salga del editor de texto.
- Ejecute pg_upgrade del siguiente modo:
pg_upgrade -d /var/lib/pgsql/data-9.1 -D /var/lib/pgsql/data -b /usr/lib64/pgsql/postgresql-9.1/bin -B /usr/bin
- La salida debe ser similar a la siguiente:
Performing Consistency Checks
-----------------------------
Checking current, bin, and data directories ok
Checking cluster versions ok
Checking database user is a superuser ok
Checking for prepared transactions ok
Checking for reg* system oid user data types ok
Checking for contrib/isn with bigint-passing mismatch ok
Creating catalog dump ok
Checking for presence of required libraries ok
Checking database user is a superuser ok
Checking for prepared transactions ok
| If pg_upgrade fails after this point, you must
| re-initdb the new cluster before continuing.
| You will also need to remove the ".old" suffix
| from /var/lib/pgsql/data-9.0/global/pg_control.old.
Performing Upgrade
------------------
Adding ".old" suffix to old global/pg_control ok
Analyzing all rows in the new cluster ok
Freezing all rows on the new cluster ok
Deleting new commit clogs ok
Copying old commit clogs to new server ok
Setting next transaction id for new cluster ok
Resetting WAL archives ok
Setting frozenxid counters in new cluster ok
Creating databases in the new cluster ok
Adding support functions to new cluster ok
Restoring database schema to new cluster ok
Removing support functions from new cluster ok
Restoring user relation files
ok
Setting next oid for new cluster ok
Creating script to delete old cluster ok
Upgrade complete
----------------
| Optimizer statistics are not transferred by pg_upgrade
| so consider running:
| vacuumdb --all --analyze-only
| on the newly-upgraded cluster.
| Running this script will delete the old cluster's data files:
| /var/lib/pgsql/delete_old_cluster.sh - Si lo anterior tuvo éxito, edite el archivo /var/lib/pgsql/data/pg_hba.conf:
vi /var/lib/pgsql/data/pg_hba.conf
- Cambie de vuelta el método para local de trust a password:
local all all password
- Regrese como root:
exit
- Inicie de nuevo el servicio:
service postgresql start
- Ingrese al intérprete de PosdgreSQL (psql) para establecer conexión con el servidor de bases de datos y para validar las credenciales de acceso del usuario postgres. Ejecute lo siguiente:
psql -Upostgres -W
- Verifique que todas las bases de datos, roles y usuarios están presentes.
- Salga del intérprete de PostgreSQL.
- Elimine el directorio de datos de PostgreSQL 9.1:
sh /var/lib/pgsql/delete_old_cluster.sh
- Cambie de nuevo al usuario postgres:
su -l postgres
- El procedimiento con pg_upgrade omite actualizar las estadísticas del optimizador. Ejecute lo siguiente para realizar dicho procedimiento:
vacuumdb --all --analyze-only
- Cierre la sesión del usuario postgres al terminar el procedimiento:
exit
- Inicie de nuevo Apache y otras aplicaciones o servicios que utilizan PostgreSQL.
- ¡Felicidades! Usted ha actualizado exitosamente a PostgreSQL 9.2.
Los siguientes comentarios son de la persona que los haya enviado. Este sitio no se hace responsable de las opiniones expresadas por los participantes en los foros y secciones de comentarios, y el hecho de publicar las mismas no significa que esté de acuerdo con ellas.