博客
关于我
【mac】iTerm2中ssh保持连接不断开
阅读量:101 次
发布时间:2019-02-25

本文共 780 字,大约阅读时间需要 2 分钟。

iTerm2 SSH连接空闲断开问题解决方案

最近,我遇到了一个让人头疼的问题:使用iTerm2进行SSH连接时,空闲一段时间就会断开了。这个问题尤其是在开着vim的时候,突然被打断,回去后发现连接已经断了,真是让人抓狂。

问题分析

这个问题的根源在于服务器端将空闲连接断开。为了解决这个问题,我尝试了两种方法,分别是通过iTerm2的参数配置和通过客户端SSH配置的方法。

方法一:通过iTerm2参数配置

在iTerm2中进行如下设置:

  • 进入“Profiles”菜单。
  • 选择“Sessions”选项。
  • 在“When idle, send ASCII code”中设置一个ASCII码(例如,'a'对应的ASCII码97)。这样,iTerm2会在空闲时发送一个‘a’,保持连接。不过,这种方法在实际使用中存在一个问题:每次重新连接后,需要手动输入Escape字符,这在长时间使用中确实有些不便。
  • 方法二:通过客户端SSH配置

    这种方法更加可靠。只需在本地的~/.ssh/config文件中添加以下配置:

    Host *    ServerAliveInterval 30

    这个参数表示客户端每隔30秒会向远程服务器发送一个“no-op”包,防止服务器端关闭连接。这种配置简单且适用于多种连接场景。在实际使用中,这种方法表现稳定。

    补充说明

  • 单次连接:如果只需要一次连接,可使用参数选项-o实现:
    ssh -o ServerAliveInterval=30 user@host
  • 检查远程服务器配置:确保远程服务器没有设置相关限制。通过进一步调试,发现问题实际上是由Mac的WiFi连接中断引起的,而非SSH配置问题。
  • 总结

    通过客户端配置ServerAliveInterval,解决了iTerm2在空闲时断开的问题。这种方法简单且稳定,是目前为止最优的解决方案。

    转载地址:http://ubo.baihongyu.com/

    你可能感兴趣的文章
    Oracle 比较 B-tree 和 Bitmap 索引
    查看>>
    Oracle 注意点大全
    查看>>
    UML- 组件图(构件图)
    查看>>
    oracle 用户与锁
    查看>>
    oracle 由32位迁移到64位的问题
    查看>>
    oracle 监听器的工作原理
    查看>>
    oracle 行列转换
    查看>>
    oracle 行转列
    查看>>
    Oracle 表
    查看>>
    oracle 课堂笔记
    查看>>
    Oracle 返回结果集的 存储过程
    查看>>
    Oracle 递归
    查看>>
    Oracle 递归函数与拼接
    查看>>
    oracle 逻辑优化,提升高度,综合SQL上下文进行逻辑优化
    查看>>
    oracle 闪回关闭,关闭闪回即disable flashback的操作步骤
    查看>>
    oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
    查看>>
    oracle--用户,权限,角色的管理
    查看>>
    Oracle-定时任务-JOB
    查看>>
    oracle.dataaccess 连接池,asp.net使用Oracle.DataAccess.dll连接Oracle
    查看>>
    oracle00205报错,Oracle控制文件损坏报错场景
    查看>>