Re: archive_command vs. cp -i

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi all:

Corrected the top posting.

On Fri, Jun 17, 2011 at 12:55:07PM -0400, Tim wrote:
> On Fri, Jun 17, 2011 at 12:32 PM, Kevin Grittner
> Kevin.Grittner@xxxxxxxxxxxx> wrote:
> > "Martin Münstermann"<mmuenst@xxxxxx> wrote:
> > > while setting up a new linux postgresql server, I checked my
> > > archive_command.  I noticed that the usual "cp -i f1 f2 <
> > > /dev/null" did NOT as expected:  It did not overwrite the file
> > > (PASS), but it returned zero (FAIL, should return error).
> > >
> > > This could be reproduced on CentOS 5.6, RHEL4, and Ubuntu 10.04.
> > I've confirmed on SLES 10 and Ubuntu 9, too.

Not really surprising since choosing to not copy a file isn't really
an indication of an error when copying a file so...

I get the same result (0 exit status) on solaris 8 and solaris 10 with
/bin/cp.  I wonder what platform the example worked on.

> > > Should the BACKUP-ARCHIVING-WAL doc be changed?
> >
> > I think so.  Given the wide variety of platforms on which the
> > example could silently cause data loss, I *really* don't think we
> > want that in our docs.  Someone could blithely copy it into
> > production without testing and not know they had it wrong until a
> > backup failed to restore.

For what it's worth I strongly agree.

> Technically the documentation covers its self by saying:
> "This is an example, not a recommendation, and might not work on all
> platforms."
> What would be nice is if the documentation could be made more useful by
> providing some more complex example scripts.
> What do our readers use for WAL archiving?

'test ! -f /var/bak/pgsql/%f && cp %p /var/bak/pgsql/%f'

Which does have a slight race condition as the output file could be
created between the test finishing and the cp starting. But the only
way that is likely to happen is if postgresql tried to run two
identical archive commands in parallel, and I think I would have other
issues if that was happening.

The following may be safer if you are using a shell with noclobber, or
it may not be. Depends on the race conditions in how the shell
implements the noclobber code.

'sh -c "set -o noclobber; cat %p > /var/bak/pgsql/%f"'


-- 
				-- rouilj

John Rouillard       System Administrator       Renesys Corporation

-- 
Sent via pgsql-admin mailing list (pgsql-admin@xxxxxxxxxxxxxx)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-admin


[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux