Puedes recuperar una transmisión que falló de forma permanente sin tener que crear una nueva. Para ello, especifica la posición desde la que Datastream intenta reanudar la lectura de cambios de la fuente.
Descripción general de la recuperación de transmisiones
Una transmisión en ejecución puede encontrar algunos errores irrecuperables y cambiar su estado a FAILED_PERMANENTLY
. Estos errores impiden que la transmisión siga ejecutándose y pueden causar la pérdida de datos.
Para recuperar una transmisión que falló de forma permanente, configúrala para que ignore el error y siga leyendo los eventos en curso en lugar de volver a crear la transmisión y reabastecer los datos históricos. Para recuperar una transmisión con errores de forma permanente, restablece la replicación para comenzar a leer desde una posición de replicación diferente. Cada tipo de fuente compatible tiene su propia definición de lo que es una posición de replicación:
- En el caso de las fuentes de Oracle, una posición de replicación es un archivo de registro redo en la base de datos y el número de cambio del sistema (SCN) en este archivo.
- En el caso de las fuentes de MySQL, una posición de replicación es el archivo de registro binario (binlog) de la base de datos y la posición en este archivo.
- En el caso de las fuentes de SQL Server, una posición de replicación es el número de secuencia de registro (LSN) en los registros de transacciones o las tablas de cambios.
- En el caso de las fuentes de PostgreSQL (incluida AlloyDB para PostgreSQL), una posición de replicación es el número de secuencia de registro (LSN) en la ranura de replicación. Durante la recuperación, el flujo comienza a leer desde el primer LSN en la ranura de replicación.
Cómo recuperar una transmisión para una fuente de MySQL o Oracle
Para recuperar una transmisión de una fuente de MySQL o Oracle, tienes las siguientes opciones:
Reintentar desde la posición actual (recomendado): Selecciona esta opción para intentar transmitir desde la posición actual, en la que la transmisión falló por última vez. Primero, debes corregir el archivo de registro o recuperarlo desde la copia de seguridad. Esta es la opción recomendada.
Salta la posición actual y transmite desde la siguiente posición disponible: Si faltan uno o más archivos de registro, selecciona esta opción para saltarlos y reanudar la transmisión desde la primera posición en el siguiente archivo disponible. Se perderán los cambios de los archivos de registro faltantes, pero puedes recuperarlos reabasteciendo la base de datos.
Salta la posición actual y transmite desde la posición más reciente: Si faltan uno o más archivos de registro, selecciona esta opción para omitir estos archivos y reanudar la transmisión desde la posición más reciente en el archivo de registro más actualizado. Se perderán los cambios de los archivos de registro faltantes, pero puedes recuperarlos reabasteciendo la base de datos.
Reanudar desde tu posición y archivo de transmisión preferidos: Selecciona esta opción para reanudar la transmisión desde un archivo de registro y una posición de registro específicos. Es posible que algunos cambios se pierdan si la posición del registro especificada no se superpone con la posición del registro perdida o no la sigue de inmediato. Para recuperar estos cambios, realiza un reabastecimiento.
Para recuperar una transmisión con errores permanentes de una fuente de MySQL o Oracle, sigue estos pasos:
Ve a la página Transmisiones en Google Cloud.
Haz clic en Recuperar en la fila con el nombre de la transmisión que deseas recuperar.
Se abrirá el panel Choose a recovery strategy. Selecciona una opción. Si seleccionas Reanudar desde tu posición y archivo de transmisión preferidos, ingresa lo siguiente:
- Para una fuente de MySQL, el nombre del archivo de registro en el campo Nombre de archivo y la posición del registro en el campo Posición Si no especificas la posición, la transmisión se reanuda desde la primera posición del archivo de registro indicado.
- Para una fuente de Oracle: el número de cambio del sistema (SCN) en el campo Número de cambio del sistema (SCN) Este campo es obligatorio.
Haz clic en Aplicar.
Cuando se recupera la transmisión, aparece una marca de tiempo en la columna Recuperada de la página Transmisiones.
Cómo recuperar una transmisión para una fuente de PostgreSQL
Para recuperar un flujo de una fuente de PostgreSQL, debes proporcionar el nombre de la ranura de replicación. El servidor usa esta ranura de replicación para enviar eventos a Datastream. El nombre de la ranura de replicación puede ser el mismo que el de la ranura que se usó para la transmisión fallida o ser diferente:
- Si la nueva ranura de replicación tiene un nombre diferente, proporciona el nombre de la ranura de replicación nueva a Datastream.
Si no proporcionas un nombre de ranura de replicación, Datastream usará el nombre de ranura de replicación especificado en la configuración de origen.
Para obtener más información sobre los intervalos de replicación, consulta Configura una base de datos de PostgreSQL de origen.
Se pierden los eventos de cambio de la fuente que se produjeron entre la pérdida de posición del registro y el primer LSN de la ranura de replicación nueva. Puedes recuperar estos cambios reabasteciendo la base de datos.
Para recuperar una transmisión con errores permanentes de una fuente de PostgreSQL, sigue estos pasos:
Ve a la página Transmisiones en Google Cloud.
Haz clic en Recuperar en la fila con el nombre de la transmisión que deseas recuperar.
Se abrirá el panel Define una nueva ranura de replicación.
En el campo Nombre de la ranura de replicación, proporciona el nombre de una ranura de replicación nueva desde la que se intentará recuperar la transmisión. Si volviste a crear el puerto de replicación con el mismo nombre o deseas volver a usar el puerto que especificaste cuando configuraste tu fuente, puedes dejar este campo vacío.
Haz clic en Aplicar.
Cuando se recupera la transmisión, aparece una marca de tiempo en la columna Recuperada de la página Transmisiones.
También puedes recuperar transmisiones con errores permanentes desde la página Detalles de la transmisión. Para ello, haz clic en Recuperar transmisión cuando veas información detallada sobre tu transmisión.
Cómo recuperar una transmisión para una fuente de SQL Server
Para recuperar una transmisión de una fuente de SQL Server, tienes las siguientes opciones:
Reanudar desde la primera posición disponible: Selecciona esta opción si el registro se truncó o faltan algunos registros en las tablas de cambios, y deseas reanudar desde el primer evento disponible. Se perderán los eventos faltantes, pero puedes recuperarlos mediante un reabastecimiento.
Reanudar la transmisión desde el número de secuencia de registro (LSN) que prefieras: Selecciona esta opción para reanudar la transmisión desde un LSN específico en los registros de transacción o tablas de modificaciones. Es posible que se pierdan algunos eventos si el LSN especificado no se superpone con el último LSN que Datastream pudo recuperar o lo sigue inmediatamente. Puedes recuperar estos eventos reabasteciendo la base de datos.
El LSN en los registros de transacciones y las tablas de cambios contiene 20 caracteres hexadecimales, pero en el caso de los registros de transacciones, está separado por un delimitador. Por ejemplo:
- LSN en los registros de transacciones:
0000123C:0000BA78:0004
- LSN en tablas de cambios:
0000123C0000BA780004
- LSN en los registros de transacciones:
Para recuperar una transmisión con errores permanentes de una fuente de SQL Server, sigue estos pasos:
Ve a la página Transmisiones en Google Cloud.
Haz clic en Recuperar en la fila con el nombre de la transmisión que deseas recuperar.
Se abrirá el panel Choose a recovery strategy. Selecciona una opción.
Haz clic en Aplicar.
Cuando se recupera la transmisión, aparece una marca de tiempo en la columna Recuperada de la página Transmisiones.
Usa la recuperación de flujo para una fuente de MySQL en una situación de conmutación por error manual
Puedes realizar una conmutación por error manual y usar la recuperación de transmisiones para evitar volver a crear tus transmisiones desde cero durante el mantenimiento o una falla de la instancia principal. Por lo general, Datastream no admite conmutaciones por error a réplicas porque rompen la continuidad del registro de binarios, pero puedes seguir estos pasos para recuperar el flujo y asegurarte de que se capturen tus datos de cambios:
- Detén todas las operaciones de escritura en la instancia principal.
- Asegúrate de que la métrica de actualización de datos esté configurada en 0. Esto significa que Datastream capturó todos los cambios y no hay eventos nuevos para leer desde la fuente. Para obtener más información, consulta Cómo supervisar una transmisión.
- Realiza el resguardo a la nueva instancia de base de datos.
- Si es necesario, actualiza el perfil de conexión del flujo a la nueva instancia de la base de datos (por ejemplo, es posible que debas cambiar el nombre de host o la dirección IP de la base de datos). Para obtener más información, consulta Modifica los perfiles de conexión.
- Recupera la transmisión desde una posición específica en la instancia de conmutación por error para garantizar la continuidad de la CDC.
¿Qué sigue?
- Para obtener más información sobre los estados de las transmisiones, consulta Ciclo de vida de las transmisiones.
- Para obtener información sobre cómo ver información sobre tu transmisión, consulta Cómo ver una transmisión.
- Para obtener información sobre cómo supervisar una transmisión, consulta Supervisa una transmisión.
- Para obtener información sobre cómo administrar el reabastecimiento de una transmisión, consulta Administra el reabastecimiento de los objetos de una transmisión.
- Si quieres obtener información para borrar una transmisión existente, consulta Borra una transmisión.