Dado que AlloyDB Omni es compatible con PostgreSQL, los comandos y las técnicas de restauración de datos que se describen en el manual de pgBackRest también se aplican a AlloyDB Omni. En esta página, se muestran ejemplos de comandos relevantes para una selección de tareas de recuperación comunes.
Para obtener más información sobre cómo configurar pgBackRest para que funcione con AlloyDB Omni, consulta Configura pgBackRest para AlloyDB Omni.
Consulta Copia de seguridad y restablecimiento en Kubernetes para obtener información sobre Kubernetes.
Antes de comenzar
Antes de configurar AlloyDB Omni para que funcione con pgBackrest, debes tener AlloyDB Omni instalado y en ejecución en un servidor que controles.
Un servidor de base de datos de destino que ejecute la misma versión principal de AlloyDB Omni que la copia de seguridad que deseas restablecer Para obtener más información sobre la instalación de AlloyDB Omni, consulta Instala AlloyDB Omni.
Un repositorio de copias de seguridad de pgBackRest que contenga al menos una copia de seguridad de la base de datos de AlloyDB Omni de origen.
Espacio libre suficiente en el disco del servidor de destino para contener la base de datos restablecida
Descripción general
Para realizar un restablecimiento de AlloyDB Omni con pgBackRest, ejecuta el comando pgbackrest restore
. Los parámetros que proporcionas al comando varían según tu situación.
En general, ejecutas el comando pgbackrest restore
con marcas que proporcionan la siguiente información:
- Ubicación de tu archivo
pgbackrest.conf
- Nombre del repositorio de copias de seguridad de pgBackRest al que deseas restablecer la copia. Estos repositorios se nombran y definen en el archivo
pgbackrest.conf
. - Ubicación en el sistema de archivos local en la que se escribirán los datos restablecidos.
- Es un identificador de la copia de seguridad o el momento determinado específicos desde los que deseas realizar el restablecimiento.
Cuando ejecutes los comandos pgbackrest restore
en contenedores, recuerda usar las rutas de acceso del sistema de archivos desde el punto de vista del contenedor. Por ejemplo, la ruta de acceso a tu directorio de datos de AlloyDB Omni siempre es /var/lib/postgresql/data
, sin importar su ubicación en el servidor host. Para obtener más información, consulta Una nota sobre las rutas de acceso del sistema de archivos.
Realiza un restablecimiento a un momento determinado
En este ejemplo, se restablecen datos de un repositorio de pgBackRest y se nombra un momento determinado para restablecerlos. Si definiste varios repositorios en el archivo pgbackrest.conf
del entorno de destino, pgBackRest elegirá el repositorio desde el que se realizará la restauración según la disponibilidad, la velocidad esperada y otros factores.
En el ejemplo, se supone lo siguiente:
Tienes un archivo
pgbackrest.conf
ubicado en el nivel superior de tu directorio de datos de AlloyDB Omni de destino. Esto hace que el archivo esté disponible para elpgbackrest
en contenedores como/var/lib/postgresql/data
.Habilitaste las copias de seguridad continuas con tu configuración de pgBackRest.
En el entorno de destino, realiza una restauración de PITR y especifica una marca de tiempo para la restauración:
Docker
docker exec CONTAINER_NAME pgbackrest \ --config-path=/var/lib/postgresql/data \ --stanza=STANZA \ --type=time \ --pg1-path=/var/lib/postgresql/data/data-RESTORED \ --target="TIMESTAMP" \ restore
Reemplaza lo siguiente:
CONTAINER_NAME
: Es el nombre que le asignaste al contenedor de AlloyDB Omni cuando lo instalaste, por ejemplo,my-omni
.STANZA
: Es la estrofa de configuración, definida por el archivopgbackrest.conf
, que se aplicará a esta restauración, por ejemplo,omni
.TIMESTAMP
: Es la fecha y hora a la que se realizará la restauración, por ejemplo,2024-02-22 19:50:00
.
Podman
podman exec CONTAINER_NAME pgbackrest \ --config-path=/var/lib/postgresql/data \ --stanza=STANZA \ --type=time \ --pg1-path=/var/lib/postgresql/data/data-RESTORED \ --target="TIMESTAMP" \ restore
Reemplaza lo siguiente:
CONTAINER_NAME
: Es el nombre que le asignaste al contenedor de AlloyDB Omni cuando lo instalaste, por ejemplo,my-omni
.STANZA
: Es la estrofa de configuración, definida por el archivopgbackrest.conf
, que se aplicará a esta restauración, por ejemplo,omni
.TIMESTAMP
: Es la fecha y hora a la que se realizará la restauración, por ejemplo,2024-02-22 19:50:00
.
En el entorno de destino, detén el contenedor con el siguiente comando:
Docker
docker container stop CONTAINER_NAME
Podman
podman container stop CONTAINER_NAME
Cambia el nombre del subdirectorio
data
de tu directorio de datos como medida de seguridad:cd DATA_DIR
sudo mv data data-OLD
Reemplaza
DATA_DIR
por la ruta de acceso del sistema de archivos a tu directorio de datos de AlloyDB Omni.Mueve los datos restablecidos a su lugar y limpia
postgresql.auto.conf
:sudo mv data-RESTORED data
sudo sed -i 's|data-RESTORED|data|' data/postgresql.auto.conf
Inicia el contenedor de AlloyDB Omni con el servidor de la base de datos:
Docker
docker container start CONTAINER_NAME
Podman
podman container start CONTAINER_NAME
Ahora puedes conectarte a tu base de datos con psql
y confirmar que los datos se restablecieron según lo previsto. Si es así, puedes borrar la copia data-OLD
del subdirectorio data
que creaste antes.
Para obtener más información sobre la PITR en pgBackRest, consulta Recuperación de un momento determinado.
Para obtener más información sobre cómo preparar un archivo pgbackrest.conf
para usarlo con AlloyDB Omni, consulta Configura pgBackRest para AlloyDB Omni.
Otras opciones
El comando pgbackrest restore
es muy flexible y cuenta con una variedad de opciones y funciones que puedes controlar pasando diferentes opciones de línea de comandos. Se incluyen las siguientes:
- Limitar la restauración solo a los archivos modificados
- Solo se restablecen las bases de datos seleccionadas.
Para obtener una guía completa sobre cómo realizar restablecimientos en pgBackRest, consulta Restore.