Limitaciones y recomendaciones conocidas

En esta página, se describen las limitaciones conocidas (incluidas las consideraciones especiales para controlar entidades como claves primarias o claves foráneas y activadores), así como las prácticas recomendadas para las migraciones heterogéneas de Oracle con Database Migration Service.

Qué no se migra

  • Los usuarios y los permisos no se migran.
  • Los cambios de esquema que se producen durante un trabajo de migración activo no se migran automáticamente. Si cambias tu esquema durante la migración, primero debes actualizar el lugar de trabajo de conversión con los cambios del esquema y, luego, actualizar los trabajos de migración relevantes. Para obtener más información, consulta Cómo agregar esquemas o tablas actualizados al trabajo de migración.
  • Las declaraciones SAVEPOINT no son compatibles y pueden causar discrepancias de datos en caso de una reversión.
  • Database Migration Service replica los tipos de datos definidos por el usuario, pero solo almacena el tipo de datos base del que derivas tus tipos definidos por el usuario. Por ejemplo, si defines un tipo de datos USERNAME según el tipo de datos VARCHAR2, los datos se almacenan en el destino como VARCHAR.

Base de datos, transacciones y coherencia de los datos

  • La migración es coherente con el tiempo, ya que Database Migration Service no replica cada transacción a medida que ocurre. La migración incorpora datos de varias tablas. El orden en el que se cargan los datos en el destino puede variar, pero se vuelve a alinear con la fuente después de que se detienen las operaciones de escritura en la fuente y se borra el búfer de migración.
  • En el caso de las migraciones heterogéneas de Oracle, Database Migration Service solo puede migrar una base de datos por trabajo de migración.
  • Database Migration Service admite la arquitectura multiusuario de Oracle (CDB/PDB), pero solo puedes migrar una sola base de datos conectable por trabajo de migración.
  • No se replica la seguridad de etiquetas de Oracle (OLS).
  • La base de datos de destino debe tener el mismo nombre que el nombre de usuario que se usa para conectarse a la base de datos.
  • Es posible que las transacciones que se reviertan en tu base de datos de origen durante el proceso de migración sean visibles en el destino de forma temporal (cuando la transacción sea lo suficientemente larga).
  • Database Migration Service no admite la conectividad directa a bases de datos con la función Nombre de acceso de cliente único (SCAN) en entornos de Oracle Real Application Clusters (RAC). Si quieres conocer posibles soluciones para usar la conectividad de la lista de entidades permitidas de IP pública con esos entornos, consulta Cómo solucionar errores de Oracle SCAN.

Codificación de datos

  • Database Migration Service solo admite codificaciones establecidas de UTF8 para la base de datos de destino. No se admiten nombres de esquemas y tablas que incluyan caracteres que no formen parte del conjunto de codificación UTF8.
  • Database Migration Service admite las siguientes codificaciones de conjuntos de caracteres para bases de datos de Oracle:
    • AL16UTF16
    • AL32UTF8
    • IN8ISCII
    • JA16SJIS
    • US7ASCII
    • UTF8
    • WE8ISO8859P1
    • WE8ISO8859P9
    • WE8ISO8859P15
    • WE8MSWIN1252
    • ZHT16BIG5

