Re: size of attributes table is too big - Mailing list pgsql-general

From Ron Johnson
Subject Re: size of attributes table is too big
Date
Msg-id CANzqJaCd+WNj=wgmfaTWZ3f_WDGk1pB++QL7FdY3L1OyetNoYQ@mail.gmail.com
Whole thread Raw
In response to Re: size of attributes table is too big  (Siraj G <tosiraj.g@gmail.com>)
List pgsql-general

Use "pg_repack" instead.  It's an "online" CLUSTER / VACUUM FULL replacement that's in both RPM and apt repos.

On Tue, Mar 25, 2025 at 12:36 AM Siraj G <tosiraj.g@gmail.com> wrote:
Thank you!

I noticed over 99% free space. Now the challenge is running FULL VACUUM on a table with size over 500GB. It is going to take a couple of hours I presume.

Also, I hope aggressive vacuuming will prevent us from this situation.

Regards
Siraj




On Wed, Mar 19, 2025 at 11:27 PM Ron Johnson <ronljohnsonjr@gmail.com> wrote:
On Wed, Mar 19, 2025 at 1:06 PM Siraj G <tosiraj.g@gmail.com> wrote:
Hello!

I have a PG (v16) instance which is occupying around 1TB of storage. Out of this, around 350GB is occupied by the table pg_catalog.pg_attribute. 
Why is the catalog table's size so big?

Here are the sizes:

pg_attribute
338 GB
pg_attribute_relid_attnam_index
117 GB
pg_attribute_relid_attnum_index
69 GB

I think this table must have tons of dead tuples. Please suggest to me if we can purge any data/shrink the size of this table.


Run pgstattuple and pgstatindex on them.  They'll tell you how much bloat you have.

And tune your autovacuum parameters to be more aggressive.  These, for example, are my settings:
autovacuum_analyze_scale_factor = 0.015
autovacuum_vacuum_scale_factor = 0.015
autovacuum_vacuum_insert_scale_factor = 0.015
autovacuum_vacuum_insert_threshold = 250

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


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

pgsql-general by date:

Previous
From: Álvaro Herrera
Date:
Subject: Re: Today Page is not accessible - postgresql-15.spec
Next
From: Alexander Farber
Date:
Subject: How to pass a list of locations (longitude, latitude) to a PostgreSQL/PostGIS stored function?