Realiza una recuperación de un momento determinado (PITR)

Puedes usar la recuperación de un momento determinado (PITR) para restablecer tus instancias principales de Cloud SQL, ya sea que la instancia esté activa o se haya borrado. La PITR te permite restablecer la instancia a un momento específico. En el caso de una instancia borrada, puedes restablecerla a un momento específico en una instancia nueva o existente.

Cloud SQL proporciona las siguientes opciones para restablecer tu instancia con la PITR:

Para realizar una PITR en una instancia no disponible o borrada, deberás encontrar la hora de recuperación más reciente y más antigua.

Realiza una PITR

Console

  1. En la Google Cloud consola, ve a la página Instancias de Cloud SQL.

    Ir a Instancias de Cloud SQL

  2. Abre el menú de más acciones Ícono de más acciones. para la instancia que deseas recuperar y haz clic en Crear clonación.
  3. De manera opcional, en la página Crear una clonación, actualiza el ID de la clonación nueva.
  4. Selecciona Clonar desde un momento anterior.
  5. Ingresa un tiempo de PITR.
  6. Haz clic en Crear clon.

gcloud

Crea un clon con PITR.

Reemplaza lo siguiente:

  • SOURCE_INSTANCE_NAME: Es el nombre de la instancia desde la que restableces.
  • NEW_INSTANCE_NAME: Es el nombre para el clon.
  • TIMESTAMP: Es la zona horaria UTC para la instancia de origen en formato RFC 3339. Por ejemplo, 2012-11-15T16:19:00.094Z.
gcloud sql instances clone SOURCE_INSTANCE_NAME \
NEW_INSTANCE_NAME \
--point-in-time 'TIMESTAMP'

REST v1

Antes de usar cualquiera de los datos de solicitud a continuación, realiza los siguientes reemplazos:

  • project-id: El ID del proyecto
  • target-instance-id: El ID de la instancia de destino
  • source-instance-id: El ID de la instancia de origen
  • restore-timestamp El momento al que se restablecerá

Método HTTP y URL:

POST https://sqladmin.googleapis.com/v1/projects/project-id/instances/source-instance-id/clone

Cuerpo JSON de la solicitud:

{
  "cloneContext":
  {
    "kind": "sql#cloneContext",
    "destinationInstanceName": "target-instance-id",
    "pointInTime": "restore-timestamp"
  }
}

Para enviar tu solicitud, expande una de estas opciones:

Deberías recibir una respuesta JSON similar a la que se muestra a continuación:

REST v1beta4

Antes de usar cualquiera de los datos de solicitud a continuación, realiza los siguientes reemplazos:

  • project-id: El ID del proyecto
  • target-instance-id: El ID de la instancia de destino
  • source-instance-id: El ID de la instancia de origen
  • restore-timestamp El momento al que se restablecerá

Método HTTP y URL:

POST https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/source-instance-id/clone

Cuerpo JSON de la solicitud:

{
  "cloneContext":
  {
    "kind": "sql#cloneContext",
    "destinationInstanceName": "target-instance-id",
    "pointInTime": "restore-timestamp"
  }
}

Para enviar tu solicitud, expande una de estas opciones:

Deberías recibir una respuesta JSON similar a la que se muestra a continuación:

Realiza una PITR con la backup vault

Si tu instancia de Cloud SQL está habilitada para usar copias de seguridad mejoradas, puedes realizar la recuperación de un momento determinado de tu instancia con la bóveda de copias de seguridad.

Console

  1. En la Google Cloud consola, ve a la página Instancias de Cloud SQL.

    Ir a Instancias de Cloud SQL

  2. Abre el menú de más acciones Ícono de más acciones para la instancia que deseas recuperar y haz clic en Crear clonación.

  3. Selecciona Clonar desde un momento anterior.

  4. Ingresa un tiempo de PITR.

  5. Haz clic en Crear clon.

gcloud

Para realizar una PITR en una instancia desde la bóveda de copias de seguridad, deberás encontrar el data-source de la copia de seguridad más cercana a la hora en la que deseas realizar la PITR. Para encontrar la copia de seguridad, consulta Cómo enumerar todas las copias de seguridad en la bóveda de copias de seguridad de una instancia. Una vez que hayas identificado la copia de seguridad, ejecuta el siguiente comando para realizar la PITR:

gcloud sql instances point-in-time-restore DATA_SOURCE
PITR_TIMESTAMP
--project=TARGET_PROJECT

