The Performance Advisor suggests dropping unused, redundant, and hidden indexes to improve write performance and increase storage space.
Tip
To learn more about the impact of unnecessary indexes, see Remove Unnecessary Indexes.
Unused Indexes
An index is unused if it doesn't support any queries.
The Performance Advisor flags an index as unused if it hasn't supported a query in 7 or more days after it was created or the server was restarted.
Note
The Performance Advisor inspects only the 20 most active collections for unused indexes.
Redundant Indexes
An index is redundant if another index supports any query that it could.
The Performance Advisor flags an index as redundant if it matches the prefix of another index in the same collection.
Example
If a collection contains the indexes:
- { a: 1 }
- { b: -1 }
- { a: 1, b: -1 }
{ a: 1 } is redundant because it matches the prefix
{ a: 1, b: -1 }.
{ b: -1 } is not redundant because it does not match any prefix.
In the Performance Advisor, redundant indexes are marked with a red
Redundant badge. Below each redundant index, the Performance
Advisor displays the related indexes that cover it.
Note
Related indexes are displayed for you to verify that the redundant index can be dropped safely. Related indexes are not recommended for removal.
Hidden Indexes
Atlas doesn't use hidden indexes to support queries. They still impact write performance and consume storage space. To learn more, see Hidden Indexes.
You can hide an index to evaluate the impact of dropping an index before you drop it. Unhiding an index also takes less time than rebuilding a dropped index. To hide and unhide an index by using the Atlas UI, see Manage Indexes.
The Performance Advisor always recommends dropping hidden indexes. If you determine that a hidden index is unnecessary, drop it.
Note
The Atlas Performance Advisor page displays hidden indexes from your top 20 most active namespaces at the time you load the page. If you have more than 20 namespaces, the Performance Advisor page might not display all of your namespaces with hidden indexes.
Drop or Hide an Index
Note
Consider hiding indexes before you drop them.
To drop or hide an index by using the Performance Advisor:
In Atlas, go to the Clusters page for your project.
WARNING: Navigation Improvements In Progress We're currently rolling out a new and improved navigation experience. If the following steps don't match your view in the Atlas UI, see the preview documentation.
- If it's not already displayed, select the organization that contains your desired project from the Organizations menu in the navigation bar. 
- If it's not already displayed, select your desired project from the Projects menu in the navigation bar. 
- If it's not already displayed, click Clusters in the sidebar. - The Clusters page displays. 
On the index that you want to drop or hide, click Drop Index.
The Performance Advisor displays a dialog box with a link to the Atlas UI and a copyable MongoDB Shell command to drop that index.
The dialog box also provides a copyable MongoDB Shell command to hide that index.
Drop or hide the index by using the Atlas UI or MongoDB Shell.
To drop or hide an index by using the Atlas UI, click the Indexes tab, then click the Drop Index or Hide Index icon next to the index. Atlas displays a dialog box to confirm your selection. For more information, see Manage Indexes.
To drop or hide an index by using the MongoDB Shell, paste and run the command provided by the Performance Advisor.