Tutorial: Migración de MongoDB a Azure Cosmos DB for MongoDB RU en línea mediante Azure Database Migration Service.
SE APLICA A: MongoDB
Importante
Las migraciones a los núcleos virtuales de Azure Cosmos DB for MongoDB se pueden realizar mediante la extensión de migración de MongoDB para Azure Data Studio. Esta extensión aprovecha Azure Database Migration Service en segundo plano. Tenga en cuenta que las migraciones al núcleo virtual de Azure Cosmos DB para MongoDB no se pueden realizar mediante Database Migration Service en Azure Portal.
Esta guía de migración de MongoDB forma parte de la serie sobre la migración de MongoDB. Los pasos críticos de la migración de MongoDB son la migración previa, la migración y la migración posterior.
Introducción a la migración de datos en línea de MongoDB a Azure Cosmos DB mediante DMS
Puede usar Azure Database Migration Service para realizar una migración en línea (tiempo de inactividad mínimo) de las bases de datos desde una instancia local o en la nube de MongoDB a Azure Cosmos DB for MongoDB.
En este tutorial se muestran los pasos asociados al uso de Azure Database Migration Service para migrar datos de MongoDB a Azure Cosmos DB:
- Crear una instancia de Azure Database Migration Service.
- Cree un proyecto de migración.
- Especifique el origen.
- Especifique el destino.
- Realice la asignación a las bases de datos de destino.
- Ejecutar la migración.
- Supervisar la migración
- Compruebe los datos en Azure Cosmos DB.
- Complete la migración cuando esté listo.
En este tutorial, migrará un conjunto de datos de MongoDB hospedado en una máquina virtual de Azure a Azure Cosmos DB for MongoDB con un tiempo de inactividad mínimo mediante Azure Database Migration Service. Si aún no tiene un origen de MongoDB configurado, consulte Instalación y configuración de MongoDB en una máquina virtual Windows en Azure.
El uso de Azure Database Migration Service para realizar una migración en línea requiere la creación de una instancia basada en el plan de tarifa Premium.
Importante
Para disfrutar de una experiencia de migración óptima, Microsoft recomienda crear una instancia de Azure Database Migration Service en la misma región de Azure que la base de datos de destino. Si los datos se transfieren entre diferentes regiones o ubicaciones geográficas, el proceso de migración puede verse afectado.
Sugerencia
En Azure Database Migration Service, puede migrar las bases de datos sin conexión o mientras están en línea. Con una migración sin conexión, el tiempo de inactividad de la aplicación se inicia cuando comienza la migración. Para limitar el tiempo de inactividad al tiempo necesario para la transición al nuevo entorno cuando finalice la migración, use una migración en línea. Se recomienda probar una migración sin conexión para determinar si el tiempo de inactividad es aceptable. Si el tiempo de inactividad esperado no es aceptable, realice una migración en línea.
En este artículo se describe una migración en línea desde MongoDB a Azure Cosmos DB for MongoDB. Para realizar una migración sin conexión, vea Tutorial: Migración de MongoDB a Azure Cosmos DB for MongoDB RU sin conexión mediante Azure Database Migration Service.
Requisitos previos
Para completar este tutorial, necesita:
Realizar los pasos previos a la migración como son estimar el rendimiento, elegir una clave de partición y seleccionar la directiva de indexación.
Cree una cuenta de Azure Cosmos DB for MongoDB y asegúrese de que la opción Evitar errores de limitación de velocidad para las operaciones de Azure Cosmos DB for MongoDB está habilitada.
Nota:
DMS no se admite actualmente si va a migrar a una cuenta de Azure Cosmos DB for MongoDB aprovisionada con el modo sin servidor.
Crear una instancia de Microsoft Azure Virtual Network para Azure Database Migration Service con el modelo de implementación de Azure Resource Manager, que proporciona conectividad de sitio a sitio a los servidores de origen local mediante ExpressRoute o VPN.
Durante la configuración de la red virtual, si usa ExpressRoute con emparejamiento de red a Microsoft, agregue los siguientes puntos de conexión de servicio a la subred en la que se aprovisionará el servicio:
- Punto de conexión de base de datos de destino (por ejemplo, punto de conexión de SQL, punto de conexión de Azure Cosmos DB, etc.)
- Punto de conexión de Storage
- Punto de conexión de Service Bus
Esta configuración es necesaria porque Azure Database Migration Service no tiene conexión a Internet.
Asegúrese de que las reglas del grupo de seguridad de red (NSG) de la red virtual no bloquean los siguientes puertos de comunicación: 53, 443, 445, 9354 y 10000-20000. Para más información sobre el filtrado del tráfico con grupos de seguridad de red para redes virtuales, vea el artículo Filtrado del tráfico de red con grupos de seguridad de red.
Abra el Firewall de Windows para permitir que Azure Database Migration Service acceda al servidor MongoDB de origen, que de forma predeterminada es el puerto TCP 27017.
Al usar un dispositivo de firewall delante de las bases de datos de origen, es posible que tenga que agregar reglas de firewall para permitir que Azure Database Migration Service acceda a las bases de datos de origen para la migración.
Configuración de reintentos en el lado servidor de Azure Cosmos DB para una migración eficaz
Los clientes que migren de MongoDB a Azure Cosmos DB se benefician de la gobernanza de recursos, lo que garantiza que se puedan aprovechar al máximo las RU/s de rendimiento aprovisionadas. Azure Cosmos DB puede limitar una solicitud determinada de Data Migration Service en el transcurso de la migración si esa solicitud supera las RU/s aprovisionadas del contenedor; en ese caso, esa solicitud se debe reintentar. Aunque Data Migration Service es capaz de realizar reintentos, el tiempo de ida y vuelta implicado en el salto de red entre este servicio y Azure Cosmos DB afecta al tiempo de respuesta general de la solicitud. Mejorar el tiempo de respuesta de las solicitudes limitadas puede acortar el tiempo total necesario para la migración. La característica de Reintentos del lado servidor de Azure Cosmos DB permite al servicio interceptar los códigos de error de limitación y volver a intentarlo con un tiempo de ida y vuelta inferior, lo que mejora considerablemente los tiempos de respuesta de la solicitud.
Puede encontrar la funcionalidad Reintento en el lado servidor en la hoja Características del portal de Azure Cosmos DB.
Y, si está deshabilitada, se recomienda habilitarla como se muestra a continuación
Registrar el proveedor de recursos
Registre el proveedor de recursos Microsoft.DataMigration antes de crear su primera instancia de Database Migration Service.
Inicie sesión en Azure Portal. Busque y seleccione Suscripciones.
Seleccione la suscripción en la que quiere crear la instancia de Azure Database Migration Service y después seleccione Proveedores de recursos.
Busque la migración y, después, seleccione Registrar para Microsoft.DataMigration.
Creación de una instancia
En Azure Portal, seleccione + Crear un recurso, busque Azure Database Migration Service y, después, seleccione Azure Database Migration Service en la lista desplegable.
En la pantalla Azure Database Migration Service, seleccione Crear.
En la pantalla Crear el servicio de migración, especifique un nombre para el servicio, la suscripción y un grupo de recursos nuevo o existente.
Seleccione la ubicación en la que quiere crear la instancia de Azure Database Migration Service.
Seleccione una red virtual existente o cree una nueva.
La red virtual proporciona a Azure Database Migration Service acceso a la instancia de MongoDB de origen y a la cuenta de Azure Cosmos DB de destino.
Para más información sobre cómo crear una red virtual en Azure Portal, consulte el artículo Creación de una red virtual con Azure Portal.
Seleccione una SKU del plan de tarifa Premium.
Nota:
Las migraciones en línea solo se admiten cuando se usa el nivel Premium. Para más información sobre los costos y planes de tarifa, vea la página de precios.
Seleccione Crear para crear el servicio.
Creación de un proyecto de migración
Después de crear el servicio, búsquelo en Azure Portal, ábralo y cree un proyecto de migración.
En Azure Portal, seleccione Todos los servicios, busque Azure Database Migration Service y, luego, elija Azure Database Migration Services.
En la pantalla Azure Database Migration Services, busque el nombre de la instancia de Azure Database Migration Service que creó y, después, seleccione la instancia.
Como alternativa, puede detectar la instancia de Azure Database Migration Service desde el panel de búsqueda de Azure Portal.
Seleccione + New Migration Project (+ Nuevo proyecto de migración).
En la pantalla Nuevo proyecto de migración, especifique un nombre para el proyecto. En el cuadro de texto Tipo de servidor de origen, seleccione MongoDB, en el cuadro de texto Tipo de servidor de destino, seleccione Azure Cosmos DB for MongoDB y, por último, en Elegir el tipo de actividad, seleccione Migración de datos en línea (versión preliminar).
Seleccione Guardar y, después, Crear y ejecutar una actividad para crear el proyecto y ejecutar la actividad de migración.
Especificación de los detalles de origen
En la pantalla Detalles del origen, especifique los detalles de conexión del servidor de MongoDB de origen.
Importante
Azure Database Migration Service no admite Azure Cosmos DB como origen.
Hay tres modos de conexión a un origen:
Modo estándar, que acepta un nombre de dominio completo o una dirección IP, número de puerto y las credenciales de conexión.
Modo de cadena de conexión, que acepta una cadena de conexión de MongoDB, como se describe en el artículo Connection String URI Format (Formato de identificador URI de cadena de conexión).
Datos de Azure Storage, que acepta un dirección URL de SAS del contenedor de blobs. Seleccione El blob contiene volcados BSON si el contenedor de blobs tiene volcados BSON producidos por la herramienta bsondump de MongoDB y anule su selección si el contenedor contiene archivos JSON.
Si selecciona esta opción, asegúrese de que la cadena de conexión de la cuenta de almacenamiento aparece en el formato:
https://blobnameurl/container?SASKEY
Además, según la información del tipo de volcado de memoria de Azure Storage, tenga en cuenta el siguiente detalle.
En el caso de los volcados de BSON, los datos del contenedor de blobs deben estar en formato bsondump, con el fin de que dichos archivos se coloquen en carpetas que se llamen igual que las bases de datos que contienen en el formato colección.bson. A los archivos de metadatos (si hubiera) se les deben asignar el nombre con el formato colección.metadata.json.
En el caso de los volcados de JSON, los archivos del contenedor de blobs deben colocarse en carpetas que se llamen igual que las bases de datos que contienen. Dentro de cada una de estas carpetas, los archivos de datos se deben colocar en una subcarpeta denominada "data" y se le debe asignar el nombre con el formato colección.json. Los archivos de metadatos (si hubiera) se deben colocar en una subcarpeta denominada "metadata" y se le debe asignar el nombre con el mismo formato, colección.json. Los archivos de metadatos deben estar en el mismo formato que los que genera la herramienta bsondump de MongoDB.
Importante
No se recomienda usar un certificado autofirmado en el servidor de MongoDB. Pero si lo usa, conéctese al servidor con el modo de cadena de conexión y asegúrese de que la cadena de conexión es "".
&sslVerifyCertificate=false
La dirección IP se puede usar en situaciones en las que no es posible la resolución de nombres de DNS.
Seleccione Guardar.
La dirección del servidor de origen debe ser la dirección del principal si el origen es un conjunto de réplicas y el enrutador si el origen es un clúster con particiones de MongoDB. En el caso de un clúster con particiones de MongoDB, Azure Database Migration Service debe ser capaz de conectarse a las particiones individuales en el clúster, lo que podría requerir abrir el firewall en varias máquinas.
Especificación de los detalles de destino
En la pantalla Detalles del destino de la migración, especifique los detalles de conexión de la cuenta de Azure Cosmos DB de destino, que es la cuenta de Azure Cosmos DB for MongoDB aprovisionada previamente a la que va a migrar los datos de MongoDB.
Seleccione Guardar.
Asignación a bases de datos de destino
En la pantalla Map to target databases (Asignar a bases de datos de destino), asigne la base de datos de origen y de destino para la migración.
Si la base de datos de destino contiene el mismo nombre de base de datos que la de origen, Azure Database Migration Service selecciona la base de datos de destino de forma predeterminada.
Si la cadena Crear aparece junto al nombre de la base de datos, indica que Azure Database Migration Service no encontró la base de datos de destino, y el servicio creará la base de datos automáticamente.
En este momento de la migración, si se desea capacidad de proceso para uso compartido en la base de datos, especifique las unidades de solicitud de capacidad de proceso. En Azure Cosmos DB, puede aprovisionar rendimiento a nivel de base de datos o individualmente para cada colección. El rendimiento se mide en unidades de solicitud (RU) en Azure Cosmos DB. Obtenga más información sobre los precios de Azure Cosmos DB.
Seleccione Guardar.
En la pantalla Configuración de colecciones, expanda la lista de colecciones y, a continuación, revise la lista de las colecciones que se van a migrar.
Azure Database Migration Service selecciona automáticamente todas las colecciones existentes en la instancia de MongoDB de origen que no existen en la cuenta de Azure Cosmos DB de destino. Si desea volver a migrar las colecciones que ya incluyen datos, necesita seleccionar explícitamente las colecciones de esta pantalla.
Puede especificar el número de unidades de solicitud que desea que usen las colecciones. En la mayoría de los casos, debería ser suficiente un valor entre 500 (1000 es el mínimo para las colecciones con particiones) y 4000. Azure Database Migration Service sugiere valores predeterminados inteligentes en función del tamaño de la colección.
Realice la migración de base de datos y la colección en paralelo mediante múltiples instancias de Azure Database Migration Service, si es necesario, para acelerar la ejecución.
También puede especificar una clave de partición para aprovechar las ventajas de la creación de particiones en Azure Cosmos DB para una escalabilidad óptima. No olvide revisar los procedimientos recomendados para seleccionar una clave de partición. Si no tiene una clave de partición, siempre puede usar _id como clave de partición para mejorar el rendimiento.
Seleccione Guardar.
En la pantalla Migration summary (Resumen de migración), en el cuadro de texto Nombre de actividad, especifique un nombre para la actividad de migración.
Ejecución de la migración
Seleccione Ejecutar migración.
Aparecerá la ventana de actividad de migración y se mostrará el estado de la actividad.
Supervisión de la migración
En la pantalla de la actividad de migración, seleccione Actualizar para actualizar la vista hasta que el valor de Estado de la migración sea Reproduciendo.
Nota
Puede seleccionar la actividad para obtener los detalles de las métricas de migración a nivel de base de datos y de colección.
Comprobación de los datos en Azure Cosmos DB
Realice cambios en la base de datos de MongoDB de origen.
Conéctese a Azure Cosmos DB para comprobar si los datos se replican desde el servidor de MongoDB de origen.
Completar la migración
Después de que todos los documentos del origen estén disponibles en el destino de Azure Cosmos DB, seleccione Finalizar en el menú contextual de la actividad de migración para completar la migración.
Esta acción finalizará la reproducción de todos los cambios pendientes y completará la migración.
Optimización posterior a la migración
Después de migrar los datos almacenados en la base de datos de MongoDB a Azure Cosmos DB for MongoDB, puede conectarse a Azure Cosmos DB y administrar los datos. También puede realizar otros pasos de optimización posteriores a la migración, como optimizar la directiva de indexación, actualizar el nivel de coherencia predeterminado o configurar la distribución global de la cuenta de Azure Cosmos DB. Para más información, consulte el artículo Optimización posterior a la migración.
Recursos adicionales
¿Intenta planear la capacidad de una migración a Azure Cosmos DB?
- Si lo único que sabe es el número de núcleos virtuales y servidores del clúster de bases de datos existente, consulte la información sobre el cálculo de unidades de solicitud mediante núcleos virtuales o CPU virtuales.
- Si conoce las tasas de solicitudes típicas de la carga de trabajo de la base de datos actual, obtenga información sobre el cálculo de unidades de solicitud mediante la herramienta de planeamiento de capacidad de Azure Cosmos DB.