Re: Difference between Vacuum and Vacuum full - Mailing list pgsql-performance

From Radhika S
Subject Re: Difference between Vacuum and Vacuum full
Date
Msg-id fe27bfd40710022005t6a7a19c0u19203de612a15c55@mail.gmail.com
Whole thread Raw
In response to Re: Difference between Vacuum and Vacuum full  ("Scott Marlowe" <scott.marlowe@gmail.com>)
List pgsql-performance
Thank you much for such a precise explanation. That was very helpful.

Regards,
Radhika

On 10/2/07, Scott Marlowe < scott.marlowe@gmail.com> wrote:
On 10/2/07, Radhika S < radhika.sambamurti@gmail.com> wrote:
> Hi,
>
> I have recently had to change our nightly jobs from running vacuum
> full, as it has caused problems for us. Upon doing more reading on
> this topic, I understand that vacuum full needs explicit locks on the
> entire db and explicit locking conflicts with all other locks.
>
> But this has bought me to the question of what exactly is the
> difference between vacuum and vacuum full. If both give back free
> space to the disk, then why have vacuum full.

Vacuum analyzes the tables and indexes, and marks deleted entries as
free and available and puts and entry into the free space map for
them.  The next time that table or index is updated, instead of
appending the new tuple to the end it can be placed in the middle of
the table / index.  this allows the database to reuse "empty" space in
the database.  Also, if there are dead tuples on the very end of the
table or index, it can truncate the end of the file and free that
space up.

Vaccum full basically re-writes the whole file minus all the dead
tuples, which requires it to lock the table while it is doing so.

Generally speaking, regular vacuum is preferable.  Vacuum full should
only be used to recover lost space due to too infrequent regular
vacuums or too small of a free space map.

vacuum full is much more invasive and should be avoided unless
absolutely necessary.



--
It is all a matter of perspective. You choose your view by choosing where to stand. --Larry Wall

pgsql-performance by date:

Previous
From: "D'Arcy J.M. Cain"
Date:
Subject: Re: Difference between Vacuum and Vacuum full
Next
From: "Giulio Cesare Solaroli"
Date:
Subject: Re: Newbie question about degraded performance on delete statement.