Tablas, esquemas y otros objetos

  • Durante una migración, no se admiten los cambios en el lenguaje de definición de datos (DDL) en los datos, los esquemas ni los metadatos. Si actualizas tu esquema durante la migración, debes extraer los cambios a tu lugar de trabajo de conversión, convertir el código, limpiar tu destino y volver a ejecutar el trabajo de migración.
  • No se admiten nombres de columnas de tabla que incluyan caracteres distintos de los alfanuméricos o un guion bajo (_).
  • La longitud máxima de los nombres de las tablas o columnas es de 30 caracteres. el servicio de migración de bases de datos no puede replicar tablas que superen este límite ni tablas que contengan columnas cuyos nombres superen este límite.
  • No se admiten las tablas organizadas por índices (IOT).
  • Las tablas temporales globales requieren que la extensión pgtt de PostgreSQL esté instalada y creada en el destino.
  • En el caso de las columnas de tipo BFILE, solo se replicará la ruta de acceso al archivo. No se replicará el contenido del archivo.
  • En el caso de Oracle 11g, no se admiten las tablas que tienen columnas de tipos de datos ANYDATA ni UDT, y no se replicará toda la tabla.
  • No se migran los trabajos programados con dbms_job o dbms_scheduler.
  • Se migran las definiciones de vistas materializadas, pero no sus datos materializados. Después de terminar la migración, actualiza tus vistas materializadas para propagarlas con datos de las tablas migradas.
  • Los valores de secuencia se migran, pero sus valores en la base de datos de origen pueden seguir avanzando antes de que se complete la migración. Después de completar la migración, actualiza los valores de secuencia en la instancia de destino para que coincidan con los de la base de datos de origen.
  • Los trabajos de migración se limitan a 10,000 tablas.
  • Las filas tienen un límite de tamaño de 100 MB. Las filas que superan el límite de 100 MB no se migran y aparecen como errores en el trabajo de migración.
  • Las tablas que se creen después de que se inicie la migración no se migrarán automáticamente. Primero, debes extraer su esquema en el lugar de trabajo de conversión, aplicar definiciones convertidas al destino y actualizar el trabajo de migración.

Limitaciones del tipo de datos

Los siguientes tipos de datos no son compatibles con las migraciones de Oracle:

  • ANYDATA (en Oracle 11g, las tablas con ANYDATA no se admiten y no se replican).
  • BFILE
  • INTERVAL DAY TO SECOND
  • INTERVAL YEAR TO MONTH
  • LONG/LONG RAW
  • SDO_GEOMETRY
  • UDT
  • UROWID
  • XMLTYPE
  • Fechas cero en TIMESTAMP

Consideraciones sobre las claves primarias

Las tablas sin claves primarias no garantizan una replicación coherente. Database Migration Service solo migra tablas que tienen claves primarias. Si tu base de datos de origen incluye tablas que no tienen claves primarias, los lugares de trabajo de conversión de Database Migration Service crean automáticamente las claves primarias faltantes en las tablas de destino cuando conviertes tu código fuente y esquema.

Si usas espacios de trabajo de conversiones heredados, debes crear manualmente restricciones de clave principal en las tablas convertidas de la base de datos de destino antes de iniciar la migración. Para obtener más información, consulta Lugares de trabajo de conversión heredados.

Consideraciones sobre las claves externas y los activadores

Las claves externas y los activadores presentes en tu base de datos de origen pueden generar problemas de integridad de los datos o incluso hacer que falle el trabajo de migración. Puedes evitar estos problemas si omites las claves externas y los activadores mediante la opción REPLICATION para el usuario de migración. Como alternativa, también puedes descartar todas las claves externas y los activadores en la base de datos de destino y volver a crearlos cuando se complete la migración.

Activadores

Los datos que replica Database Migration Service ya incorporan cualquier cambio que realicen los activadores en la base de datos de origen. Si los activadores están habilitados en el destino, pueden volver a activarse y, posiblemente, manipular los datos, lo que genera problemas de integridad o duplicación de datos.

Claves externas

Database Migration Service no replica los datos de forma transaccional, por lo que es posible que las tablas se migren fuera de orden. Si hay claves externas y se migra una tabla secundaria que usa una clave externa antes que su tabla superior, es posible que se produzcan errores de replicación.

Recomendaciones

  • Cuando creas tu base de datos de Cloud SQL de destino, asegúrate de usar suficientes recursos de procesamiento y memoria para cubrir tus necesidades de migración. Recomendamos un tipo de máquina con al menos una CPU de doble núcleo.

    Por ejemplo, si el nombre de tu máquina es db-custom y tiene 2 CPUs y 3, 840 MB de RAM, el formato para el nombre del tipo de máquina es db-custom-2-3840.

  • La base de datos de Cloud SQL de destino se puede escribir durante la migración para permitir que se apliquen los cambios del lenguaje de manipulación de datos (DML) si es necesario. Ten cuidado de no realizar cambios en la configuración de la base de datos ni en las estructuras de las tablas que puedan interrumpir el proceso de migración o afectar la integridad de los datos.

Cuotas

  • Pueden existir hasta 2,000 perfiles de conexión y 1,000 trabajos de migración en un momento determinado. Para liberar espacio, se pueden borrar trabajos de migración (incluso los que están completos) y perfiles de conexión.