Reemplaza lo siguiente:

  • DATA_SOURCE: Es la ruta de acceso del data-source de la copia de seguridad más cercana a la marca de tiempo de la PITR a la que deseas recuperar.
  • PITR_TIMESTAMP: Es la marca de tiempo UTC del registro de PITR de la instancia de origen a la que deseas restablecer tu instancia, en formato RFC 3339. Por ejemplo, 2012-11-15T16:19:00.094Z.
  • TARGET_PROJECT: Es el ID del proyecto de tu instancia de Cloud SQL.

REST v1

REST v1beta4

Realiza PITR en una instancia no disponible

Console

Es posible que desees recuperar una instancia que no está disponible en una zona diferente debido a los siguientes motivos:

  • No se puede acceder a la zona en la que se configuró la instancia. Esta instancia tiene el estado FAILED.
  • La instancia está en mantenimiento. Esta instancia tiene el estado MAINTENANCE.

Para recuperar una instancia que no está disponible, completa los siguientes pasos:

  1. En la Google Cloud consola, ve a la página Instancias de Cloud SQL.

    Ir a Instancias de Cloud SQL

  2. Encuentra la fila de la instancia para clonar.
  3. En la columna Acciones, haz clic en el menú Más acciones .
  4. Haz clic en Crear clon.
  5. En la página Crear una clonación, completa las siguientes acciones:
    1. En el campo ID de instancia, actualiza el ID de instancia, si es necesario.
    2. Selecciona Clonar desde un momento anterior.
    3. En el campo Momento determinado, selecciona una fecha y una hora a partir de las cuales deseas clonar los datos. Esto recupera el estado de la instancia desde ese momento.
    4. Haz clic en Crear clon.
  6. Mientras se inicializa el clon, vuelves a la página de la lista de instancias.

gcloud

Es posible que desees recuperar una instancia que no está disponible en una zona diferente porque no se puede acceder a la zona en la que se configuró la instancia.

gcloud sql instances clone SOURCE_INSTANCE_NAME TARGET_INSTANCE_NAME \
--point-in-time DATE_AND_TIME_STAMP \
--preferred-zone ZONE_NAME \
--preferred-secondary-zone SECONDARY_ZONE_NAME

La cuenta de servicio o usuario que ejecuta el comando gcloud sql instances clone debe tener el permiso cloudsql.instances.clone. Si quieres obtener más información sobre los permisos necesarios para ejecutar comandos de gcloud CLI, consulta Permisos de Cloud SQL.

REST v1

Es posible que desees recuperar una instancia que no está disponible en una zona diferente porque no se puede acceder a la zona en la que se configuró la instancia.

Antes de usar cualquiera de los datos de solicitud a continuación, realiza los siguientes reemplazos:

  • PROJECT_ID: El ID del proyecto.
  • SOURCE_INSTANCE_NAME: el nombre de la instancia de origen.
  • TARGET_INSTANCE_NAME: es el nombre de la instancia de destino (clonada).
  • DATE_AND_TIME_STAMP: Una marca de fecha y hora para la instancia de origen en laZona horaria UTC y enRFC 3339 formato (por ejemplo,
    2012-11-15T16:19:00.094Z).
  • ZONE_NAME: Opcional Es el nombre de la zona principal de la instancia de destino. Esto se usa para especificar una zona primaria de la instancia de Cloud SQL que deseas clonar. En una instancia regional, esta zona reemplaza la zona principal, pero la zona secundaria sigue siendo la misma.
  • SECONDARY_ZONE_NAME: Opcional Es el nombre de la zona secundaria para la instancia de destino. Esto se usa para especificar una zona secundaria diferente de la instancia de Cloud SQL que deseas clonar.

Método HTTP y URL:

POST https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/SOURCE_INSTANCE_NAME/clone

Cuerpo JSON de la solicitud:

{
  "cloneContext":
  {
    "destinationInstanceName": "TARGET_INSTANCE_NAME",
    "pointInTime": "DATE_AND_TIME_STAMP",
    "preferredZone": "ZONE_NAME",
    "preferredSecondaryZone": "SECONDARY_ZONE_NAME"
  }
}

Para enviar tu solicitud, expande una de estas opciones:

Deberías recibir una respuesta JSON similar a la que se muestra a continuación:

La cuenta de servicio o usuario que usa el método de API instances.clone debe tener el permiso cloudsql.instances.clone. Si deseas obtener más información sobre los permisos necesarios para usar los métodos de API, consulta Permisos de Cloud SQL.

REST v1beta4

Es posible que desees recuperar una instancia que no está disponible en una zona diferente porque no se puede acceder a la zona en la que se configuró la instancia.

Antes de usar cualquiera de los datos de solicitud a continuación, realiza los siguientes reemplazos:

  • PROJECT_ID: El ID del proyecto.
  • SOURCE_INSTANCE_NAME: el nombre de la instancia de origen.
  • TARGET_INSTANCE_NAME: es el nombre de la instancia de destino (clonada).
  • DATE_AND_TIME_STAMP: una marca de fecha y hora para la instancia de origen en la zona horaria de UTC y en el formato RFC 3339 (por ejemplo,
    2012-11-15T16:19:00.094Z).
  • ZONE_NAME: Opcional Es el nombre de la zona principal de la instancia de destino. Esto se usa para especificar una zona primaria diferente de la instancia de Cloud SQL que deseas clonar. En una instancia regional, esta zona reemplaza la zona principal, pero la zona secundaria sigue siendo la misma.
  • SECONDARY_ZONE_NAME: Opcional Es el nombre de la zona secundaria para la instancia de destino. Esto se usa para especificar una zona secundaria diferente de la instancia de Cloud SQL que deseas clonar.

Método HTTP y URL:

POST https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/SOURCE_INSTANCE_NAME/clone

Cuerpo JSON de la solicitud:

{
  "cloneContext":
  {
    "destinationInstanceName": "TARGET_INSTANCE_NAME",
    "pointInTime": "DATE_AND_TIME_STAMP",
    "preferredZone": "ZONE_NAME",
    "preferredSecondaryZone": "SECONDARY_ZONE_NAME"
  }
}

Para enviar tu solicitud, expande una de estas opciones:

Deberías recibir una respuesta JSON similar a la que se muestra a continuación:

La cuenta de servicio o usuario que usa el método de API instances.clone debe tener el permiso cloudsql.instances.clone. Si deseas obtener más información sobre los permisos necesarios para usar los métodos de API, consulta Permisos de Cloud SQL.

Si intentas crear un clon de PITR en un momento posterior a la hora recuperable más reciente, se mostrará el siguiente mensaje de error:

The timestamp for point-in-time recovery is after the latest recovery time of
Timestamp of latest recovery time. Clone the instance with a time
that's earlier than this recovery time.

Realiza PITR en una instancia borrada

Para usar la PITR y restablecer una instancia borrada, necesitarás lo siguiente:

  • La marca de tiempo de PITR (timestamp) a la que deseas restablecer tu instancia
  • El nombre de la instancia de destino
  • La fecha y hora en que se borró la instancia de origen (source-instance-deletion-time)

Solo puedes usar la recuperación a un momento determinado en una instancia borrada con gcloud CLI o la API de Cloud SQL. Para obtener más información, consulta Restablece una instancia borrada con la PITR.

gcloud

Cómo encontrar tu ventana de PITR

Para encontrar el período de PITR de tu instancia borrada, obtén la hora de recuperación más reciente y más antigua de tu instancia. Puedes seleccionar la marca de tiempo de cualquier momento en esta ventana para realizar una PITR.

Cómo encontrar la hora de eliminación de la instancia de origen y los días de retención de registros

Los valores de source-instance-deletion-time y log-retention-days de la instancia borrada se almacenan con las copias de seguridad retenidas de tu instancia después del borrado. Para encontrar estos valores en tu instancia borrada, consulta Cómo enumerar las copias de seguridad conservadas.

Cómo restablecer con una PITR

Para restablecer tu instancia borrada con la PITR, ejecuta el siguiente comando:

gcloud sql instances clone SOURCE_INSTANCE_NAME \
NEW_INSTANCE_NAME \
--point-in-time='PITR_TIMESTAMP' \
--source-instance-deletion-time=SOURCE_INSTANCE_DELETION_TIMESTAMP

Reemplaza lo siguiente:

  • SOURCE_INSTANCE_NAME: Es el nombre de la instancia de origen que deseas restablecer.
  • NEW_INSTANCE_NAME: es el nombre de la instancia nueva.
  • PITR_TIMESTAMP: Es la marca de tiempo UTC del registro de PITR de la instancia de origen a la que deseas restablecer tu instancia, en formato RFC 3339. Por ejemplo, 2012-11-15T16:19:00.094Z.
  • SOURCE_INSTANCE_DELETION_TIMESTAMP: Es la marca de tiempo UTC de la hora en que se borró la instancia de origen, en formato RFC 3339. Por ejemplo, 2012-11-15T16:19:00.094Z.

REST v1

