Drop a Hashed Shard Key Index
On this page
Starting in MongoDB 7.0.3 (and 6.0.12 and 5.0.22), you can drop the index for a hashed shard key.
This can speed up data insertion for collections sharded with a hashed
shard key. It can also speed up data ingestion when using
mongosync
.
About this Task
Dropping an unnecessary index can speed up CRUD operations. Each CRUD operation has to update all the indexes related to a document. Removing one index can increase the speed of all CRUD operations.
Important
You should only drop a hashed shard key index from a collection
if a supporting non-hashed index on the shard key exists. If a
supporting non-hashed index does not exist on the shard key, queries
filtering by the shard key perform a collection scan.
To see what indexes exist on a collection, use
db.collection.getIndexes()
.
Considerations
When dropping a hashed shard key index, consider the following:
The server disables balancing for your collection and excludes the collection from future balancing rounds. To include the collection in future balancing rounds, recreate the shard key index.
When you drop the shard key index, the range deleter does not clean up any remaining orphans in your collection. You must confirm that no orphaned documents exist in your collection before dropping the hashed shard key index. See the below procedure for how to confirm that there are no orphaned documents in your collection.
Steps
Confirm there are no orphaned documents in your collection
Starting in MongoDB 6.0.3, you can run an aggregation using the
$shardedDataDistribution
stage to confirm no orphaned
documents remain:
db.aggregate([ { $shardedDataDistribution: {} }, { $match: { "ns": "<database>.<collection>" } } ])
$shardedDataDistribution
has output similar to the following:
[ { "ns": "test.names", "shards": [ { "shardName": "shard-1", "numOrphanedDocs": 0, "numOwnedDocuments": 6, "ownedSizeBytes": 366, "orphanedSizeBytes": 0 }, { "shardName": "shard-2", "numOrphanedDocs": 0, "numOwnedDocuments": 6, "ownedSizeBytes": 366, "orphanedSizeBytes": 0 } ] } ]
Ensure that "numOrphanedDocs"
is 0
for each shard in the
cluster.