Commit c22ed3d5 authored by Tom Lane's avatar Tom Lane

Turn the -i/--ignore-version options of pg_dump and pg_dumpall into no-ops:

the server version check is now always enforced.  Relax the version check to
allow a server that is of pg_dump's own major version but a later minor
version; this is the only case that -i was at all safe to use in.

pg_restore already enforced only a very weak version check, so this is
really just a documentation change for it.

Per discussion.
parent ba1c4630
<!-- <!--
$PostgreSQL: pgsql/doc/src/sgml/ref/pg_dump.sgml,v 1.101 2008/03/26 16:34:47 tgl Exp $ $PostgreSQL: pgsql/doc/src/sgml/ref/pg_dump.sgml,v 1.102 2008/04/13 03:49:21 tgl Exp $
PostgreSQL documentation PostgreSQL documentation
--> -->
...@@ -296,20 +296,7 @@ PostgreSQL documentation ...@@ -296,20 +296,7 @@ PostgreSQL documentation
<term><option>--ignore-version</></term> <term><option>--ignore-version</></term>
<listitem> <listitem>
<para> <para>
Ignore version mismatch between A deprecated option that is now ignored.
<application>pg_dump</application> and the database server.
</para>
<para>
By default, <application>pg_dump</> will refuse to attempt
to dump from a server that is of a newer <productname>PostgreSQL</>
version than <application>pg_dump</application> is. It will also
refuse to attempt to dump from a server that is older than the oldest
supported version (currently, 7.0). The <option>-i</> option
overrides this check and forces a dump to be attempted anyway.
This option is <emphasis>deprecated</> because the dump is very
likely to fail &mdash; or worse, seem to succeed but be wrong or
incomplete.
</para> </para>
</listitem> </listitem>
</varlistentry> </varlistentry>
......
<!-- <!--
$PostgreSQL: pgsql/doc/src/sgml/ref/pg_dumpall.sgml,v 1.71 2008/03/26 16:34:47 tgl Exp $ $PostgreSQL: pgsql/doc/src/sgml/ref/pg_dumpall.sgml,v 1.72 2008/04/13 03:49:21 tgl Exp $
PostgreSQL documentation PostgreSQL documentation
--> -->
...@@ -156,20 +156,7 @@ PostgreSQL documentation ...@@ -156,20 +156,7 @@ PostgreSQL documentation
<term><option>--ignore-version</></term> <term><option>--ignore-version</></term>
<listitem> <listitem>
<para> <para>
Ignore version mismatch between A deprecated option that is now ignored.
<application>pg_dumpall</application> and the database server.
</para>
<para>
By default, <application>pg_dumpall</> will refuse to attempt
to dump from a server that is of a newer <productname>PostgreSQL</>
version than <application>pg_dumpall</application> is. It will also
refuse to attempt to dump from a server that is older than the oldest
supported version (currently, 7.0). The <option>-i</> option
overrides this check and forces a dump to be attempted anyway.
This option is <emphasis>deprecated</> because the dump is very
likely to fail &mdash; or worse, seem to succeed but be wrong or
incomplete.
</para> </para>
</listitem> </listitem>
</varlistentry> </varlistentry>
......
<!-- $PostgreSQL: pgsql/doc/src/sgml/ref/pg_restore.sgml,v 1.74 2008/03/26 16:34:47 tgl Exp $ --> <!-- $PostgreSQL: pgsql/doc/src/sgml/ref/pg_restore.sgml,v 1.75 2008/04/13 03:49:21 tgl Exp $ -->
<refentry id="APP-PGRESTORE"> <refentry id="APP-PGRESTORE">
<refmeta> <refmeta>
...@@ -200,8 +200,7 @@ ...@@ -200,8 +200,7 @@
<term><option>--ignore-version</option></term> <term><option>--ignore-version</option></term>
<listitem> <listitem>
<para> <para>
Ignore version mismatch between A deprecated option that is now ignored.
<application>pg_restore</application> and the database server.
</para> </para>
</listitem> </listitem>
</varlistentry> </varlistentry>
......
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup.h,v 1.46 2008/03/20 17:36:57 tgl Exp $ * $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup.h,v 1.47 2008/04/13 03:49:21 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -116,7 +116,6 @@ typedef struct _restoreOptions ...@@ -116,7 +116,6 @@ typedef struct _restoreOptions
char *pgport; char *pgport;
char *pghost; char *pghost;
char *username; char *username;
int ignoreVersion;
int noDataForFailedTables; int noDataForFailedTables;
int requirePassword; int requirePassword;
int exit_on_error; int exit_on_error;
...@@ -144,9 +143,7 @@ PGconn *ConnectDatabase(Archive *AH, ...@@ -144,9 +143,7 @@ PGconn *ConnectDatabase(Archive *AH,
const char *pghost, const char *pghost,
const char *pgport, const char *pgport,
const char *username, const char *username,
const int reqPwd, int reqPwd);
const int ignoreVersion);
/* Called to add a TOC entry */ /* Called to add a TOC entry */
extern void ArchiveEntry(Archive *AHX, extern void ArchiveEntry(Archive *AHX,
......
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_archiver.c,v 1.153 2008/03/20 17:36:57 tgl Exp $ * $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_archiver.c,v 1.154 2008/04/13 03:49:21 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -162,7 +162,7 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt) ...@@ -162,7 +162,7 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt)
ConnectDatabase(AHX, ropt->dbname, ConnectDatabase(AHX, ropt->dbname,
ropt->pghost, ropt->pgport, ropt->username, ropt->pghost, ropt->pgport, ropt->username,
ropt->requirePassword, ropt->ignoreVersion); ropt->requirePassword);
/* /*
* If we're talking to the DB directly, don't send comments since they * If we're talking to the DB directly, don't send comments since they
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* Implements the basic DB functions used by the archiver. * Implements the basic DB functions used by the archiver.
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_db.c,v 1.78 2008/03/26 14:32:22 momjian Exp $ * $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_db.c,v 1.79 2008/04/13 03:49:22 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -24,7 +24,7 @@ ...@@ -24,7 +24,7 @@
static const char *modulename = gettext_noop("archiver (db)"); static const char *modulename = gettext_noop("archiver (db)");
static void _check_database_version(ArchiveHandle *AH, bool ignoreVersion); static void _check_database_version(ArchiveHandle *AH);
static PGconn *_connectDB(ArchiveHandle *AH, const char *newdbname, const char *newUser); static PGconn *_connectDB(ArchiveHandle *AH, const char *newdbname, const char *newUser);
static void notice_processor(void *arg, const char *message); static void notice_processor(void *arg, const char *message);
static char *_sendSQLLine(ArchiveHandle *AH, char *qry, char *eos); static char *_sendSQLLine(ArchiveHandle *AH, char *qry, char *eos);
...@@ -48,7 +48,7 @@ _parse_version(ArchiveHandle *AH, const char *versionString) ...@@ -48,7 +48,7 @@ _parse_version(ArchiveHandle *AH, const char *versionString)
} }
static void static void
_check_database_version(ArchiveHandle *AH, bool ignoreVersion) _check_database_version(ArchiveHandle *AH)
{ {
int myversion; int myversion;
const char *remoteversion_str; const char *remoteversion_str;
...@@ -71,11 +71,7 @@ _check_database_version(ArchiveHandle *AH, bool ignoreVersion) ...@@ -71,11 +71,7 @@ _check_database_version(ArchiveHandle *AH, bool ignoreVersion)
{ {
write_msg(NULL, "server version: %s; %s version: %s\n", write_msg(NULL, "server version: %s; %s version: %s\n",
remoteversion_str, progname, PG_VERSION); remoteversion_str, progname, PG_VERSION);
if (ignoreVersion) die_horribly(AH, NULL, "aborting because of server version mismatch\n");
write_msg(NULL, "ignoring server version mismatch\n");
else
die_horribly(AH, NULL, "aborting because of server version mismatch\n"
"Use the -i option to bypass server version check, but be prepared for failure.\n");
} }
} }
...@@ -182,7 +178,7 @@ _connectDB(ArchiveHandle *AH, const char *reqdb, const char *requser) ...@@ -182,7 +178,7 @@ _connectDB(ArchiveHandle *AH, const char *reqdb, const char *requser)
free(password); free(password);
/* check for version mismatch */ /* check for version mismatch */
_check_database_version(AH, true); _check_database_version(AH);
PQsetNoticeProcessor(newConn, notice_processor, NULL); PQsetNoticeProcessor(newConn, notice_processor, NULL);
...@@ -201,8 +197,7 @@ ConnectDatabase(Archive *AHX, ...@@ -201,8 +197,7 @@ ConnectDatabase(Archive *AHX,
const char *pghost, const char *pghost,
const char *pgport, const char *pgport,
const char *username, const char *username,
const int reqPwd, int reqPwd)
const int ignoreVersion)
{ {
ArchiveHandle *AH = (ArchiveHandle *) AHX; ArchiveHandle *AH = (ArchiveHandle *) AHX;
char *password = NULL; char *password = NULL;
...@@ -254,7 +249,7 @@ ConnectDatabase(Archive *AHX, ...@@ -254,7 +249,7 @@ ConnectDatabase(Archive *AHX,
PQdb(AH->connection), PQerrorMessage(AH->connection)); PQdb(AH->connection), PQerrorMessage(AH->connection));
/* check for version mismatch */ /* check for version mismatch */
_check_database_version(AH, ignoreVersion); _check_database_version(AH);
PQsetNoticeProcessor(AH->connection, notice_processor, NULL); PQsetNoticeProcessor(AH->connection, notice_processor, NULL);
......
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
* by PostgreSQL * by PostgreSQL
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.c,v 1.486 2008/03/28 00:21:56 tgl Exp $ * $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.c,v 1.487 2008/04/13 03:49:22 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -211,19 +211,20 @@ main(int argc, char **argv) ...@@ -211,19 +211,20 @@ main(int argc, char **argv)
int i; int i;
bool force_password = false; bool force_password = false;
int compressLevel = -1; int compressLevel = -1;
bool ignore_version = false;
int plainText = 0; int plainText = 0;
int outputClean = 0; int outputClean = 0;
int outputCreate = 0; int outputCreate = 0;
bool outputBlobs = false; bool outputBlobs = false;
int outputNoOwner = 0; int outputNoOwner = 0;
char *outputSuperuser = NULL; char *outputSuperuser = NULL;
int my_version;
int optindex;
RestoreOptions *ropt;
static int disable_triggers = 0; static int disable_triggers = 0;
static int outputNoTablespaces = 0; static int outputNoTablespaces = 0;
static int use_setsessauth = 0; static int use_setsessauth = 0;
RestoreOptions *ropt;
static struct option long_options[] = { static struct option long_options[] = {
{"data-only", no_argument, NULL, 'a'}, {"data-only", no_argument, NULL, 'a'},
{"blobs", no_argument, NULL, 'b'}, {"blobs", no_argument, NULL, 'b'},
...@@ -266,7 +267,6 @@ main(int argc, char **argv) ...@@ -266,7 +267,6 @@ main(int argc, char **argv)
{NULL, 0, NULL, 0} {NULL, 0, NULL, 0}
}; };
int optindex;
set_pglocale_pgservice(argv[0], "pg_dump"); set_pglocale_pgservice(argv[0], "pg_dump");
...@@ -345,8 +345,8 @@ main(int argc, char **argv) ...@@ -345,8 +345,8 @@ main(int argc, char **argv)
pghost = optarg; pghost = optarg;
break; break;
case 'i': /* ignore database version mismatch */ case 'i':
ignore_version = true; /* ignored, deprecated option */
break; break;
case 'n': /* include schema(s) */ case 'n': /* include schema(s) */
...@@ -512,20 +512,26 @@ main(int argc, char **argv) ...@@ -512,20 +512,26 @@ main(int argc, char **argv)
/* Let the archiver know how noisy to be */ /* Let the archiver know how noisy to be */
g_fout->verbose = g_verbose; g_fout->verbose = g_verbose;
g_fout->minRemoteVersion = 70000; /* we can handle back to 7.0 */ my_version = parse_version(PG_VERSION);
g_fout->maxRemoteVersion = parse_version(PG_VERSION); if (my_version < 0)
if (g_fout->maxRemoteVersion < 0)
{ {
write_msg(NULL, "could not parse version string \"%s\"\n", PG_VERSION); write_msg(NULL, "could not parse version string \"%s\"\n", PG_VERSION);
exit(1); exit(1);
} }
/*
* We allow the server to be back to 7.0, and up to any minor release
* of our own major version. (See also version check in pg_dumpall.c.)
*/
g_fout->minRemoteVersion = 70000;
g_fout->maxRemoteVersion = (my_version / 100) * 100 + 99;
/* /*
* Open the database using the Archiver, so it knows about it. Errors mean * Open the database using the Archiver, so it knows about it. Errors mean
* death. * death.
*/ */
g_conn = ConnectDatabase(g_fout, dbname, pghost, pgport, g_conn = ConnectDatabase(g_fout, dbname, pghost, pgport,
username, force_password, ignore_version); username, force_password);
/* Set the client encoding if requested */ /* Set the client encoding if requested */
if (dumpencoding) if (dumpencoding)
...@@ -739,7 +745,6 @@ help(const char *progname) ...@@ -739,7 +745,6 @@ help(const char *progname)
printf(_("\nGeneral options:\n")); printf(_("\nGeneral options:\n"));
printf(_(" -f, --file=FILENAME output file name\n")); printf(_(" -f, --file=FILENAME output file name\n"));
printf(_(" -F, --format=c|t|p output file format (custom, tar, plain text)\n")); printf(_(" -F, --format=c|t|p output file format (custom, tar, plain text)\n"));
printf(_(" -i, --ignore-version ignore server version mismatch\n"));
printf(_(" -v, --verbose verbose mode\n")); printf(_(" -v, --verbose verbose mode\n"));
printf(_(" -Z, --compress=0-9 compression level for compressed formats\n")); printf(_(" -Z, --compress=0-9 compression level for compressed formats\n"));
printf(_(" --help show this help, then exit\n")); printf(_(" --help show this help, then exit\n"));
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* *
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_dumpall.c,v 1.103 2008/03/26 14:32:22 momjian Exp $ * $PostgreSQL: pgsql/src/bin/pg_dump/pg_dumpall.c,v 1.104 2008/04/13 03:49:22 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -60,7 +60,6 @@ static PQExpBuffer pgdumpopts; ...@@ -60,7 +60,6 @@ static PQExpBuffer pgdumpopts;
static bool output_clean = false; static bool output_clean = false;
static bool skip_acls = false; static bool skip_acls = false;
static bool verbose = false; static bool verbose = false;
static bool ignoreVersion = false;
static int disable_dollar_quoting = 0; static int disable_dollar_quoting = 0;
static int disable_triggers = 0; static int disable_triggers = 0;
...@@ -214,8 +213,7 @@ main(int argc, char *argv[]) ...@@ -214,8 +213,7 @@ main(int argc, char *argv[])
break; break;
case 'i': case 'i':
ignoreVersion = true; /* ignored, deprecated option */
appendPQExpBuffer(pgdumpopts, " -i");
break; break;
case 'l': case 'l':
...@@ -488,7 +486,6 @@ help(void) ...@@ -488,7 +486,6 @@ help(void)
printf(_("\nGeneral options:\n")); printf(_("\nGeneral options:\n"));
printf(_(" -f, --file=FILENAME output file name\n")); printf(_(" -f, --file=FILENAME output file name\n"));
printf(_(" -i, --ignore-version ignore server version mismatch\n"));
printf(_(" --help show this help, then exit\n")); printf(_(" --help show this help, then exit\n"));
printf(_(" --version output version information, then exit\n")); printf(_(" --version output version information, then exit\n"));
printf(_("\nOptions controlling the output content:\n")); printf(_("\nOptions controlling the output content:\n"));
...@@ -1391,21 +1388,19 @@ connectDatabase(const char *dbname, const char *pghost, const char *pgport, ...@@ -1391,21 +1388,19 @@ connectDatabase(const char *dbname, const char *pghost, const char *pgport,
exit(1); exit(1);
} }
/*
* We allow the server to be back to 7.0, and up to any minor release
* of our own major version. (See also version check in pg_dump.c.)
*/
if (my_version != server_version if (my_version != server_version
&& (server_version < 70000 /* we can handle back to 7.0 */ && (server_version < 70000 ||
|| server_version > my_version)) (server_version / 100) > (my_version / 100)))
{ {
fprintf(stderr, _("server version: %s; %s version: %s\n"), fprintf(stderr, _("server version: %s; %s version: %s\n"),
remoteversion_str, progname, PG_VERSION); remoteversion_str, progname, PG_VERSION);
if (ignoreVersion) fprintf(stderr, _("aborting because of server version mismatch\n"));
fprintf(stderr, _("ignoring server version mismatch\n"));
else
{
fprintf(stderr, _("aborting because of server version mismatch\n"
"Use the -i option to bypass server version check, but be prepared for failure.\n"));
exit(1); exit(1);
} }
}
/* /*
* On 7.3 and later, make sure we are not fooled by non-system schemas in * On 7.3 and later, make sure we are not fooled by non-system schemas in
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_restore.c,v 1.87 2008/03/26 14:32:22 momjian Exp $ * $PostgreSQL: pgsql/src/bin/pg_dump/pg_restore.c,v 1.88 2008/04/13 03:49:22 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -171,7 +171,7 @@ main(int argc, char **argv) ...@@ -171,7 +171,7 @@ main(int argc, char **argv)
opts->pghost = strdup(optarg); opts->pghost = strdup(optarg);
break; break;
case 'i': case 'i':
opts->ignoreVersion = 1; /* ignored, deprecated option */
break; break;
case 'l': /* Dump the TOC summary */ case 'l': /* Dump the TOC summary */
...@@ -378,7 +378,6 @@ usage(const char *progname) ...@@ -378,7 +378,6 @@ usage(const char *progname)
printf(_(" -d, --dbname=NAME connect to database name\n")); printf(_(" -d, --dbname=NAME connect to database name\n"));
printf(_(" -f, --file=FILENAME output file name\n")); printf(_(" -f, --file=FILENAME output file name\n"));
printf(_(" -F, --format=c|t specify backup file format\n")); printf(_(" -F, --format=c|t specify backup file format\n"));
printf(_(" -i, --ignore-version ignore server version mismatch\n"));
printf(_(" -l, --list print summarized TOC of the archive\n")); printf(_(" -l, --list print summarized TOC of the archive\n"));
printf(_(" -v, --verbose verbose mode\n")); printf(_(" -v, --verbose verbose mode\n"));
printf(_(" --help show this help, then exit\n")); printf(_(" --help show this help, then exit\n"));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment