Keep-alive connections parameters ================================= PostgreSQL® keep-alive connection parameters are useful to manage Idle connections. The following is a reference to the default Aiven for PostgreSQL® parameters on the server side, and what keep-alive parameters can be used at the client side. Keep-alive server side parameters --------------------------------- Currently, the following default keep-alive timeouts are used on the `server-side `_: +---------------------------+-------+-----------------------------------------------------------------------+ | Parameter (server) | Value | Description | +===========================+=======+=======================================================================+ |``tcp_keepalives_idle`` |180 |Specifies the amount of time with no network activity after which the | | | |operating system should send a TCP ``keepalive`` message to the client.| +---------------------------+-------+-----------------------------------------------------------------------+ |``tcp_keepalives_count`` |6 |Specifies the number of TCP ``keepalive`` messages that can be lost | | | |before the server's connection to the client is considered dead. | +---------------------------+-------+-----------------------------------------------------------------------+ |``tcp_keepalives_interval``|10 |Specifies the amount of time after which a TCP ``keepalive`` message | | | |that has not been acknowledged by the client should be retransmitted. | +---------------------------+-------+-----------------------------------------------------------------------+ Keep-alive client side parameters --------------------------------- The `client-side `_ keep-alive parameters can be set to whatever values you want. +-----------------------+----------------------------------------------------------------------+ | Parameter (client) | Description | +=======================+======================================================================+ |``keepalives`` |Controls whether client-side TCP ``keepalives`` are used. | | |The default value is 1, meaning on. | +-----------------------+----------------------------------------------------------------------+ |``keepalives_idle`` |Controls the number of seconds of inactivity after which TCP should | | |send a ``keepalive`` message to the server. | +-----------------------+----------------------------------------------------------------------+ |``keepalive_count`` |Controls the number of TCP ``keepalives`` that can be lost before the | | |client's connection to the server is considered dead. | +-----------------------+----------------------------------------------------------------------+ |``keepalives_interval``|Controls the number of seconds after which a TCP ``keepalive`` message| | |that is not acknowledged by the server should be retransmitted. | +-----------------------+----------------------------------------------------------------------+ Even though TCP connections usually stay open for extended periods of time, you should also make sure that your applications can reconnect, since TCP connections are liable to break at times. Also, when reconnecting you should make sure that your client always resolves the DNS address on connection, since the underlying address will change during automatic failover when a primary node fails.