Index Advisor: Index Consolidation
The pganalyze Index Advisor includes an experimental, early access feature
to include index consolidation insights (i.e., insights that use DROP INDEX
recommendations in addition to CREATE INDEX).
Overview
While indexes can dramatically speed up many queries, they do have some performance impact on your database: write overhead, additional memory needed for the index data structure while in use, and disk space. To optimize the number of indexes recommended, the Index Advisor considers the full query workload on a table rather than recommending indexes specifically for each query or each scan. This works well when starting from scratch, but when starting with existing indexes, it may lead to over-indexing. Consolidation insights can help.
Limitations
- Dropping the wrong index can have a catastrophic impact on database performance. We recommend testing all Index Advisor insights before implementing them, but this is especially true of consolidation insights.
- Index Advisor currently has a limited model of partial indexes (indexes with
a WHEREclause) due to technical limitations, and will recommend dropping them all when consolidation is turned on. These insights should be disregarded.
- Index Advisor generates insights that are intended to be taken as a group:
e.g., a DROP INDEXrecommendation may exist because it's supplanted by a separateCREATE INDEXrecommendation. We do not recommend applyingDROP INDEXrecommendations independently unless they are carefully reviewed and tested.
Usage
In order to use consolidation insights, first your pganalyze organization must be flagged into early access (see below).
Once flagged in, go to the Schema Statistics page in the menu, click on the table you are interested in, and click on the Index Advisor tab. Then, select "Custom Configuration" and check the "Allow consolidation/removal of indexes" checkbox:
Click "Try configuration" to see Index Advisor insights with consolidation enabled. You can then save this configuration like any other. Consolidation is currently only available on a table-by-table basis, only using custom configurations (though note you can load any of our default configurations as the starting point).
Early access
If you are interested in exploring this experimental feature, please contact us. The feature will be enabled for your entire organization, so any organization member with access to a particular server and database in pganalyze will be able to use it. Please ensure your colleagues understand the limitations listed above and do not apply the recommendations without adequate review and testing.
Couldn't find what you were looking for or want to talk about something specific?
Start a conversation with us →
