Join us Sept 17 at .local NYC! Use code WEB50 to save 50% on tickets. Learn more >
MongoDB Jokes
Docs Menu
Docs Home
/ /

FAQ: Connection String Options

Atlas provides multiple connection strings. These strings allow you to connect to your clusters from both public and private contexts. Atlas always assigns clusters unique connections strings so that no two clusters share hostnames or connection strings across Atlas.

The structure of the connection string's URI indicates the string's type. If you have created a peering connection or private endpoint, Atlas displays more than one of these options for your use.

To connect to Atlas, point your applications to a URI to communicate with a cluster. Atlas creates clusters with more than one node or host. Each node has its own hostname that resolves to an IP address. The URI, known as a connection string, to which Atlas connects might have more than one hostname. Configure Atlas to accept connections to the cluster hosts from allowed IP addresses.

Atlas secures connections from public IP address through authentication and TLS. If you want to connect to private IP addresses, you can use:

  • AWS and GCP VPC Peering

  • Azure VNet Peering

  • AWS PrivateLink and Azure Private Link

These features all manage communication over internal IP addresses within secure networks.

Atlas provides more than one connection string when using secure networks. Each network offers a string that resolves to different IP addresses.

All clusters have a standard connection string. This resolves to the cluster's:

  • Public IP addresses for Internet connections and

  • VPC private IP addresses for AWS clusters when resolved from a peered VPC.

Use this string for applications connecting over the Internet or connecting to peered clusters in AWS.

Clusters with peered networks have a Private IP for Peering connection string. This string resolves to IP addresses available to:

  • Peered networks in Azure or Google Cloud

  • AWS peered clusters with a custom DNS service.

Use this connection string with applications connecting:

  • Within an Azure or Google Cloud peered network

  • To AWS clusters when using AWS with custom DNS service.

AWS or Azure clusters in regions with private endpoints configured have one or more connection strings. Each string resolves to the private IP address of a network interface in your VPC or VNet that connects directly to a load balancer in the Atlas VPC or VNet. Use these connection strings with applications connecting with private endpoints.

Before 31 March 2020, you were required to enable peering-only mode to connect to databases on peer networked Azure or Google Cloud clusters. This mode:

  • Affected global DNS resolution and

  • Limited any database connections outside the peered network.

Multiple horizons lifts these restrictions and unlocks the following additional features:

To leverage multiple horizons, complete the following tasks:

Note

You can keep connecting to your clusters using existing peering-enabled connection strings at this time. Peering-Only mode prevents access to the improved functionality and reduced limitations of multiple horizons. To use the new features and remove the legacy limitations, MongoDB requires that you use the new connection strings.

Yes.

Change your applications to connect using the Private IP for Peering connection string. This change allows your applications to connect from peered networks using the UI or API.

To expand into more regions, disable Peering-Only mode on existing Azure clusters first.

To disable Peering-Only mode using the:

1
  1. If it's not already displayed, select the organization that contains your desired project from the Organizations menu in the navigation bar.

  2. If it's not already displayed, select your desired project from the Projects menu in the navigation bar.

  3. In the sidebar, click Clusters under the Database heading.

The Clusters page displays.

2

Change any URLs in your applications that use your Atlas clusters to use Private IP for Peering connection strings.

3
  1. If it's not already displayed, select the organization that contains your desired project from the Organizations menu in the navigation bar.

  2. If it's not already displayed, select your desired project from the Projects menu in the navigation bar.

  3. In the sidebar, click Project Settings.

The Project Settings page displays.

4

Toggle Connect via Peering Only (GCP and Azure) to Off.

1

Call the get all API endpoint to return all clusters and their MongoDB versions:

Example

curl --user "{PUBLIC-KEY}:{PRIVATE-KEY}" --digest \
--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"

If successful, the response should include:

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

Change any URLs in your applications that use your Atlas clusters to use Private IP for Peering connection strings.

3

Call the API endpoint to Disable Private IP Mode.

Example

Using curl, you would invoke this command:

curl --user "{PUBLIC-KEY}:{PRIVATE-KEY}" --digest \
--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
}'

Change {GROUP-ID} to the Project ID of your project.

If successful, the response displays:

1{
2 "enabled" : false
3}

Before 31 March 2020, applications deployed within AWS using custom DNS services and VPC-peered with Atlas couldn't connect over private IP addresses:

  • Custom DNS resolved to public IP addresses.

  • AWS internal DNS resolved to private IP addresses.

Applications deployed with custom DNS services in AWS should use Private IP for Peering connection strings.

To show these strings:

1
  1. If it's not already displayed, select the organization that contains your desired project from the Organizations menu in the navigation bar.

  2. If it's not already displayed, select your desired project from the Projects menu in the navigation bar.

  3. In the sidebar, click Project Settings.

The Project Settings page displays.

2
  1. Toggle Using Custom DNS on AWS with VPC Peering to On.

  2. View the connect modal for your AWS cluster.

  3. Select the Private IP for Peering connection string.

Standard connection strings follow this format:

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

The dot before ab123 matters. URIs using this format resolve to public IP addresses except when connecting from inside AWS with VPC-peering configured.

Important

This format changes one character from the Legacy Connection Strings: a hyphen (-) after the cluster name becomes a period (.).

For example, this legacy connection string:

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

is written as this standard connection string:

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

For new clusters, replica sets and shards don't derive their name from the name of the cluster. The new names use a six alphanumeric character ID.

Private connection strings follow this format:

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

The -pri before ab123 matters. URIs using this format resolve to private IP addresses reachable within the peered network. If you configure network peering for your cluster, you must use the new hostname when you connect to your cluster to utilize the peering.

Important

In new clusters, replica sets and shards don't derive their name from the name of the cluster. The new names use a six alphanumeric character ID.

AWS PrivateLink connection strings follow this format:

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

If you enable the regionalized private endpoint setting, AWS PrivateLink connection strings follow this format:

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

URIs using this format can be reachable via the AWS VPC where someone configured PrivateLink, though access can be transitive from other VPCs peered in turn.

Azure Private Link connection strings follow this format:

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

If you enable the regionalized private endpoint setting, Azure Private Link connection strings follow this format:

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

URIs using this format can be reachable via the Azure VNet where someone configured Private Link, though access can be transitive from other VNets peered in turn.

Before 31 March 2020, you wrote Atlas connection strings as follows:

AWS

foo-shard-00-00-ab123.mongodb.net
foo-ab123.mongodb.net

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

If you enabled Private Only mode, these hostnames resolve to peered network IP addresses. If you disabled that mode, hostnames resolve to public IP addresses.

If your application uses a legacy connection string in Peering Only mode, switch to Private IP for Peering connection strings.

Atlas can generate an optimized SRV connection string for sharded clusters using the load balancers from your private endpoint service. When you use an optimized connection string, Atlas limits the number of connections per mongos between your application and your sharded cluster. The limited connections per mongos improve performance during spikes in connection counts.

To use an optimized connection string, you must meet all of the following criteria:

Note

If your cluster meets the criteria for optimized SRV strings, Atlas generates an Optimized SRV Connection string for you. If your cluster ever had legacy connection strings, Atlas maintains those strings indefinitely and includes a Legacy SRV Connection string when you select the Private Endpoint connection type. Consider switching to the Optimized SRV Connection for optimal performance and update your connection string wherever you use it.

If you create the cluster and enable private endpoints after Atlas released this feature, Atlas displays the optimized connection string by default when you select the Private Endpoint connection type. You can identify an optimized connection string by the addition of lb to the connection string as shown in the following example:

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

To disable optimized connection strings for clusters that don't have the Legacy SRV Connection option, contact support.

Warning

Converting to a Multi-Region Cluster

If you convert your single-region sharded cluster to a multi-region cluster without enabling regionalized private endpoints, you cannot continue to use the optimized connection string. Before converting your cluster, update your connection string to the Legacy SRV Connection string described in the preceding note.

To learn how to connect using a driver and an optimized connection string, select the Private Endpoint Connection tab in the Connect Your Application procedure.

To learn how to connect using Compass and an optimized connection string, select the Private Endpoint Connection tab in the Connect to your Cluster procedure.

To learn how to connect using mongosh and an optimized connection string, select the Private Endpoint Connection tab in the Connect to your Cluster procedure.

If you have a legacy connection string and you want to change cloud providers, your connection string must include .gcp or .azure and you want to do one of the following:

  • Move to Google Cloud or Azure

  • Move off of Google Cloud or Azure

    Note

    Either operation may change your connection string. In the Atlas UI, click Connect on your cluster after the upgrade completes for an updated connection string.

It depends on the following:

  • which cloud provider your current cluster uses

  • when you created the cluster

If you created your cluster before multi-cloud clusters were introduced on November 3, 2020, and your cluster runs on Google Cloud or Azure:

  1. In Atlas, go to the Clusters page for your project.

    1. If it's not already displayed, select the organization that contains your desired project from the Organizations menu in the navigation bar.

    2. If it's not already displayed, select your desired project from the Projects menu in the navigation bar.

    3. In the sidebar, click Clusters under the Database heading.

      The Clusters page displays.

  2. Open the cluster builder.

  3. Edit the cluster.

  4. Add read-only nodes from your target cloud provider.

    Note

    If you are using legacy backups, keep one node in your current cloud provider, and move the rest to your target cloud provider.

  5. Review and submit the changes.

  6. Copy the resulting comma-delimited URI connection string.

  7. Replace the connection string in your application with this new standard connection string.

    This allows your application to connect to nodes from multiple cloud providers.

  8. Restart your application.

  9. Make sure that your application can connect to Atlas.

  10. After the first change completes, reconfigure your cluster:

    • Remove all electable nodes using the original cloud provider.

    • Remove the read-only nodes for the target cloud provider.

    • Add the same number of electable nodes using the target cloud provider.

    Note

    If you are using legacy backups, wait until new backups are taken, then move the remaining node to your target cloud provider.

  11. Review and submit the changes.

  12. Copy the resulting comma-delimited URI connection string.

  13. Replace the URI connection string in your application with this new URI connection string.

  14. Restart your application.

  15. Make sure that your application can connect to Atlas.

Your connection string doesn't change and you don't experience cluster downtime if any of the following is true:

  • Your cluster runs on AWS.

  • Your cluster runs on any cloud provider but was created after November 2, 2020.

To change the cloud provider for your cluster:

  1. In Atlas, go to the Clusters page for your project.

    1. If it's not already displayed, select the organization that contains your desired project from the Organizations menu in the navigation bar.

    2. If it's not already displayed, select your desired project from the Projects menu in the navigation bar.

    3. In the sidebar, click Clusters under the Database heading.

      The Clusters page displays.

  2. Open the cluster builder.

  3. Edit the cluster.

  4. Change the cloud provider.

  5. Review and submit the changes.

Back

FAQ: Billing