博客
关于我
【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 DBA课程系列笔记(20)
    查看>>
    oracle dblink 创建使用 垮库转移数据
    查看>>
    oracle dblink结合同义词的用法 PLS-00352:无法访问另一数据库
    查看>>
    Oracle dbms_job.submit参数错误导致问题(ora-12011 无法执行1作业)
    查看>>
    oracle dg switchover,DG Switchover fails
    查看>>
    Oracle E-Business Suite软件 任意文件上传漏洞(CVE-2022-21587)
    查看>>
    Oracle EBS OPM 发放生产批
    查看>>
    Oracle EBS-SQL (BOM-15):检查多层BOM(含common BOM).sql
    查看>>
    Oracle EBS环境下查找数据源(OAF篇)
    查看>>
    oracle Extract 函数
    查看>>
    uni-app开发环境自动部署的一个误区(App running at...)
    查看>>
    Oracle GoldenGate Director安装和配置(无图)
    查看>>
    Oracle Goldengate在HP平台裸设备文件系统OGG-01028处理
    查看>>
    oracle instr函数详解
    查看>>
    Oracle Java所有版本的下载链接
    查看>>
    Oracle JDBC url的几种方式
    查看>>
    Oracle JDBC 连接卡死后 Connection Reset
    查看>>
    Oracle JDK vs OpenJDK
    查看>>
    ORACLE MERGE INTO (2)
    查看>>
    oracle ogg 单实例双向复制搭建(oracle-oracle)--Oracle GoldenGate
    查看>>