0

0

Linux SSH 会话频繁断开的排查方法

舞夢輝影

舞夢輝影

发布时间:2026-02-05 17:25:02

|

282人浏览过

|

来源于php中文网

原创

linux ssh 会话频繁断开的排查方法

SSH 连接被服务端主动断开的典型表现

你执行命令到一半,终端突然卡住几秒后显示 Connection closed by remote host 或直接断连,且本地 ssh 进程退出。这不是网络抖动导致的临时丢包,而是服务端(sshd)主动终止了连接。

根本原因通常是服务端设置了空闲超时策略。OpenSSH 默认启用 ClientAliveIntervalClientAliveCountMax 机制:若客户端在指定时间内未发任何数据包,sshd 会发送探测包;连续几次无响应就 kill 掉该连接。

常见错误配置包括:

  • ClientAliveInterval 0(禁用探测)但搭配了 TCPKeepAlive no,导致内核无法感知链路异常
  • ClientAliveInterval 60ClientAliveCountMax 3,意味着最多 3 分钟无交互就会断连
  • MaxStartupsMaxSessions 被设得过低,高并发时新连接被拒绝或旧连接被踢出

如何确认是服务端配置导致的断连

登录服务器后检查 /etc/ssh/sshd_config 中的关键项,并比对当前生效值:

运行 sudo sshd -T | grep -E "(clientalive|tcpkeepalive|maxstart|maxsess)" 获取实际加载的配置(注意:此命令需 root 权限,且不校验语法,仅输出合并后的结果)。

重点关注以下字段是否被显式修改过:

  • ClientAliveInterval:非零值即启用保活探测,单位秒
  • ClientAliveCountMax:默认 3,表示允许连续丢失多少次探测响应
  • TCPKeepAlive:设为 yes 可让内核在传输层维持连接,但对 NAT 网关不友好
  • MaxStartups:如设为 10:30:60 表示最多 10 个未认证连接,超过后按概率丢弃

如果发现 ClientAliveInterval 是 60、120 或其他较小值,基本可锁定问题来源。

秘塔写作猫
秘塔写作猫

秘塔写作猫是一个集AI写作、校对、润色、配图等为一体的创作平台

下载

客户端侧快速绕过断连的实操方式

无需改服务器配置,也能稳定长连接。在本地 SSH 客户端加保活参数即可:

  • 临时使用:ssh -o ServerAliveInterval=30 -o ServerAliveCountMax=3 user@host
  • 永久生效:编辑 ~/.ssh/config,加入对应 Host 块:
    Host myserver
    HostName 192.168.1.100
    User admin
    ServerAliveInterval 30
    ServerAliveCountMax 3
  • ServerAliveInterval 必须小于服务端的 ClientAliveInterval,否则探测包赶不上服务端判定节奏
  • 避免设 ServerAliveInterval 0 —— 这会禁用客户端保活,完全依赖服务端策略

注意:ServerAlive* 是客户端行为,只影响本机发起的连接;而 ClientAlive* 是服务端行为,影响所有接入的客户端。

排查 NAT 或中间设备干扰的必要步骤

即使服务端和客户端都配了保活,仍可能因路由器防火墙、云平台 SLB 清理空闲连接而断连。这类断连通常没有日志痕迹,且复现不稳定。

验证方法:

  • 在客户端执行 ping -i 30 target_ip 同时保持 SSH 连接,观察是否还断——若不断,说明是纯空闲导致;若仍断,大概率是中间设备干的
  • tcpdump -i any port 22 抓包,看最后收到的是否为 RST 或 FIN 包,以及源 IP 是否来自网关而非目标服务器
  • 云服务器(如阿里云、AWS)需检查安全组/网络 ACL 是否启用了“连接空闲超时”,该值常为 900 秒(15 分钟),且不可调

这种场景下,唯一可靠解法是客户端持续发送保活帧,ServerAliveInterval 建议设为 300(5 分钟)以内,避开中间设备阈值。

真正麻烦的是那些既没日志、又不回 RST 的“静默丢包”设备——它们会让 SSH 卡住几十秒才报错,此时必须结合 ConnectTimeout 和重试逻辑做容错,而不是指望一次配置解决所有问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1457

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

709

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

296

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

784

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

579

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

552

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

300

2023.07.20

linux查看cpu使用率
linux查看cpu使用率

在linux的系统维护中,可能需要经常查看cpu使用率,分析系统整体的运行情况。本专题为大家带来了linux查看cpu使用率的相关文章,感兴趣的朋友千万不要错过了。

387

2023.07.25

java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

4

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.5万人学习

Git 教程
Git 教程

共21课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号