On Tue, Apr 5, 2016 at 11:40 PM, Amit Kapila <amit.kapil...@gmail.com> wrote: > On Tue, Apr 5, 2016 at 3:15 PM, Fujii Masao <masao.fu...@gmail.com> wrote: >> >> On Tue, Apr 5, 2016 at 4:31 PM, Amit Kapila <amit.kapil...@gmail.com> >> wrote: >> > On Mon, Apr 4, 2016 at 1:58 PM, Fujii Masao <masao.fu...@gmail.com> >> > wrote: >> >> >> >> >> >> Thanks for updating the patch! >> >> >> >> I applied the following changes to the patch. >> >> Attached is the revised version of the patch. >> >> >> > >> > 1. >> > { >> > {"synchronous_standby_names", PGC_SIGHUP, REPLICATION_MASTER, >> > gettext_noop("List of names of potential synchronous standbys."), >> > NULL, >> > GUC_LIST_INPUT >> > }, >> > &SyncRepStandbyNames, >> > "", >> > check_synchronous_standby_names, NULL, NULL >> > }, >> > >> > Isn't it better to modify the description of synchronous_standby_names >> > in >> > guc.c based on new usage? >> >> What about "Number of synchronous standbys and list of names of >> potential synchronous ones"? Better idea? >> > > Looks good. > >> >> > 2. >> > pg_stat_get_wal_senders() >> > { >> > .. >> > /* >> > ! * Allocate and update the config data of synchronous replication, >> > ! * and then get the currently active synchronous standbys. >> > */ >> > + SyncRepUpdateConfig(); >> > LWLockAcquire(SyncRepLock, LW_SHARED); >> > ! sync_standbys = SyncRepGetSyncStandbys(); >> > LWLockRelease(SyncRepLock); >> > .. >> > } >> > >> > Why is it important to update the config with patch? Earlier also any >> > update to config between calls wouldn't have been visible. >> >> Because a backend has no chance to call SyncRepUpdateConfig() and >> parse the latest value of s_s_names if SyncRepUpdateConfig() is not >> called here. This means that pg_stat_replication may return the >> information >> based on the old value of s_s_names. >> > > Thats right, but without this patch also won't pg_stat_replication can show > old information? If no, why so?
Without the patch, when s_s_names is changed and SIGHUP is sent, a backend calls ProcessConfigFile(), parse the configuration file and set the global variable SyncRepStandbyNames to the latest value of s_s_names. When pg_stat_replication is accessed, a backend calculates which standby is synchronous based on that latest value in SyncRepStandbyNames, and then displays the information of sync replication. With the patch, basically the same steps are executed when s_s_names is changed. But the difference is that, with the patch, SyncRepUpdateConfig() must be called after ProcessConfigFile() is called before the calculation of sync standbys. So I just added the call of SyncRepUpdateConfig() to pg_stat_get_wal_senders(). BTW, we can move SyncRepUpdateConfig() just after ProcessConfigFile() from pg_stat_get_wal_senders() and every backends always parse the value of s_s_names when the setting is changed. >> > 3. >> > <title>Planning for High Availability</title> >> > >> > <para> >> > ! <varname>synchronous_standby_names</> specifies the number of >> > ! synchronous standbys that transaction commits made when >> > >> > Is it better to say like: <varname>synchronous_standby_names</> >> > specifies >> > the number and names of >> >> Precisely s_s_names specifies a list of names of potential sync standbys >> not sync ones. >> > > Okay, but you doesn't seem to have updated this in your latest patch. I applied the change you suggested, to the patch. Thanks! Regards, -- Fujii Masao -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers