Make the MongoDB docs better! We value your opinion. Share your feedback for a chance to win $100.
MongoDB Branding Shape
Click here >
Docs Menu

FAQ: Opciones de cadenas de conexión

Atlas proporciona varias cadenas de conexión. Estas cadenas permiten conectarte a tus clústeres tanto desde contextos públicos como privados. Atlas siempre asigna a los clústeres cadenas de conexión únicas para que ningún clúster comparta nombres de host o cadenas de conexión en Atlas.

La estructura del URI de la cadena de conexión indica el tipo de cadena. Si has creado una conexión de emparejamiento o unos nodos privados, Atlas muestra más de una de estas opciones para tu uso.

Para conectarse a Atlas, dirija sus aplicaciones a un URI para comunicarse con un clúster. Atlas crea clusters con más de un nodo o host. Cada nodo tiene su propio nombre de host que resuelve en una dirección IP. El URI, conocido como cadena de conexión, al que se conecta Atlas puede tener más de un nombre de host. Configura Atlas para aceptar conexiones a los hosts del clúster desde direcciones IP autorizadas.

Atlas asegura las conexiones desde la dirección IP pública mediante autenticación y TLS. Si quieres conectarte a direcciones IP privadas, puedes utilizar:

Estas funcionalidades gestionan la comunicación a través de direcciones IP internas dentro de redes seguras.

Atlas proporciona más de una cadena de conexión cuando se utilizan redes seguras. Cada red ofrece un string que se resuelve en diferentes direcciones IP.

Todos los clústeres tienen una cadena de conexión estándar. Esta se resuelve en el clúster:

  • Direcciones IP públicas para conexiones a Internet y

  • Direcciones IP privadas de VPC para clústeres de AWS cuando se resuelven desde una VPC emparejada.

Utiliza esta string para aplicaciones que se conectan a través de Internet o se conectan a clústeres emparejados en AWS.

Los clústeres con redes emparejadas tienen una cadena de conexión IP privada para emparejamiento. Esta cadena se resuelve en direcciones IP disponibles para:

  • Redes interconectadas en Azure o Google Cloud

  • AWS clústeres emparejados con un servicio personalizado de DNS.

Utiliza esta cadena de conexión con aplicaciones que se conecten:

  • Dentro de una red asociada de Azure o de Google Cloud

  • A los clústeres de AWS cuando se utilice AWS con un servicio DNS personalizado.

Los clústeres de AWS o Azure en regiones con nodos privados configurados tienen una o más cadenas de conexiones. Cada string se resuelve a la dirección IP privada de una interfaz de red en tu VPC o VNet que se conecta directamente a un balanceador de carga en el VPC o VNet de Atlas. Utiliza estas cadenas de conexión con aplicaciones que se conectan mediante nodos privados.

Sí, puedes utilizar una única cadena de conexión SRV para un clúster multiregional con Private Link en MongoDB Atlas. La cadena de conexión SRV se resuelve automáticamente a los nodos adecuados en todas las regiones. Sin embargo, asegúrate de que tu configuración de red permita la conectividad entre regiones a través de nodos privados. Para AWS y Azure, esto implica configurar el emparejamiento entre VPC/VNet entre regiones. Para Google Cloud, necesitas configurar acceso global para Private Service Connect.

Para obtener más información, consulte la documentación sobre nodos privados.

Antes del 31 de marzo de 2020, debías activar el modo solo de emparejamiento para conectarte a bases de datos en redes de permisos Azure o en clústeres de Google Cloud. Este modo:

  • Resolución DNS global y afectada

  • Limitó todas las conexiones de base de datos fuera de la red emparejada.

Horizontes múltiples elimina estas restricciones y desbloquea las siguientes funcionalidades adicionales:

Para aprovechar varios horizontes, completa las siguientes tareas:

Nota

Puede seguir habiendo conexión a los clústeres usando las cadenas de conexión existentes habilitadas para el emparejamiento en este momento. El modo de solo emparejamiento impide el acceso a la funcionalidad mejorada y a las limitaciones reducidas de múltiples horizontes. Para utilizar las nuevas funcionalidades y remover las limitaciones heredadas, MongoDB requiere que se utilicen las nuevas cadenas de conexión.

Sí.

Cambie sus aplicaciones para que se conecten mediante la cadena de conexión IP privada para peering. Este cambio permite que sus aplicaciones se conecten desde redes peering mediante la interfaz de usuario o la API.

Para expandirse a más regiones, primero desactive el modo Solo emparejamiento en los clústeres existentes de Azure.

Para desactivar el modo Solo Emparejamiento utilizando el:

1
  1. Si aún no se muestra, seleccione la organización que contiene su proyecto deseado en el menú Organizations de la barra de navegación.

  2. Si aún no aparece, selecciona el proyecto deseado en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en Clusters en la sección Database.

La página de clústeres se muestra.

2

Cambie cualquier URLen sus aplicaciones que usen sus clústeres Atlas para usar IP privada para cadenas de conexión de peering.

3
  1. Si aún no se muestra, seleccione la organización que contiene su proyecto deseado en el menú Organizations de la barra de navegación.

  2. Si aún no aparece, selecciona el proyecto deseado en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en el icono junto a Project Overview.

La página Configuración del proyecto se muestra.

4

Cambiar Connect via Peering Only (GCP and Azure) a Apagado.

1

Llama al punto final get all API para que devuelva todos los clústeres y sus versiones de MongoDB:

Nota

Este comando curl utiliza un token de acceso de cuenta de servicio (OAuth 2.0) para autenticar en lugar de claves API. Para obtener más información, consulte Introducción a la API de administración de Atlas.

Ejemplo

curl --header "Authorization: Bearer {ACCESS-TOKEN}" \
--header "Accept: application/json" \
--header "Content-Type: application/json" \
--include \
--request GET "https://cloud.mongodb.com/api/atlas/v1.0/groups/{GROUP-ID}/clusters?pretty=true"

Si es exitosa, la respuesta deberá incluir:

{
"results": [{
...
"mongoDBMajorVersion": "6.0",
"mongoDBVersion": "6.0.14",
...
},{
...
"mongoDBMajorVersion": "6.0",
"mongoDBVersion": "6.0.12",
... }
]
}
2

Cambie cualquier URLen sus aplicaciones que usen sus clústeres Atlas para usar IP privada para cadenas de conexión de peering.

3

Llama al endpoint API para Desactivar el modo de IP privada.

Ejemplo

Usando curl, debes invocar este comando:

curl --header "Authorization: Bearer {ACCESS-TOKEN}" \
--header "Accept: application/json" \
--header "Content-Type: application/json" \
--include \
--request PATCH "https://cloud.mongodb.com/api/atlas/v1.0/groups/{GROUP-ID}/privateIpMode?pretty=true" \
--data '
{
"enabled" : false
}'

Cambia {GROUP-ID} al ID del grupo de tu proyecto.

En caso de ser exitosa, la respuesta muestra:

1{
2 "enabled" : false
3}

Antes del 31 de marzo de 2020, las aplicaciones implementadas dentro de AWS que usaban servicios personalizados de DNS y VPC-emparejados con Atlas, no podían conectarse a través de direcciones IP privadas:

  • Los DNS personalizados se resolvieron en direcciones IP públicas.

  • AWS DNS interno se resolvió a direcciones IP privadas.

Las aplicaciones implementadas con servicios DNS personalizados en AWS deben usar IP privada para las cadenas de conexión de peering.

Para mostrar estas cadenas:

1
  1. Si aún no se muestra, seleccione la organización que contiene su proyecto deseado en el menú Organizations de la barra de navegación.

  2. Si aún no aparece, selecciona el proyecto deseado en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en el icono junto a Project Overview.

La página Configuración del proyecto se muestra.

2
  1. Establece Using Custom DNS on AWS with VPC Peering en On.

  2. Visualiza el siguiente connect modal para tu clúster de AWS.

  3. Seleccione la cadena de conexión Private IP for Peering.

Las cadenas de conexión estándar siguen este formato:

mongodb://xyz456-shard-00-00.ab123.mongodb.net:27017
mongodb+srv://xyz456.ab123.mongodb.net

El punto antes de ab123 es importante. Los URIque utilizan este formato se resuelven en direcciones IP públicas, excepto cuando se conectan desde dentro de AWS con VPC-emparejamiento configurado.

Importante

Este formato cambia un carácter de las cadenas de conexión heredadas: un- guion () después del nombre del clúster se convierte en un punto. ().

Por ejemplo, esta cadena de conexión heredada:

mongodb+srv://xyx456-ab123.mongodb.net

se escribe como esta cadena de conexión estándar:

mongodb+srv://xyx456.ab123.mongodb.net

Para nuevos clústeres, los sets de réplicas y particiones no obtienen su nombre del nombre del clúster. Los nuevos nombres utilizan un ID de seis caracteres alfanuméricos.

Las cadenas de conexión privadas siguen este formato:

mongodb://xyx456-shard-00-00-pri.ab123.mongodb.net:27017
mongodb+srv://xyx456-pri.ab123.mongodb.net

El -pri antes del ab123 importa. URIs que utilizan este formato resuelven direcciones IP privadas accesibles dentro de la red emparejada. Si configuras el emparejamiento de red para tu clúster, debes utilizar el nuevo nombre de host cuando te conectes a tu clúster para aprovechar el emparejamiento.

Importante

En los nuevos clústeres, los sets de réplicas y las particiones no derivan su nombre del nombre del clúster. Los nuevos nombres utilizan un ID de seis caracteres alfanuméricos.

Nota

En entornos AWS, la cadena de conexión -pri es opcional, incluso cuando el emparejamiento de red está habilitado. AWS resuelve las direcciones IP privadas del clúster, ya sea que utilices la cadena de conexión privada o estándar.

Las cadenas de conexión de AWS PrivateLink siguen este formato:

mongodb://pl-0-us-east-1a.ab123.mongodb.net:1024
mongodb+srv://pl-0-us-east-1a.ab123.mongodb.net

Si habilita la configuración de punto de enlace privado regionalizado, las cadenas de conexión de AWS PrivateLink siguen este formato:

mongodb://pl-0-us-west-1.ab123.mongodb.net:1024
mongodb+srv://cluster0-pl-0-us-west-1.ab123.mongodb.net

Los URIque usan este formato pueden ser accesibles a través de la AWS VPC donde alguien configuró PrivateLink, aunque el acceso puede ser transitivo desde otras VPCemparejadas a su vez.

Las cadenas de conexión Azure Private Link siguen este formato:

mongodb://pl-0-eastus2.ab123.mongodb.net:1024
mongodb+srv://pl-0-eastus2.ab123.mongodb.net

Si activas la configuración de endpoint privado regionalizado, las cadenas de conexión de Azure Private Link siguen este formato:

mongodb://pl-0-eastus2.ab123.mongodb.net:1024
mongodb+srv://cluster0-pl-0-eastus2.ab123.mongodb.net

Los URIque utilizan este formato pueden ser accesibles a través de la VNet de Azure donde alguien haya configurado Private Link, aunque el acceso puede ser transitivo desde otras VNets emparejadas a su vez.

Antes del 31 de marzo de 2020, las cadenas de conexión de Atlas se escribían de la siguiente manera:

AWS (Servicios Web de Amazon)
foo-shard-00-00-ab123.mongodb.net
foo-ab123.mongodb.net
Azure (Microsoft Azure)
foo-shard-00-00-ab123.azure.mongodb.net
foo-ab123.azure.mongodb.net
Google Cloud
foo-shard-00-00-ab123.gcp.mongodb.net
foo-ab123.gcp.mongodb.net

Si activaste el modo Solo privado, estos nombres de host se resuelven en direcciones IP de red interconectadas. Si desactivas ese modo, los nombres de host se resuelven en direcciones IP públicas.

Si su aplicación utiliza una cadena de conexión heredada en modo de solo intercambio de tráfico, cambie a IP privada para cadenas de conexión de intercambio de tráfico.

Atlas puede generar una cadena de conexión SRV optimizada para clústeres particionados utilizando los balanceadores de carga del servicio de nodos privados. Cuando se usa una cadena de conexión optimizada, Atlas limita el número de conexiones por mongos entre la aplicación y el clúster particionado. Las conexiones limitadas por mongos mejoran el rendimiento durante los picos en el número de conexiones.

Para utilizar una cadena de conexión optimizada, se debe cumplir con todos los criterios siguientes:

Nota

Si tu clúster cumple los criterios para SRV optimizadas, Atlas genera una string Optimized SRV Connection para ti. Si tu clúster alguna vez tuvo cadenas de conexión heredadas, Atlas las mantiene indefinidamente e incluye una string Legacy SRV Connection cuando seleccionas el tipo de conexión Private Endpoint. Considera cambiar al Optimized SRV Connection para un rendimiento óptimo y actualiza tu cadena de conexión dondequiera que la utilices.

Si crea el clúster y habilita los nodos privados después de que Atlas haya lanzado esta funcionalidad, Atlas mostrará la cadena de conexión optimizada por defecto cuando seleccione el tipo de conexión Private Endpoint. Puedes identificar una cadena de conexión optimizada por la adición de lb a la cadena de conexión como se muestra en el siguiente ejemplo:

mongodb+SRV://User1:P@ssword@cluster0-pl-0-lb.oq123.mongodb-dev.net/

Para deshabilitar las cadenas de conexión optimizadas para clústeres que no tienen la opción Legacy SRV Connection, contacte con soporte.

