Docs Menu
Docs Home
/
MongoDB Manual
/

Replica Set Data Synchronization

On this page

  • Initial Sync
  • Replication

To maintain up-to-date copies of the shared data set, secondary members of a replica set sync or replicate data from a source member. MongoDB uses two forms of data synchronization: initial sync to populate new members with the full data set, and replication to apply ongoing changes to the entire data set.

Initial sync copies all the data from the source member of the replica set to a destination member. See Initial Sync Source Selection for more information on source member selection criteria.

You can specify the preferred initial sync source using the initialSyncSourceReadPreference parameter. This parameter can only be specified when starting the mongod.

Starting in MongoDB 5.2, initial syncs can be logical or file copy based.

When you perform a logical initial sync, MongoDB:

  1. Clones all databases except the local database. To clone, the mongod scans every collection in each source member database and inserts all data into its own copies of these collections.

  2. Builds all collection indexes as the documents are copied for each collection.

  3. Pulls newly added oplog records during the data copy. Ensure that the destination member has enough disk space in the local database to temporarily store these oplog records for the duration of this data copy stage.

  4. Applies all changes to the data set. Using the oplog from the source member, the mongod updates its data set to reflect the current state of the replica set.

When the initial sync finishes, the member transitions from STARTUP2 to SECONDARY.

To perform an initial sync, see Resync a Member of a Self-Managed Replica Set.

Available in MongoDB Enterprise only.

File copy based initial sync runs the initial sync process by copying and moving files on the file system. This sync method can be faster than logical initial sync.

Important

File copy based initial sync may cause inaccurate counts

After file copy based initial sync completes, if you run the count() method without a query predicate, the count of documents returned may be inaccurate.

A count method without a query predicate looks like this: db.<collection>.count().

To learn more, see Inaccurate Counts Without Query Predicate.

To enable file copy based initial sync, set the initialSyncMethod parameter to fileCopyBased on the destination member for the initial sync. This parameter can only be set at startup.

File copy based initial sync replaces the local database of the destination member with the local database of the source member when syncing.

  • During a file copy based initial sync:

    • You cannot run backups on either the source member or the destination member.

    • You cannot write to the local database on the destination member.

  • You can only run an initial sync from one source member at a time.

  • When using the encrypted storage engine, MongoDB uses the source member key to encrypt the destination.

You must perform an initial sync on clusters that use the local Non-Volatile Memory Express (NVMe) SSD storage option, including if you're using Atlas auto-scaling. Atlas NVMe clusters auto-scale to the next higher tier when 90% of the storage space is full. An initial sync takes longer to complete compared to subsequent syncs, and reduces the performance of the primary from which the data is read.

If a destination member performing initial sync encounters a persistent network error during the sync process, the destination member restarts the initial sync process from the beginning.

A destination member performing initial sync can attempt to resume the sync process if interrupted by a temporary network error, collection drop, or collection rename.

By default, the destination member tries to resume initial sync for 24 hours. You can use the initialSyncTransientErrorRetryPeriodSeconds server parameter to control the amount of time the destination member attempts to resume initial sync. If the destination member cannot successfully resume the initial sync process during the configured time period, it selects a new healthy source member from the replica set and restarts the initial synchronization process from the beginning.

The secondary attempts to restart the initial sync up to 10 times before returning a fatal error.

Initial sync source selection depends on the value of the mongod startup parameter initialSyncSourceReadPreference:

  • For initialSyncSourceReadPreference set to primary (default if chainingAllowed is disabled), select the primary as the source member. If the primary is unavailable or unreachable, log an error and periodically check for primary availability.

  • For initialSyncSourceReadPreference set to primaryPreferred (default for voting replica set members), attempt to select the primary as the source member. If the primary is unavailable or unreachable, perform sync source member selection from the remaining replica set members.

  • For all other supported read modes, perform sync source member selection from the destination members.

Members performing initial source member selection make two passes through the list of all replica set members:

The member applies the following criteria to each replica set member when making the first pass for selecting a initial source member:

  • The source member must be in the PRIMARY or SECONDARY replication state.

  • The source member must be online and reachable.

  • If initialSyncSourceReadPreference is secondary or secondaryPreferred, the source member must be a secondary.

  • The source member must be visible.

  • The source member must be within 30 seconds of the newest oplog entry on the primary.

  • If the member builds indexes, the source member must build indexes.

  • If the member votes in replica set elections, the source member must also vote.

  • If the member is not a delayed member, the source member must not be delayed.

  • If the member is a delayed member, the source member must have a shorter configured delay.

  • The source member must be faster than the current best sync source.

