From: | "Euler Taveira" <euler(at)eulerto(dot)com> |
---|---|
To: | anatoli(at)rainforce(dot)org, pgsql-docs(at)lists(dot)postgresql(dot)org |
Subject: | Re: pg_isready docs doesn't specify what exactly it is checking |
Date: | 2022-01-07 00:29:16 |
Message-ID: | d42e67fa-57ca-412d-8055-dca522a091db@www.fastmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-docs |
On Tue, Jan 4, 2022, at 3:11 PM, PG Doc comments form wrote:
> `pg_isready` docs don't specify how its different from a port probe - what
> does on top of checking that a port is open? Does it send some handshake
> message that a server responds to when initialization is finished?
pg_isready uses a PQping function that reports the current Postgres status. The
main advantage of pg_isready is that it uses the Postgres protocol to report
the server status. A port probe is not a sufficient step to determine if the
server is running and accepting connections. Why? A Postgres server can be
running but in a state that disallows connections such as during a startup or
crash recovery phase. pg_isready is capable of reporting such state
(PQPING_REJECT -- 1) [1].
We could include a sentence explaining that a port probe is not a sufficient
condition to successfully connect to a Postgres server because the state
machine has more than 2 states. PQping [1] already states "reports the status
of the server" and describe each state it provides. Feel free to suggest an
improvement to documentation.
> People here are telling that `pg_isready` is not reliable and that
> `pg_isready` may return when database is not actually ready
> https://github.com/docker-library/postgres/issues/880#issuecomment-1004251102
> Without further info about `pg_isready` it is not clear if it should be
> filled as a bug. Or if it should be filled as a bug only when an
> initialization script is involved.
There is no known issues with pg_isready and that report isn't clear. He says
"database and/or user wasn't available". What's the exact error message? If
there is a reproducible test case, share it here.
[1] https://www.postgresql.org/docs/current/libpq-connect.html#LIBPQ-PQPINGPARAMS
--
Euler Taveira
EDB https://www.enterprisedb.com/
From | Date | Subject | |
---|---|---|---|
Next Message | Anatoli Babenia | 2022-01-07 00:50:13 | Re: pg_isready docs doesn't specify what exactly it is checking |
Previous Message | PG Doc comments form | 2022-01-06 17:38:41 | .pg_service.conf default location and default name on MS Windows platform |