Migrating MongoDB clusters
To migrate your MongoDB database to Yandex StoreDoc, follow these steps: transfer the data, switch the legacy database to read-only mode, transfer the workload over to the Yandex Cloud database cluster.
Using Data Transfer for migration allows you to:
- Migrate your database with zero downtime.
- Migrate from older to newer versions of MongoDB.
- Eliminate the need for an intermediate VM or for exposing your Yandex StoreDoc target cluster to the internet.
For more information, see Problems addressed by Yandex Data Transfer.
To use this migration method, enable internet access to the source cluster.
Required paid resources
- Yandex StoreDoc cluster: Computing resources allocated to hosts along with storage and backup capacity (see Yandex StoreDoc pricing).
- Public IP addresses if public access is enabled for cluster hosts (see Virtual Private Cloud pricing).
- Per transfer: Computing resources used and the number of data rows transferred (see Data Transfer pricing).
Getting started
Create a Yandex StoreDoc target cluster with computing capacity and storage size matching the source database’s environment.
The source and target database names must be the same.
Transferring data
-
Create a source endpoint with the following settings:
-
Database type:
MongoDB. -
Endpoint parameters → Connection settings:
Custom installation.Configure the source cluster connection settings.
Note
Transferring of
Time Seriescollections is not supported, so you should exclude such collections in the endpoint settings. -
-
Create a target endpoint with the following settings:
-
Database type:
MongoDB. -
Endpoint parameters → Connection settings:
Yandex StoreDoc cluster.Specify the target cluster ID.
-
-
Create a transfer of the Snapshot and increment type that will use the new endpoints.
To make large collections (over 1 GB) copy more quickly, enable parallel copy in the transfer settings. Specify two or more workers. The collection will be split into the specified number of parts that will be copied concurrently.
For parallel copy to work, the
_idfields in all documents within the collection must have the same data type. If a transfer detects a type mismatch, the collection will not be split but transferred in a single thread instead. If needed, remove documents with mismatched data types from the collection prior to transfer.Note
If a document with a different data type is added to the collection after the transfer starts, the transfer will migrate it at the replication stage after parallel copying. However, when reactivated, the transfer will not be able to split the collection into parts, since the requirement for the same
_idfield type in all documents of the collection will not be met. -
Wait for the transfer status to change to Replicating.
-
Switch the source cluster to "read-only" mode and move the workload to the target cluster.
-
On the transfer monitoring page, wait until the Maximum data transfer delay value drops to zero. This means that all changes made in the source cluster after the initial data copy have been transferred to the target cluster.
-
Deactivate the transfer and wait for its status to change to Stopped.
For more information about transfer statuses, see Transfer lifecycle.
See also
For other migration methods, see this Yandex StoreDoc guide.