pgsql: Error when creating names too long for tar format

From: Peter Eisentraut <peter_e(at)gmx(dot)net>
To: pgsql-committers(at)postgresql(dot)org
Subject: pgsql: Error when creating names too long for tar format
Date: 2015-02-24 18:42:09
Message-ID: E1YQKQr-0005yC-Ps@gemulon.postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-committers

Error when creating names too long for tar format

The tar format (at least the version we are using), does not support
file names or symlink targets longer than 99 bytes. Until now, the tar
creation code would silently truncate any names that are too long. (Its
original application was pg_dump, where this never happens.) This
creates problems when running base backups over the replication
protocol.

The most important problem is when a tablespace path is longer than 99
bytes, which will result in a truncated tablespace path being backed up.
Less importantly, the basebackup protocol also promises to back up any
other files it happens to find in the data directory, which would also
lead to file name truncation if someone put a file with a long name in
there.

Now both of these cases result in an error during the backup.

Add tests that fail when a too-long file name or symlink is attempted to
be backed up.

Reviewed-by: Robert Hass <robertmhaas(at)gmail(dot)com>

Branch
------
master

Details
-------
http://git.postgresql.org/pg/commitdiff/23a78352c0a0dc21d6120bd868f0b2d07395b537

Modified Files
--------------
src/backend/replication/basebackup.c | 21 ++++++++++++++++++++-
src/bin/pg_basebackup/t/010_pg_basebackup.pl | 15 ++++++++++++++-
src/include/pgtar.h | 10 +++++++++-
src/port/tar.c | 10 +++++++++-
4 files changed, 52 insertions(+), 4 deletions(-)

Responses

Browse pgsql-committers by date

  From Date Subject
Next Message Robert Haas 2015-02-24 20:51:46 Re: pgsql: Error when creating names too long for tar format
Previous Message Fabien COELHO 2015-02-24 16:36:58 Re: pgsql: Support more commands in event triggers