Petr Novak <petr.novak23@xxxxxxxxx> 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 -- Sent via pgsql-admin mailing list (pgsql-admin@xxxxxxxxxxxxxx) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-admin