Re: New trigger option of pg_standby
От | Heikki Linnakangas |
---|---|
Тема | Re: New trigger option of pg_standby |
Дата | |
Msg-id | 4A0C7F96.2040407@enterprisedb.com обсуждение исходный текст |
Ответ на | Re: New trigger option of pg_standby (Simon Riggs <simon@2ndQuadrant.com>) |
Ответы |
Re: New trigger option of pg_standby
Re: New trigger option of pg_standby |
Список | pgsql-hackers |
I've finally committed Simon's recovery_end_command patch, as well as the changes to pg_standby. There's now smart and fast failover modes, chosen by the content of the trigger file, smart mode is the default. A "fast" trigger file is truncated, turning it into a "smart" trigger for subsequent pg_standby invocations. I believe this is now safe in all the combinations discussed, in both fast and smartmode, with or without extra WAL files copied to pg_xlog, and also if the last archived WAL file is incomplete. You now need to set up recovery_end_command to clean up the trigger file; pg_standby no longer does that automatically. Simon Riggs wrote: > On Fri, 2009-05-15 at 03:49 +0900, Fujii Masao wrote: >> Hi, >> >> On Fri, May 15, 2009 at 12:36 AM, Simon Riggs <simon@2ndquadrant.com> wrote: >>> On Wed, 2009-05-13 at 21:43 +0100, Simon Riggs wrote: >>>> On Wed, 2009-05-13 at 21:26 +0300, Heikki Linnakangas wrote: >>>> >>>>> This whole thing can be considered to be a new feature. >>>> recovery.conf will contain a new optional parameter: >>>> >>>> recovery_end_command (string) >>> Implemented. >>> + ereport(signaled ? FATAL : WARNING, >>> + (errmsg("recovery_end_command \"%s\": return code %d", >>> + xlogRecoveryEndCmd, rc))); >> In fast failover case, pg_standby has to delete the trigger file immediately >> if it's found. Otherwise, recovery may go wrong as I already described. >> http://archives.postgresql.org/pgsql-hackers/2009-04/msg01139.php >> >> So, in fast mode, recovery_end_command would always fail to delete the >> trigger file, and cause warning. This is odd behavior, I think. We should >> change WARNING to DEBUG2 like RestoreArchivedFile() in the above code? > > Using rm -f would avoid the WARNING. > > I'd rather keep it at WARNING, since not sure what command I'll be > running and what a non-zero rc means. > -- Heikki Linnakangas EnterpriseDB http://www.enterprisedb.com
В списке pgsql-hackers по дате отправления: