A Practical Guide to Disabling SSH Timeout

As we delve into the world of network administration, we frequently encounter SSH (Secure Shell) for secure data communication, remote command-line login, remote command execution, and other secure network services between two networked computers. SSH provides robust authentication and secure data communication over insecure channels, making it a favorite among system administrators.

However, one frequently faced challenge in this domain is SSH timeouts. Let’s decode what it is and how to disable it for seamless and continuous connections.

Understanding SSH Timeout

SSH Timeout, as the name implies, refers to the idle time after which the SSH server ends an SSH session. This is a safety feature that can prevent potential security risks associated with leaving an unattended SSH session open.

However, this could be a nuisance for network administrators who need to keep the SSH sessions active for extended periods. The server abruptly disconnecting due to inactivity could disrupt ongoing tasks or result in lost data. This is where disabling SSH timeout becomes necessary.

Disabling SSH Timeout

There are two primary methods to prevent SSH timeouts: modifying server configurations and modifying client configurations. Here’s how you can implement each:

Server-Side Configuration

Step 1: Open the SSH daemon configuration file on your server using a text editor. The file is usually located at `/etc/ssh/sshd_config`.

sudo nano /etc/ssh/sshd_config 

Step 2: Find the following lines:

ClientAliveInterval 0
ClientAliveCountMax 3

The `ClientAliveInterval` specifies the duration in seconds that the server waits before it sends a null packet to the client, aiming to sustain the active connection. On the other hand, `ClientAliveCountMax` represents the maximum count of unanswered keep-alive messages that the server can send to the client before it considers the connection as unresponsive. If the client fails to respond beyond this limit, SSH will sever the connection, thus ending the session.

Step 3: Modify these lines to set the timeout period. For example, if you want the timeout to be 2 hours, set the `ClientAliveInterval` to 7200 (seconds) and `ClientAliveCountMax` to 3. The changes imply that the server will send a keep-alive message every 2 hours and disconnect if it does not receive any response after three consecutive requests.

ClientAliveInterval 7200
ClientAliveCountMax 3

Step 4: Save and close the file.

Step 5: Restart the SSH service to apply the changes.

sudo systemctl restart sshd 

Client-Side Configuration

Step 1: Open the SSH client configuration file. The file is typically located at `~/.ssh/config`. If it doesn’t exist, you can create it.

nano ~/.ssh/config 

Step 2: Add the following lines to set the keepalive interval:

Host *
ServerAliveInterval 60

This configuration means the client will send a keepalive message to the server every 60 seconds to keep the connection alive.

Step 3: Save and close the file.

Now, your client will automatically send these keep-alive messages to prevent the server from timing out.

Remember that server-side configurations will apply to all clients connecting to that server, while client-side configurations only apply to that specific client.


Disabling SSH timeout can significantly reduce disruptions during your network operations, ensuring smooth and continuous connections for your tasks. However, remember that this feature also serves a security function, so ensure to implement it wisely and maintain regular monitoring to avoid potential risks.

Understanding the SSH timeout mechanism and effectively managing it will go a long way in enhancing your efficiency as a network administrator.

The post A Practical Guide to Disabling SSH Timeout appeared first on TecAdmin.

Connection Timeout Linux System Administration openssh server SSH SSH Server TecAdmin