Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

TODO / Ideas #1

Closed
2 of 15 tasks
ankane opened this issue Jun 26, 2017 · 11 comments
Closed
2 of 15 tasks

TODO / Ideas #1

ankane opened this issue Jun 26, 2017 · 11 comments

Comments

@ankane
Copy link
Owner

ankane commented Jun 26, 2017

0.4.0

  • Update to pg_query 2
  • Drop support for Ruby < 2.5 (2.5 is EOL but Ubuntu 18.04 uses it)

Ideas

  • determine write-heavy tables automatically
  • notifications when indexes found (email & Slack)
  • only create indexes at certain times of day (low traffic times) - one approach is to run Dexter daily instead of stream
  • option to write created/suggested indexes to table (in dexter schema)
  • optimize across all queries (get N best indexes for a query)
  • non-BTREE indexes (add support to hypopg)
  • use multiple samples for each fingerprint
  • add support for directions to multicolumn indexes
  • calculate total time saved, and order indexes by this

Big ideas

  • prefer lots of small partial indexes over full indexes

Full index management

  • drop duplicate/covered indexes
  • drop unused indexes - drop_unused branch (have to be careful with replicas)
  • drop indexes that have little benefit (have to be careful with replicas)
@matias-eduardo
Copy link

This is great! Thank you.
+1 for determining write-heavy tables 🙌

@booleanbetrayal
Copy link

+1 for multi-column indexes, as this would cover a significant amount of our existing index definitions. Would love to use Dexter to validate certain assumptions, but probably can't until that goes in.

@jfinzel
Copy link

jfinzel commented Dec 21, 2017

What about partial indexes - especially for low cardinality fields? You could use pg_statistics to help with that. I haven't checked if these are supported as suggestions but I am guessing not yet?

@anthares
Copy link

Hi @ankane,

Great work so far on pghero and dexter, thanks :)
I was wondering if there is plans to implement dexter to Slack connectivity in a near future.
Because we'd rather use dexter for automatic missing index detection and notification. Slack notification would be far more convenient than tailling the logs.

Thanks,
Anthares

@jfinzel
Copy link

jfinzel commented Feb 20, 2018

@ankane does it support creating indexes when queries only use views? I have a particular system where almost all user queries are pointed to views, thus of course indexes can only apply to the tables underneath. This would be very useful.

@ankane
Copy link
Owner Author

ankane commented Feb 21, 2018

@jfinzel Just added support for views and materialized views.

@jfinzel
Copy link

jfinzel commented Mar 7, 2018

@ankane now that I am finding this working, I have another thought. It would be nice to run this and save the query_id, initial cost, pass costs, sql and suggested index. The reason is for additional analysis - I want to see how many queries end up suggesting the same index before creating one.

It already is very useful as-is, but would be a "nice to have" to have something like an output format that I could save itself into a db table and run some sampling on.

@alexandervlpl
Copy link

alexandervlpl commented Aug 17, 2018

+1 for "non-BTREE indexes", specifically GiST!

@ankane This is amazing work, I wish I could already use Dexter to GiST index my PostGIS databases. The potential to improve the performance of OpenStreetMap and other map services would be enormous!

Specifically, it would be great to have Dexter suggest indexes like this one from OpenStreetMap:

CREATE INDEX planet_osm_roads_admin ON planet_osm_roads USING GIST (way) WHERE boundary = 'administrative';

@brightball
Copy link

Specify a tablespace for indexes created by Dexter. Beneficial for setups with multiple mounted disks where you may have access to something like very fast NVMe drives.

@cpj95
Copy link

cpj95 commented Nov 6, 2020

Is there support for AWS RDS running PostgreSQL yet?
@ankane

@ankane
Copy link
Owner Author

ankane commented Nov 24, 2020

@brightball fwiw, just released a --tablespace option.

@cpj95 See the instructions in the readme for how to use Dexter with Amazon RDS.

@ankane ankane closed this as completed Mar 26, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

8 participants