Advertencia

Conversión a un clúster multirregional

Si conviertes un clúster particionado de una sola región a un clúster multiregional sin habilitar los nodos privados regionalizados, no podrás seguir usando la cadena de conexión optimizada. Antes de convertir el clúster, actualiza la cadena de conexión al string Legacy SRV Connection descrito en la nota anterior.

Para aprender cómo conectarse usando un controlador y una cadena de conexión optimizada, selecciona la pestaña Private Endpoint Connection en el procedimiento Conectar a tu aplicación.

Para aprender cómo conectar usando Compass y una cadena de conexión optimizada, selecciona la pestaña Private Endpoint Connection en el procedimiento Conectar a tu clúster.

Para aprender a conectarse usando mongosh y una cadena de conexión optimizada, se debe seleccionar la pestaña Private Endpoint Connection en el procedimiento Conectarse al clúster.

Si tienes una cadena de conexión heredada y quieres cambiar de proveedor de nube, tu cadena de conexión debe incluir .gcp o .azure y deseas realizar una de las siguientes acciones:

  • Muévete a Google Cloud o Azure

  • Salir Google Cloud o Azure

    Nota

    Cualquiera de las dos operaciones puede cambiar la cadena de conexión. En la interfaz de usuario de Atlas, hacer clic en Connect en el clúster una vez finalizada la actualización para obtener una cadena de conexión actualizada.

Depende de lo siguiente:

  • qué proveedor de nube utiliza tu clúster actual

  • cuando creaste el clúster

Si creó su clúster antes de que se introdujeran los clústeres de multi-nube el 3 de noviembre de 2020, y su clúster se ejecuta en Google Cloud o Azure:

  1. En Atlas, se debe ir a la página Clusters del proyecto.

    1. Si aún no se muestra, seleccione la organización que contiene su proyecto deseado en el menú Organizations de la barra de navegación.

    2. Si aún no aparece, selecciona el proyecto deseado en el menú Projects de la barra de navegación.

    3. En la barra lateral, haz clic en Clusters en la sección Database.

      La página de clústeres se muestra.

  2. Abre el generador de clústeres.

  3. Editar el clúster.

  4. Agrega nodos de solo lectura de tu proveedor de nube objetivo.

    Nota

    Si utilizas respaldos heredados, mantén un nodo en tu proveedor de nube actual y traslada el resto a tu proveedor de nube de destino.

  5. Revisa y envía las siguientes modificaciones.

  6. Copie la cadena de conexión URI delimitada por comas resultante.

  7. Reemplace la cadena de conexión en su aplicación con esta nueva cadena de conexión estándar.

    Esto permite que tu aplicación se conecte a nodos desde múltiples proveedores de nube.

  8. Reinicia la aplicación.

  9. Asegúrate de que la aplicación pueda conectarse a Atlas.

  10. Después de que se complete el primer cambio, vuelve a configurar tu clúster:

    • Remover todos los nodos elegibles con el proveedor de nube original.

    • Remueve los nodos de solo lectura para el proveedor de nube objetivo.

    • Agregue la misma cantidad de nodos elegibles usando el proveedor de nube objetivo.

    Nota

    Si está utilizando respaldos heredados, espere hasta que se realicen nuevas copias de seguridad y luego mueva el nodo restante a su proveedor de nube de destino.

  11. Revisa y envía las siguientes modificaciones.

  12. Copie la cadena de conexión URI delimitada por comas resultante.

  13. Sustituye la cadena de conexión URI en la aplicación por esta nueva cadena de conexión URI.

  14. Reinicia la aplicación.

  15. Asegúrate de que la aplicación pueda conectarse a Atlas.

Su cadena de conexión no cambia ni se experimenta tiempo de inactividad del clúster si cualquiera de las siguientes condiciones es verdadera:

  • Tu clúster funciona en AWS.

  • Su clúster se ejecuta en cualquier proveedor de nube, pero se creó después de 2 de noviembre de 2020.

Para cambiar el proveedor de nube de tu clúster:

  1. En Atlas, se debe ir a la página Clusters del proyecto.

    1. Si aún no se muestra, seleccione la organización que contiene su proyecto deseado en el menú Organizations de la barra de navegación.

    2. Si aún no aparece, selecciona el proyecto deseado en el menú Projects de la barra de navegación.

    3. En la barra lateral, haz clic en Clusters en la sección Database.

      La página de clústeres se muestra.

  2. Abre el generador de clústeres.

  3. Editar el clúster.

  4. Cambia el proveedor de nube.

  5. Revisa y envía las siguientes modificaciones.