Greetings,

* Sergei Kornilov (s...@zsrv.org) wrote:
> Updated patch attached:
> - added testcase to verify database does not start with multiple recovery 
> targets
> - recovery_target = immediate was replaced with recovery_target_immediate 
> bool GUC

I'd encourage you to look through the diff after you're finished hacking
before sending it to the list, in case things get left in that should be
removed, as below...

> diff --git a/src/backend/access/transam/xlog.c 
> b/src/backend/access/transam/xlog.c
> index c80b14e..cd29606 100644
> --- a/src/backend/access/transam/xlog.c
> +++ b/src/backend/access/transam/xlog.c
> @@ -261,13 +261,21 @@ static bool restoredFromArchive = false;
>  static char *replay_image_masked = NULL;
>  static char *master_image_masked = NULL;
>  
> +/* recovery_target* original GUC values */
> +char *recovery_target_string;

This shouldn't be here now, should it?

> +char *recovery_target_xid_string;
> +char *recovery_target_time_string;
> +char *recovery_target_name_string;
> +char *recovery_target_lsn_string;

>  /* options formerly taken from recovery.conf for archive recovery */

Shouldn't all of the above be listed under this comment..?

>  char    *recoveryRestoreCommand = NULL;
>  char    *recoveryEndCommand = NULL;
>  char    *archiveCleanupCommand = NULL;
> -RecoveryTargetType recoveryTarget = RECOVERY_TARGET_UNSET;
> +static RecoveryTargetType recoveryTarget = RECOVERY_TARGET_UNSET;
>  bool         recoveryTargetInclusive = true;
>  int                  recoveryTargetAction = RECOVERY_TARGET_ACTION_PAUSE;
> +bool                 recoveryTargetImmediate;

Seems like this should, at least, be close to the char*'s that are
defining the other ways to specify a recovery targer.

>  TransactionId recoveryTargetXid;
>  TimestampTz recoveryTargetTime;
>  char    *recoveryTargetName;
> @@ -5381,9 +5389,42 @@ readRecoverySignalFile(void)
>  static void
>  validateRecoveryParameters(void)
>  {
> +     uint8 targetSettingsCount = 0;
> +
>       if (!ArchiveRecoveryRequested)
>               return;
>  
> +     /* Check for mutually exclusive target actions */
> +     if (recoveryTargetImmediate)
> +     {
> +             ++targetSettingsCount;
> +             recoveryTarget = RECOVERY_TARGET_IMMEDIATE;
> +     }
> +     if (strcmp(recovery_target_name_string, "") != 0)
> +     {
> +             ++targetSettingsCount;
> +             recoveryTarget = RECOVERY_TARGET_NAME;
> +     }
> +     if (strcmp(recovery_target_lsn_string, "") != 0)
> +     {
> +             ++targetSettingsCount;
> +             recoveryTarget = RECOVERY_TARGET_LSN;
> +     }
> +     if (strcmp(recovery_target_xid_string, "") != 0)
> +     {
> +             ++targetSettingsCount;
> +             recoveryTarget = RECOVERY_TARGET_XID;
> +     }
> +     if (strcmp(recovery_target_time_string, "") != 0)
> +     {
> +             ++targetSettingsCount;
> +             recoveryTarget = RECOVERY_TARGET_TIME;
> +     }
> +     if (targetSettingsCount > 1)
> +             ereport(FATAL,
> +                             (errcode(ERRCODE_INVALID_PARAMETER_VALUE),
> +                              errmsg("can not specify multiple recovery 
> targets")));

Doesn't look like you changed this based on my prior comment..?

Thanks!

Stephen

Attachment: signature.asc
Description: PGP signature

Reply via email to