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

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

在这里插入图片描述

1.概述

转载:

一、一个iTerm2蛋疼的问题

最近基友搞了台mbp,在装一些常用app时,跟我交流到一个情况:「用iTerm2进行ssh时,空闲了一段时间就会断掉了……」想来,这个情形也是之前总遇到的,尤其正开着vim开开心心的一把梭时,突然有产品汪跑来跟你沟通需求细节,等好不容易聊完,人家的需求有了,你TM代码呢?……于是又吭哧吭哧回到刚才的界面,正准备撸起袖子加油干,却发现冰冷的窗口上一点反应都没有了……

在这里插入图片描述

二、解决?解决!

看这情况,是服务器端把空闲连接给断开了。只能重新连接了。这么蛋疼,是该找点法子处理下了。

随手一搜,锦囊到手。

1、方案一(通过iTerm2参数配置)

刚接触iTerm2,用起来感觉还不错,就是不知道如何保持连接,让ssh不断线。 profiles -> sessions -> When idel, send ASCII code [1]

(我就不说这回答把「idle」都拼错了……-0-)

很快,按照设置,配好,验证,好了。

在这里插入图片描述

我配置的ASCII code是97,所以是一串aaaaaa,一看效果,果然没断。但是接着用了用,就发现有坑了……

在这里插入图片描述

在这里插入图片描述
开着vim,过了一段时间再回来时,这一长串aaaaaa……还要手工ESC,u一下,才恢复,而且指不定还会有其它副作用,实在蛋疼……

2、方案二(通过客户端ssh参数配置)

正确的做法是,通过配置 ServerAliveInterval 来实现,在 ~/.ssh/config 中加入: ServerAliveInterval=30[2]

ServerAliveInterval 30 #表示ssh客户端每隔30秒给远程主机发送一个no-op包,no-op是无任何操作的意思,这样远程主机就不会关闭这个SSH会话。[3]

好的,二话不说,马上改!

在这里插入图片描述

我只需要在当前用户的ssh连接调整就好(注意:是本地发起连接的客户端!并非修改所要连接的远程服务器端),那么vim ~/.ssh/config,然后新增

Host *    ServerAliveInterval 60

我觉得60秒就好了,而且基本去连的机器都保持,所以配置了*,如果有需要针对某个机器,可以自行配置为需要的serverHostName。

再经过最后的验证,方案二确实为最优选择。

三、补充

1、单次连接

若只是单次连接时需要,可使用-o参数实现: ssh -o ServerAliveInterval=30 user@host

2、罪魁祸首?

最后看下服务端的配置:

在这里插入图片描述

我去……结果发现服务端其实只是默认配置?并没有主动做什么限制,那这次问题的根源,其实只是因为Mac的wifi断开了造成的而已?并非ssh连接的问题吗?(wifi:这锅我不背……)

好吧,这个问题记下了,留着下次研究。 (果然发现,之前把问题想得太简单了,后面原来隐藏了这么个秘密……「」)

你可能感兴趣的文章
MySQL索引那些事:什么是索引?为什么加索引就查得快了?
查看>>
Mysql索引(1):索引概述
查看>>
Mysql索引(2):索引结构
查看>>
Mysql索引(3):索引分类
查看>>
Mysql索引(4):索引语法
查看>>
mysql级联删除_Mysql笔记系列,DQL基础复习,Mysql的约束与范式
查看>>
mysql练习语句
查看>>
mysql经常使用命令
查看>>
MySQL经常使用技巧
查看>>
mysql给root开启远程访问权限,修改root密码
查看>>
mysql给账号授权相关功能 | 表、视图等
查看>>
MySQL缓存使用率超过80%的解决方法
查看>>
Mysql缓存调优的基本知识(附Demo)
查看>>
mysql编写存储过程
查看>>
mysql网站打开慢问题排查&数据库优化
查看>>
mysql网络部分代码
查看>>
mysql联合索引 where_mysql联合索引与Where子句优化浅析
查看>>
mysql联合索引的最左前缀匹配原则
查看>>
MySQL聚簇索引
查看>>
mysql自动化同步校验_Shell: 分享MySQL数据同步+主从复制自动化脚本_20190313_七侠镇莫尛貝...
查看>>