From 370f770c15a4c08094298685887d8a512267c369 Mon Sep 17 00:00:00 2001 From: Heikki Linnakangas Date: Wed, 7 Apr 2010 06:12:52 +0000 Subject: [PATCH] Forbid using pg_xlogfile_name() and pg_xlogfile_name_offset() during recovery. We might want to relax this in the future, but ThisTimeLineID isn't currently correct in backends during recovery, so the filename returned was wrong. --- doc/src/sgml/func.sgml | 6 +++--- src/backend/access/transam/xlog.c | 14 +++++++++++++- 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/doc/src/sgml/func.sgml b/doc/src/sgml/func.sgml index 4aa78728e3..7a18c92d31 100644 --- a/doc/src/sgml/func.sgml +++ b/doc/src/sgml/func.sgml @@ -1,4 +1,4 @@ - + Functions and Operators @@ -13064,8 +13064,8 @@ SELECT set_config('log_statement_stats', 'off', false); The functions shown in assist in making on-line backups. - Use of the first three functions is restricted to superusers. The first - five functions cannot be executed during recovery. + These functions cannot be executed during recovery. + Use of the first three functions is restricted to superusers. diff --git a/src/backend/access/transam/xlog.c b/src/backend/access/transam/xlog.c index ce6d561d5b..592419d356 100644 --- a/src/backend/access/transam/xlog.c +++ b/src/backend/access/transam/xlog.c @@ -7,7 +7,7 @@ * Portions Copyright (c) 1996-2010, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $PostgreSQL: pgsql/src/backend/access/transam/xlog.c,v 1.389 2010/04/06 17:51:58 sriggs Exp $ + * $PostgreSQL: pgsql/src/backend/access/transam/xlog.c,v 1.390 2010/04/07 06:12:52 heikki Exp $ * *------------------------------------------------------------------------- */ @@ -8410,6 +8410,12 @@ pg_xlogfile_name_offset(PG_FUNCTION_ARGS) HeapTuple resultHeapTuple; Datum result; + if (RecoveryInProgress()) + ereport(ERROR, + (errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE), + errmsg("recovery is in progress"), + errhint("pg_xlogfile_name_offset() cannot be executed during recovery."))); + /* * Read input and parse */ @@ -8479,6 +8485,12 @@ pg_xlogfile_name(PG_FUNCTION_ARGS) XLogRecPtr locationpoint; char xlogfilename[MAXFNAMELEN]; + if (RecoveryInProgress()) + ereport(ERROR, + (errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE), + errmsg("recovery is in progress"), + errhint("pg_xlogfile_name() cannot be executed during recovery."))); + locationstr = text_to_cstring(location); if (sscanf(locationstr, "%X/%X", &uxlogid, &uxrecoff) != 2)