Respaldar y Restaurar Bases de Datos en PostgreSQL

Estándar

No he podido probar si funciona con la versión 8, yo lo he probado en las versiones 9.x en adelante

Les comparto dos comandos muy utiles para realizar respaldos y posterior restauracion de Bases de Datos en PostgreSQL, para este artículo se supone que tenemos instalado el PostgreSQL 9.6 en la ruta C:\Program Files\PostgreSQL\9.6\ y que se utiliza la ruta C:\respaldos tanto para almacenar como para restaurar los respaldos.

Realizar Respaldo usando pg_dump
Este comando tardara un momento, dependiendo del tamaño actual de la Base de Datos que se esta respaldando, el mismo nos exportara el contenido de la BD llamada midominiodb, accede a la misma utilizando el usuario postgres, por tanto se deben proveer las credenciales al momento de ejecutar el mismo. Al final del proceso, obtenemos el archivo current_backup-midominio.sql en la ruta indicada con anterioridad, el cual contiene los scripts y datos necesarios para una posterior restauracion.

El comando es el siguiente:

Restaurar Base de datos usando psql
Es importante tomar en cuenta que se debe crear una Base de Datos vacía con el mismo nombre midominiodb y asignarla al usuario postgres también al iniciar el proceso las credenciales del usuario asignado serán requeridas. Tomar en cuenta que si la Base de Datos ya existe es muy probable que todo el proceso de restauración FALLE, asi que la recomendación es clara: restaurar sobre una Base de Datos vacía. Los pasos a continuación utilizando pgAdmin versión 4.x:

Primero eliminamos la anterior (no olviden realizar un respaldo utilizando pgdump, por si las dudas), hacemos click derecho en la entrada de la Base de Datos en el servidor que la contiene y seleccionamos Delete/Drop:

Confirmamos

Luego hacemos click derecho sobre la entrada Databases dentro del servidor y seleccionamos Create y luego Database…

Escribimos el nombre en el campo Database, y confirmamos que dentro del campo propietario Owner este configurado nuestro usuario postgres, luego presionamos el boton guardar save

Ahora podemos ejecutar el comando siguiente:

C:\Program Files\PostgreSQL\9.6\bin & psql.exe -U postgres midominiodb < C:\respaldos\current_backup-midominio.sqlEste comando nos restaura la Base de Datos midominiodb a partir del archivo de respaldo current_backup-midominio.sql. Este proceso tarda bastante, especialmente si nuestra base de datos a restaurar tienen información de varios meses de transacciones y operaciones.

Saludos.