If no candidate source member remains after the first pass, the member performs a second pass with relaxed criteria. See Sync Source Selection (Second Pass).

The member applies the following criteria to each replica set member when making the second pass for selecting a initial source member:

If the destination member cannot select a source member after two passes, it logs an error and waits 1 second before restarting the selection process. The secondary mongod can restart the initial sync source selection process up to 10 times before exiting with an error.

The oplog window must be long enough so that a destination member can fetch any new oplog entries that occur between the start and end of the Logical Initial Sync Process. If the window isn't long enough, there is a risk that some entries may fall off the oplog before the destination member can apply them.

It is recommended that you size the oplog for additional time to fetch any new oplog entries. This allows for changes that may occur during initial syncs.

For more information, see Oplog Size.

Destination members replicate data continuously after the initial sync. Destination members copy the oplog from the source member and apply these operations in an asynchronous process.

Destination members automatically change their source member as needed based on changes in the ping time and state of other members' replication. See Replication Sync Source Selection for more information on source member selection criteria.

Source members send a continuous stream of oplog entries to their destination members. Streaming replication mitigates replication lag in high-load and high-latency networks. It also:

  • Reduces staleness for reads from secondaries.

  • Reduces risk of losing write operations with w: 1 due to primary failover.

  • Reduces latency on write operations with w: "majority" and w: >1 (that is, any write concern that requires waiting for replication).

Use the oplogFetcherUsesExhaust startup parameter to disable streaming replication and using the older replication behavior. Set the oplogFetcherUsesExhaust parameter to false only if there are any resource constraints on the source member or if you wish to limit MongoDB's usage of network bandwidth for replication.

MongoDB applies write operations in batches using multiple threads to improve concurrency. MongoDB groups batches by document ID (WiredTiger) and simultaneously applies each group of operations using a different thread. MongoDB always applies write operations to a given document in their original write order.

Read operations that target secondaries and are configured with a read concern level of "local" or "majority" read from a WiredTiger snapshot of the data if the read takes place on a secondary where replication batches are being applied.

Reading from a snapshot guarantees a consistent view of the data, and allows the read to occur simultaneously with the ongoing replication without the need for a lock. As a result, secondary reads requiring these read concern levels no longer need to wait for replication batches to be applied, and can be handled as they are received.

Administrators can limit the rate at which the primary applies its writes with the goal of keeping the majority committed lag under a configurable maximum value flowControlTargetLagSeconds.

By default, flow control is enabled.

Note

For flow control to engage, the replica set/sharded cluster must have: featureCompatibilityVersion (fCV) of 4.2 and read concern majority enabled. That is, enabled flow control has no effect if fCV is not 4.2 or if read concern majority is disabled.

For more information, see Flow Control.

Replication source member selection depends on the replica set chaining setting:

  • With chaining enabled (default), perform source member selection from the destination members.

  • With chaining disabled, select the primary as the source member. If the primary is unavailable or unreachable, log an error and periodically check for primary availability.

Members performing replication source member selection make two passes through the list of all replica set members:

The member applies the following criteria to each replica set member when making the first pass for selecting a source member:

  • The source member must be in the PRIMARY or SECONDARY replication state.

  • The source member must be online and reachable.

  • The source member must have newer oplog entries than the member. That is, the source member must be ahead of the member.

  • The source member must be visible.

  • The source member must be within 30 seconds of the newest oplog entry on the primary.

  • If the member builds indexes, the source member must build indexes.

  • If the member votes in replica set elections, the source member must also vote.

  • If the member is not a delayed member, the source member must not be delayed.

  • If the member is a delayed member, the source member must have a shorter configured delay.

  • The source member must be faster than the current best sync source.

If no candidate source members remain after the first pass, the member performs a second pass with relaxed criteria. See the Sync Source Selection (Second Pass).

The member applies the following criteria to each replica set member when making the second pass for selecting a source member:

  • The source member must be in the PRIMARY or SECONDARY replication state.

  • The source member must be online and reachable.

  • If the member builds indexes, the source member must build indexes.

  • The source member must be faster than the current best sync source.

If the member cannot select a sync source after two passes, it logs an error and waits 1 second before restarting the selection process.

The number of times a source member can be changed per hour is configurable by setting the maxNumSyncSourceChangesPerHour parameter.

Note

The startup parameter initialSyncSourceReadPreference takes precedence over the replica set's settings.chainingAllowed setting when selecting an initial sync source member. After a replica set member successfully performs initial sync, it defers to the value of chainingAllowed when selecting a source member.

See Initial Sync Source Selection for more information on initial sync source selection.

Back

Oplog

Next

Replica Set Members