Re: Patch: Implement failover on libpq connect level.
От | Robert Haas |
---|---|
Тема | Re: Patch: Implement failover on libpq connect level. |
Дата | |
Msg-id | CA+TgmoZr4kVoHkrio1rRLkBuGJva5WFhoHBxOa8ruozpEEFO6w@mail.gmail.com обсуждение исходный текст |
Ответ на | Re: Patch: Implement failover on libpq connect level. (Catalin Iacob <iacobcatalin@gmail.com>) |
Список | pgsql-hackers |
On Tue, Nov 15, 2016 at 12:53 PM, Catalin Iacob <iacobcatalin@gmail.com> wrote: > On Tue, Nov 15, 2016 at 5:58 PM, Robert Haas <robertmhaas@gmail.com> wrote: >> On Tue, Nov 15, 2016 at 9:42 AM, Alvaro Herrera >> <alvherre@2ndquadrant.com> wrote: >>> I would rather come up with something that works in both cases that we >>> can extend internally later, say pg_is_primary_node() or something like >>> that instead; and we implement it initially by returning the inverse of >>> pg_is_in_recovery() for replicated non-logical flocks, while we figure >>> out what to do in logical replication. Otherwise it will be harder to >>> change later if we embed it in libpq, and we may be forced into >>> supporting nonsensical situations such as having pg_is_in_recovery() >>> return true for logical replication primary nodes. >> >> I don't think we'll be backed into a corner like that, because we can >> always make this contingent on server version. libpq will have that >> available. > > But even with server version checking code, that code will be inside > libpq so there will be old libpq versions in the field that won't know > the proper query to send to new server versions. Good point. pg_is_writable_node() sounds good, then, and we can still send pg_is_in_recovery() if we're connected to a pre-10 version. -- Robert Haas EnterpriseDB: http://www.enterprisedb.com The Enterprise PostgreSQL Company
В списке pgsql-hackers по дате отправления: