>>> On Thu, Dec 13, 2007 at 10:11 AM, in message <1197562283.4255.1829.camel@xxxxxxxxxx>, Simon Riggs <simon@xxxxxxxxxxxxxxx> wrote: > On Thu, 2007-12-13 at 09:46 -0600, Kevin Grittner wrote: > >> The data was inserted through a Java program using a prepared >> statement with no indexes on the table. The primary key was then >> added, and now I've started a vacuum. The new table wound up being >> the first big table vacuumed, and I noticed something odd. Even >> though there have been no rollbacks, updates, or deletes on this >> table, the vacuum is writing as much as it is reading while dealing >> with the TOAST data. > > Writing hint bits. Annoying isn't it? :-( Is there anything in the documentation that mentions this pattern of activity? Since I started clearing the WAL file tails before compression, it has surprised me how much WAL file activity there is from the nightly vacuum. I had assumed that some part of this was freezing old tuples, but that didn't seem to exactly match the pattern of activity. If the hint bit changes are written to the WAL, I think this explains it. Maybe this too arcane for the docs, but I'm not so sure. Effectively, it means that every new tuple which has much of a lifespan has to be written at least three times, if I'm understanding you: once during the database transaction which creates it, once in the first subsequent vacuum of that table to flag that it was committed, and again when it reaches the freeze threshold to prevent transaction number wraparound. That last one could be sort of a surprise for someone at some point after, say, restoring from pg_dump, couldn't it? Would it make any kind of sense for a person to do the first vacuum after a bulk load using the FREEZE keyword (or the more recent equivalent setting)? -Kevin ---------------------------(end of broadcast)--------------------------- TIP 2: Don't 'kill -9' the postmaster