Index rebuilding strategy

Started by Siraj G7 months ago4 messagesgeneral
Jump to latest
#1Siraj G
tosiraj.g@gmail.com

Hello Experts!

What are the top pointers we should consider for index rebuild? Check its
size, bloat estimate, heavy Updates/Deletes?

Please highlight the best practices.

Thanks
Siraj

#2Alban Hertroys
haramrae@gmail.com
In reply to: Siraj G (#1)
Re: Index rebuilding strategy

On 24 Sep 2025, at 22:42, Siraj G <tosiraj.g@gmail.com> wrote:

Hello Experts!

What are the top pointers we should consider for index rebuild? Check its size, bloat estimate, heavy Updates/Deletes?

Please highlight the best practices.

I think just any pointers of corruption, really. OS updates with differing collation implementations, known flaky hardware or driver issues, checksum discrepancies if you have those turned on and get any of those.

The need to rebuild indices should be quite rare. Regular vacuuming and analysing should take care of most of the need, with much of those happening automatically anyway (could need some tuning though).

Regards,
Alban Hertroys
--
If you can't see the forest for the trees,
cut the trees and you'll find there is no forest.

#3Laurenz Albe
laurenz.albe@cybertec.at
In reply to: Siraj G (#1)
Re: Index rebuilding strategy

On Thu, 2025-09-25 at 02:12 +0530, Siraj G wrote:

What are the top pointers we should consider for index rebuild? Check its size,  bloat estimate, heavy Updates/Deletes?

https://www.cybertec-postgresql.com/en/should-i-rebuild-my-postgresql-index/

Yours,
Laurenz Albe

#4Ron
ronljohnsonjr@gmail.com
In reply to: Alban Hertroys (#2)
Re: Index rebuilding strategy

On Wed, Sep 24, 2025 at 4:51 PM Alban Hertroys <haramrae@gmail.com> wrote:

On 24 Sep 2025, at 22:42, Siraj G <tosiraj.g@gmail.com> wrote:

Hello Experts!

What are the top pointers we should consider for index rebuild? Check

its size, bloat estimate, heavy Updates/Deletes?

Please highlight the best practices.

I think just any pointers of corruption, really. OS updates with differing
collation implementations, known flaky hardware or driver issues, checksum
discrepancies if you have those turned on and get any of those.

The need to rebuild indices should be quite rare. Regular vacuuming and
analysing should take care of most of the need, with much of those
happening automatically anyway (could need some tuning though).

I drop the scale factors down to 1.5% and the insert threshold to 500. The
application we run seems to like that. YMMV, of course.

autovacuum_analyze_scale_factor = 0.015
autovacuum_vacuum_scale_factor = 0.015
autovacuum_vacuum_insert_scale_factor = 0.015
autovacuum_vacuum_insert_threshold = 500

Also, I repack tables when abs(correlation) gets below 60% (which
eventually happens on tables where the oldest records are regularly
deleted). That rebuilds the indices for you.

(Why don't I partition those tables? 1. It's a 3rd party application;
thus, they control the schema. 2. Partitioning by date means adding a date
field to the PK, which means the PK really isn't a PK anymore.)

--
Death to <Redacted>, and butter sauce.
Don't boil me, I'm still alive.
<Redacted> lobster!