pgsql: Force a checkpoint in CREATE DATABASE before starting to copy the - Mailing list pgsql-committers

From heikki@postgresql.org (Heikki Linnakangas)
Subject pgsql: Force a checkpoint in CREATE DATABASE before starting to copy the
Date
Msg-id 20081009103406.D69C57545A4@cvs.postgresql.org
Whole thread Raw
List pgsql-committers
Log Message:
-----------
Force a checkpoint in CREATE DATABASE before starting to copy the files,
to process any pending unlinks for the source database.

Before, if you dropped a relation in the template database just before
CREATE DATABASE, and a checkpoint happened during copydir(), the checkpoint
might delete a file that we're just about to copy, causing lstat() in
copydir() to fail with ENOENT.

Backpatch to 8.3, where the pending unlinks were introduced.

Per report by Matthew Wakeling and analysis by Tom Lane.

Modified Files:
--------------
    pgsql/src/backend/commands:
        dbcommands.c (r1.213 -> r1.214)
        (http://anoncvs.postgresql.org/cvsweb.cgi/pgsql/src/backend/commands/dbcommands.c?r1=1.213&r2=1.214)

pgsql-committers by date:

Previous
From: okbob@pgfoundry.org (User Okbob)
Date:
Subject: orafce - orafce: Change message buffer size and item size from size_t to
Next
From: heikki@postgresql.org (Heikki Linnakangas)
Date:
Subject: pgsql: Force a checkpoint in CREATE DATABASE before starting to copy the