如何保持 SSH 会话不中断?

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

哈喽大家好我是咸鱼

不知道小伙伴们有没有遇到过下面的情况

使用终端XShell、secureCRT 或 MobaXterm 等登录 Linux 服务器之后如果有一段时间没有进行交互SSH 会话就会断开
在这里插入图片描述
如果正在执行一些非后台命令SSH 会话断开就可能会使得这些命令可能会被中断导致任务无法完成

那如何保持 SSH 会话不中断呢我们来看一下

原文链接https://linuxiac.com/how-to-keep-ssh-session-alive/

为什么 SSH 会关闭连接

简短的回答是这一切都归结为 TCP 超时。

TCP 超时时间是指 TCP 连接或网络操作在认为进程失败之前等待响应的时间

在 Linux 中TCP 超时时间设置确定了 TCP 连接或操作在丢包或者连接无响应前应该等待多长时间

TCP 超时机制确保了网络通信的可靠性和效率

在保持 SSH 会话的情况下有三个关键的系统参数我们需要注意

  • tcp_keepalive_time在空闲 TCP 连接上发送 TCP keepalive 探针的间隔时间即使在没有实际数据传输的情况下。TCP keepalive 探针用于检测远程主机是否仍然存活和响应
  • tcp_keepalive_probesTCP keepalive 探针由 TCP 端发送的数据包用于检查空闲连接中远端的运行状况和响应性。有助于检测远程主机是否变得不可访问或者连接是否由于网络问题而丢失
  • tcp_keepalive_intvl控制发送空闲 TCP 连接的 keepalive 探针的时间间隔

我们可以通过下面的命令来查看上面三个参数的值

[root@localhost ~]# cat /proc/sys/net/ipv4/tcp_keepalive_time
600

[root@localhost ~]# cat /proc/sys/net/ipv4/tcp_keepalive_probes
9

[root@localhost ~]# cat /proc/sys/net/ipv4/tcp_keepalive_intvl
75

tcp_keepalive_time 为 600 表示保持 TCP 连接时间为 600s 或 10 分钟但是这并不意味着我们的 SSH 会话就真的会保持 10 分钟

因为 tcp_keepalive_probes 为 9 和 tcp_keepalive_intvl 为 75 表示系统会每隔 75s 发送 9 个探测包总计 675 s之后会话将会被视为失败然后关闭

也就是说在 675s 后SSH 会话将在不活动时终止即没有在终端中输入内容

如何保持 SSH 会话

保持 SSH 会话是一个涉及 client 和 server 配置的过程

Linux client 配置

对于 Linux client 我们在家目录下修改 ~/.ssh/config 文件如果没有就创建

vim  ~/.ssh/config

下面是配置

Host *
ServerAliveInterval 120
ServerAliveCountMax 30
  • Host配置仅对 “Host” 关键字后面列出的主机生效。由于使用了通配符 *因此它们适用于所有主机
  • ServerAliveInterval设置超时间隔(以秒为单位)如果没有从 server 接收到数据SSH 将通过加密通道发送消息请求 server 响应。默认值为 0表示不会将这些消息发送到 server
  • ServerAliveCountMax设置在 SSH 没有收到任何消息的情况下向 server 发送keepalive 消息的数量。如果达到了该阈值SSH 将断开与 server 的连接终止会话默认值为 3

表示 client 每 120s 向 server 发送 keepalive 消息一共发送 30 次也就是 120 * 30 = 3600 s一个小时在这一个小时内 SSH 会话会一直保持

Windows client 配置

对于 Windows 而言我们一般使用终端来访问 server

以 secureCRT 为例

选项——>会话选项
在这里插入图片描述
然后点击【终端】
在这里插入图片描述
Linux server 配置

上面介绍的是 client 端的配置我们接下来介绍 server 端的配置

修改 /etc/ssh/sshd_config 文件

vim /etc/ssh/sshd_config
TCPKeepAlive yes
ClientAliveInterval 120 
ClientAliveCountMax 30
  • TCPKeepAlive是否应该向 client 发送 TCP keepalive 信息
  • ClientAliveInterval设置超时间隔(以秒为单位)如果没有从 client 接收到数据SSH 将通过加密通道发送消息请求 client 响应。默认值为 0表示不会将这些消息发送到 client
  • ClientAliveCountMax设置在 SSH 没有收到任何消息的情况下向 client 发送keepalive 消息的数量。如果达到了该阈值SSH 将断开与 client 的连接终止会话默认值为 3

与前面讲到的 Linux client 配置一样server 将保持 SSH 会话一个小时120 * 30 = 3600s

配置之后重启 SSH 服务

systemctl restart sshd
阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6