summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/bin/pg_basebackup/pg_createsubscriber.c19
1 files changed, 14 insertions, 5 deletions
diff --git a/src/bin/pg_basebackup/pg_createsubscriber.c b/src/bin/pg_basebackup/pg_createsubscriber.c
index d29407413d9..9fa5caaf91d 100644
--- a/src/bin/pg_basebackup/pg_createsubscriber.c
+++ b/src/bin/pg_basebackup/pg_createsubscriber.c
@@ -26,6 +26,7 @@
#include "fe_utils/recovery_gen.h"
#include "fe_utils/simple_list.h"
#include "fe_utils/string_utils.h"
+#include "fe_utils/version.h"
#include "getopt_long.h"
#define DEFAULT_SUB_PORT "50432"
@@ -407,7 +408,8 @@ static void
check_data_directory(const char *datadir)
{
struct stat statbuf;
- char versionfile[MAXPGPATH];
+ uint32 major_version;
+ char *version_str;
pg_log_info("checking if directory \"%s\" is a cluster data directory",
datadir);
@@ -420,11 +422,18 @@ check_data_directory(const char *datadir)
pg_fatal("could not access directory \"%s\": %m", datadir);
}
- snprintf(versionfile, MAXPGPATH, "%s/PG_VERSION", datadir);
- if (stat(versionfile, &statbuf) != 0 && errno == ENOENT)
+ /*
+ * Retrieve the contents of this cluster's PG_VERSION. We require
+ * compatibility with the same major version as the one this tool is
+ * compiled with.
+ */
+ major_version = GET_PG_MAJORVERSION_NUM(get_pg_version(datadir, &version_str));
+ if (major_version != PG_MAJORVERSION_NUM)
{
- pg_fatal("directory \"%s\" is not a database cluster directory",
- datadir);
+ pg_log_error("data directory is of wrong version");
+ pg_log_error_detail("File \"%s\" contains \"%s\", which is not compatible with this program's version \"%s\".",
+ "PG_VERSION", version_str, PG_MAJORVERSION);
+ exit(1);
}
}