Cómo encontrar tu ventana de PITR

Para encontrar el período de PITR de tu instancia borrada, obtén la hora de recuperación más reciente y más antigua de tu instancia. Puedes seleccionar la marca de tiempo de cualquier momento en esta ventana para realizar una PITR.

Cómo encontrar la hora de eliminación de la instancia de origen y los días de retención de registros

Los valores de source-instance-deletion-time y log-retention-days de la instancia borrada se almacenan con las copias de seguridad retenidas de tu instancia después del borrado. Para encontrar estos valores en tu instancia borrada, consulta Cómo enumerar las copias de seguridad conservadas.

Cómo restablecer con una PITR

Antes de usar cualquiera de los datos de solicitud a continuación, realiza los siguientes reemplazos:

  • project-id: Es el ID del proyecto.
  • target-instance-id: el ID de la instancia de destino
  • source-instance-id: el ID de la instancia de origen
  • source-instance-deletion-time: Es la hora de eliminación de la instancia de origen.
  • restore-timestamp el momento determinado en el que deseas restablecer la instancia

Método HTTP y URL:

POST https://sqladmin.googleapis.com/v1/projects/project-id/instances/source-instance-id/clone

Cuerpo JSON de la solicitud:

{
  "cloneContext":
  {
    "kind": "sql#cloneContext",
    "destinationInstanceName": "target-instance-id",
    "sourceInstanceDeletionTime: "source-instance-deletion-time",
    "pointInTime": "restore-timestamp"
  }
}

Para enviar tu solicitud, expande una de estas opciones:

Deberías recibir una respuesta JSON similar a la que se muestra a continuación:

REST v1beta4

Cómo encontrar tu ventana de PITR

Para encontrar el período de PITR de tu instancia borrada, obtén la hora de recuperación más reciente y más antigua de tu instancia. Puedes seleccionar cualquier marca de tiempo en esta ventana para realizar la PITR.

Cómo encontrar la hora de eliminación de la instancia de origen y los días de retención de registros

Los valores de source-instance-deletion-time y log-retention-days de la instancia borrada se almacenan con las copias de seguridad retenidas de tu instancia después del borrado. Para encontrar estos valores en tu instancia borrada, consulta Cómo enumerar las copias de seguridad conservadas.

Cómo restablecer con la PITR

Antes de usar cualquiera de los datos de solicitud a continuación, realiza los siguientes reemplazos:

  • project-id: Es el ID del proyecto.
  • target-instance-id: el ID de la instancia de destino
  • source-instance-id: el ID de la instancia de origen
  • source-instance-deletion-time: Es la hora de eliminación de la instancia de origen.
  • restore-timestamp el momento determinado en el que deseas restablecer la instancia

Método HTTP y URL:

POST https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/source-instance-id/clone

Cuerpo JSON de la solicitud:

{
  "cloneContext":
  {
    "kind": "sql#cloneContext",
    "destinationInstanceName": "target-instance-id",
    "sourceInstanceDeletionTime: "source-instance-deletion-time",
    "pointInTime": "restore-timestamp"
  }
}

Para enviar tu solicitud, expande una de estas opciones:

Deberías recibir una respuesta JSON similar a la que se muestra a continuación:

Obtén el tiempo de recuperación más temprano y más tardío

Para una instancia disponible, puedes realizar una PITR a cualquier marca de tiempo dentro del período de PITR de la instancia. El período de PITR comienza en el momento de recuperación más temprano y finaliza en el momento de recuperación más reciente. Si la instancia no está disponible y los registros de la instancia se almacenan en Cloud Storage, o si la instancia se borró y tenía habilitada la retención de la PITR, puedes recuperar la hora de recuperación más antigua y más reciente, y realizar la PITR en cualquier marca de tiempo de ese período. En todos los casos, puedes restablecer la instancia en una zona principal o secundaria diferente si proporcionas valores para las zonas preferidas.

gcloud

Instancia no disponible

Para obtener la hora más temprana y más tardía a la que puedes recuperar una instancia de Cloud SQL que no está disponible, ejecuta el siguiente comando:

gcloud sql instances get-latest-recovery-time INSTANCE_NAME

Reemplaza lo siguiente:

  • INSTANCE_NAME: Es el nombre de la instancia para la que deseas encontrar el tiempo de recuperación más reciente.

Instancia borrada

Para obtener la hora más temprana y más tardía a la que puedes recuperar una instancia de Cloud SQL borrada, ejecuta el siguiente comando:

gcloud sql instances get-latest-recovery-time INSTANCE_NAME
--source-instance-deletion-time='SOURCE_INSTANCE_DELETION_TIMESTAMP'

Reemplaza lo siguiente:

  • INSTANCE_NAME: Es el nombre de la instancia para la que deseas encontrar el tiempo de recuperación más reciente.
  • SOURCE_INSTANCE_DELETION_TIMESTAMP: Es la marca de tiempo UTC de la hora en que se borró la instancia de origen, en formato RFC 3339. Por ejemplo, 2012-11-15T16:19:00.094Z.

REST v1

Instancia no disponible

Antes de usar cualquiera de los datos de solicitud a continuación, realiza los siguientes reemplazos:

  • PROJECT_ID: el ID del proyecto
  • INSTANCE_NAME: Es el nombre de la instancia para la que consultas el tiempo de recuperación más reciente.

Método HTTP y URL:

GET https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_NAME/getLatestRecoveryTime

Para enviar tu solicitud, expande una de estas opciones:

Deberías recibir una respuesta JSON similar a la que se muestra a continuación:

{
  "kind": "sql#getLatestRecoveryTime",
  "earliestRecoveryTime": "2023-06-10T17:23:59.648821586Z",
  "latestRecoveryTime": "2023-06-20T17:23:59.648821586Z"
}

Instancia borrada

Antes de usar cualquiera de los datos de solicitud a continuación, realiza los siguientes reemplazos:

  • PROJECT_ID: Es el ID del proyecto.
  • INSTANCE_NAME: Es el nombre de la instancia de origen para la que consultas el tiempo de recuperación más reciente.
  • SOURCE_INSTANCE_DELETION_TIME: Es la fecha y hora en que se borró la instancia de origen.

Método HTTP y URL:

GET https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_NAME/getLatestRecoveryTime

Para enviar tu solicitud, expande una de estas opciones:

Deberías recibir una respuesta JSON similar a la que se muestra a continuación:

{
  "kind": "sql#getLatestRecoveryTime",
  "earliestRecoveryTime": "2023-06-10T17:23:59.648821586Z",
  "latestRecoveryTime": "2023-06-20T17:23:59.648821586Z"
}

REST v1beta4

Instancia no disponible

Antes de usar cualquiera de los datos de solicitud a continuación, realiza los siguientes reemplazos:

  • PROJECT_ID: el ID del proyecto
  • INSTANCE_NAME: Es el nombre de la instancia para la que consultas el tiempo de recuperación más reciente.

Método HTTP y URL:

GET https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_NAME/getLatestRecoveryTime

Para enviar tu solicitud, expande una de estas opciones:

Deberías recibir una respuesta JSON similar a la que se muestra a continuación:

{
  "kind": "sql#getLatestRecoveryTime",
  "earliestRecoveryTime": "2023-06-10T17:23:59.648821586Z",
  "latestRecoveryTime": "2023-06-20T17:23:59.648821586Z"
}

Instancia borrada

Antes de usar cualquiera de los datos de solicitud a continuación, realiza los siguientes reemplazos:

  • PROJECT_ID: Es el ID del proyecto.
  • INSTANCE_NAME: Es el nombre de la instancia de origen para la que consultas el tiempo de recuperación más reciente.
  • SOURCE_INSTANCE_DELETION_TIME: Es la fecha y hora en que se borró la instancia de origen.

Método HTTP y URL:

GET https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_NAME/getLatestRecoveryTime

Para enviar tu solicitud, expande una de estas opciones:

Deberías recibir una respuesta JSON similar a la que se muestra a continuación:

{
  "kind": "sql#getLatestRecoveryTime",
  "earliestRecoveryTime": "2023-06-10T17:23:59.648821586Z",
  "latestRecoveryTime": "2023-06-20T17:23:59.648821586Z"
}

Solucionar problemas

Problema Soluciona problemas

argument --point-in-time: Failed to parse date/time:
Unknown string format: 2021-0928T30:54:03.094;
received: 2021-0928T30:54:03.094Z

O

Invalid value at 'body.clone_context.point_in_time'
(type.googleapis.com/google.protobuf.Timestamp), Field 'pointInTime',
Invalid time format: Failed to parse input,

La marca de tiempo que proporcionaste no es válida.

HTTP Error 400: Successful backup required for carrying out the operation was not found.

O

Successful backup required for carrying out the operation was not found. or Time where no backups can be found.

La marca de tiempo que proporcionaste se debe a una hora en la que no se pudieron encontrar las copias de seguridad o las coordenadas binlog.

¿Qué sigue?