Downgrade 6.0 Sharded Cluster to 5.0
On this page
Before you attempt a downgrade, familiarize yourself with the content in this page.
Downgrade Path
Important
Before you upgrade or downgrade a sharded cluster, ensure all sharded cluster members are running. If you do not, the upgrade or downgrade will not complete until all members are started.
If you need to downgrade from 6.0, downgrade to the latest patch release of 5.0.
MongoDB only supports single-version downgrades. You cannot downgrade to a release that is multiple versions behind your current release.
For example, you may downgrade a 6.0-series to a 5.0-series deployment. However, further downgrading that 5.0-series deployment to a 4.4-series deployment is not supported.
Prerequisites
Before you begin the downgrade procedure, you must complete the following prerequisite steps.
Create Backup
Optional but Recommended. Create a backup of your database.
To learn how to create a backup, see Backup Methods for a Self-Managed Deployment.
Remove Backward-Incompatible Features
To downgrade from 6.0 to 5.0, you must remove 6.0 features that are incompatible with 5.0. For a list of incompatible features and how to remove them, see Downgrade Considerations.
Ensure No Resharding Operations are in Progress
Ensure that any resharding operations have
successfully completed. If a recent resharding operation has failed due
to a primary failover, you must first run the
cleanupReshardCollection
command before downgrading the
featureCompatibilityVersion
of your sharded cluster.
If a resharding operation is still running while you downgrade the
featureCompatibilityVersion
of your sharded cluster, the resharding
operation will not complete.
Downgrade Feature Compatibility Version (fCV)
To downgrade the fCV of your sharded cluster:
Ensure that no initial sync is in progress. Running the
setFeatureCompatibilityVersion
command while an initial sync is in progress causes the initial sync to restart.Ensure that no nodes have a
newlyAdded
field in their replica set configuration. Run the following command on each node in your replica set to verify this:use local db.system.replset.find( { "members.newlyAdded" : { $exists : true } } ); The
newlyAdded
field only appears in a node's replica set configuration document during and shortly after an initial sync.Ensure that no replica set member is in the
ROLLBACK
orRECOVERING
state.Downgrade the
featureCompatibilityVersion
to"5.0"
.db.adminCommand( { setFeatureCompatibilityVersion: "5.0" } ) The
setFeatureCompatibilityVersion
command performs writes to an internal system collection and is idempotent. If the command does not complete successfully, retry the command on themongos
instance.Note
Troubleshooting
While
setFeatureCompatibilityVersion
is running on the sharded cluster, chunk migrations, splits, and merges can fail withConflictingOperationInProgress
.If
setFeatureCompatibilityVersion
fails with aManualInterventionRequired
error, and the cluster has recently undergone a resharding operation that had failed due to an election, you must run thecleanupReshardCollection
command before you attempt to runsetFeatureCompatibilityVersion
again.
To ensure that all members of the replica set have the updated
featureCompatibilityVersion
, connect to each replica set member and check thefeatureCompatibilityVersion
:db.adminCommand( { getParameter: 1, featureCompatibilityVersion: 1 } ) Tip
Access Control
For a sharded cluster that has access control enabled, to run the
adminCommand
on a shard replica set member, you must connect to the member as a shard local user.All members should return a result that includes:
"featureCompatibilityVersion" : { "version" : "5.0" } If any member returns a
featureCompatibilityVersion
of"6.0"
, wait for the member to return version"5.0"
before proceeding.
For more information on the returned featureCompatibilityVersion
value, see Get FeatureCompatibilityVersion.
Downgrade Procedure
Warning
Before proceeding with the downgrade procedure, ensure that all
sharded cluster members, including delayed replica set members, have
the prerequisite changes. To do that, check the
featureCompatibilityVersion
and the remove the incompatible
features for each node before downgrading.
Download the latest 5.0 binaries.
Using either a package manager or a manual download, get the latest release in the 5.0 series. If using a package manager, add a new repository for the 5.0 binaries, then perform the actual downgrade process.
Important
Before you upgrade or downgrade a replica set, ensure all replica set members are running. If you do not, the upgrade or downgrade will not complete until all members are started.
If you need to downgrade from 6.0, downgrade to the latest patch release of 5.0.
Disable the Balancer.
To disable the balancer, connect mongosh
to a
mongos
instance in the sharded cluster, and run the
following command:
sh.stopBalancer()
Note
If a migration is in progress, MongoDB completes the in-progress
migration before stopping the balancer. To check the balancer's
current state, run sh.isBalancerRunning()
.
To verify that the balancer is disabled, run the following command:
sh.getBalancerState()
sh.getBalancerState()
returns false
if the balancer
is disabled.
For more information on disabling the balancer, see Disable the Balancer.
Downgrade each shard, one at a time.
Downgrade the shard's secondary members, one at a time.
Shut down the member.
To shut down the
mongod
process, usemongosh
to connect to the deployment and run the following command:db.adminCommand( { shutdown: 1 } ) Restart the member.
To start a
mongod
process, run the following command:mongod --dbpath </path-to-data-folder> Wait for the member to enter the
SECONDARY
state.Before downgrading the next secondary, wait for the member to recover to the
SECONDARY
state. To check the member's state, use thers.status()
method inmongosh
.Repeat the previous steps to downgrade each secondary member.
Downgrade the shard arbiter, if any.
Skip this step if the replica set does not include an arbiter.
Downgrade the arbiter member of the sharded cluster:
Shut down the member.
To shut down the arbiter, use
mongosh
to connect to the arbiter and run the following command:db.adminCommand( { shutdown: 1 } ) Delete the contents of the arbiter data directory.
To find the data directory of the arbiter
mongod
, check either thestorage.dbPath
configuration setting or--dbpath
command line option.Run the following command:
rm -rf /path/to/mongodb/datafiles/* Restart the arbiter.
To start a
mongod
process, run the following command:mongod --dbpath </path-to-mongodb-datafiles> Wait for the member to enter the
ARBITER
state.Before downgrading the primary, wait for the member to recover to the
ARBITER
state. To check the member's state, use thers.status()
method inmongosh
.
Downgrade the shard primary.
Step down the primary.
In
mongosh
, users.stepDown()
to step down the primary and start an election for a new primary:rs.stepDown() Verify that the primary has stepped down.
Run the following command:
rs.status() Verify that the primary has stepped down and another member has assumed the
PRIMARY
state.Shut down the former primary member.
To shut down the former primary, connect to the deployment using
mongosh
and run the following command:db.adminCommand( { shutdown: 1 } ) Restart the
mongod
with the 5.0 binary.To start a
mongod
process, run the following command:mongod --dbpath </path-to-mongodb-datafiles> Repeat for the remaining shards.
Downgrade the config servers.
Downgrade the shard's secondary members of the config servers replica set (CSRS) one at a time:
Shut down the secondary.
Connect to the secondary and run the following command:
db.adminCommand( { shutdown: 1 } ) Restart the member.
To start a
mongod
process, run the following command:mongod --dbpath </path-to-data-folder> Wait for the member to enter the
SECONDARY
state.Before downgrading the next secondary, wait for the member to recover to the
SECONDARY
state. To check the member's state, use thers.status()
method inmongosh
.Repeat the previous steps to downgrade each secondary member.
Downgrade the config server primary.
Step down the primary.
In
mongosh
, runrs.stepDown()
to step down the primary and start an election for a new primary:rs.stepDown() Verify that the primary has stepped down.
Run the following command:
rs.status() Verify that the primary has stepped down and another member has assumed the
PRIMARY
state.Shut down the former primary member.
To shut down the former primary, connect to the deployment using
mongosh
and run the following command:db.adminCommand( { shutdown: 1 } ) Restart the
mongod
with the 5.0 binary.To start a
mongod
process, run the following command:mongod --dbpath </path-to-mongodb-datafiles>
Re-enable the balancer.
After you downgrade all of the sharded cluster components, connect
to a mongos
and run the following command to
re-enable the balancer:
sh.startBalancer()
The sh.startBalancer()
method also enables auto-splitting
for the sharded cluster.