Re: Reserved connections weird issue - Mailing list pgsql-admin

From Tom Lane
Subject Re: Reserved connections weird issue
Date
Msg-id 8022.1470333736@sss.pgh.pa.us
Whole thread Raw
In response to Reserved connections weird issue  (Petr Novak <petr.novak23@gmail.com>)
List pgsql-admin
Petr Novak <petr.novak23@gmail.com> writes:
> We're running legacy application (written in .NET) on several servers, it
> creates large number of connections to a PG cluster (9.3.10), running on
> CentOS 6. Lately the app team changed the deployment strategy in a way,
> that in peaks it generated almost twice as much connections as before.

> Strange thing is, that the connections filled all the way up to
> max_connections and started to block the new connections with:
> FATAL:  sorry, too many clients already

You were probably hitting the point at which the postmaster refused to
handle any more child processes at all, which is something like twice
the max_connections setting.  Ordinarily, this is not a problem because
child processes beyond max_connections will die quickly.  However, it
sounds like your app team did something to break authentication on the
client side, allowing new postmaster children to sit until they reached
the authentication_timeout, and thereby denying service altogether to
additional incoming connections.

> It surprised me, that it didn't kept the reserved connections for the
> superuser, as the application user is not superuser (got the Create DB
> though). So I couldn't connect to the server to find out, what is going on.
> I have verified that no superuser connections were on the server running in
> that time.

> In the process list majority of processes was in "authentication" state and
> they were not shown in the numbackends of the pg_stat_database view
> (collectd have had connections already established, so metrics were
> gathered)

If an incoming connection hasn't completed authentication yet, then we do
not know if it's for a database superuser, so it can't have any special
priority over other connections.

If you're worried about this case repeating, perhaps it'd help to lower
authentication_timeout to something tighter than the default; although
there's probably not very much you can do against an app that is willing
to flood the server with arbitrarily many connections.  Basically what
you got here is a self-DDOS scenario.

            regards, tom lane


pgsql-admin by date:

Previous
From: Petr Novak
Date:
Subject: Reserved connections weird issue
Next
From: Petr Novak
Date:
Subject: Re: Reserved connections weird issue