powershell 连接端口超时
linux运维,超时连接配置tmout和sshd_config中ClientAliveInterval参数配置有何区别?
linux运维,超时连接配置tmout和sshd_config中ClientAliveInterval参数配置有何区别?
回答行业问题
这个其实是shell环境和ssh会话的问题,问题看似简单,其实说起来,话题很长。
首先解答问题中两者的区别,然后对ssh会话和shell环境的关系、ssh会话和会话超时之间展开说明。
TMOUT是shell环境下的变量,从名字就可以看出是控制超时时间的,ClientAliveInterval参数是sshd服务会话连接保活的参数。
前者是超时时间,后者是保活连接,看似是一个很对立的关系,但是它们之间,首先来说一下它们的区别。
两者区别shell空闲等待时间TMUOT变量
TMOUT是shell环境下的一个环境变量,它控制shell环境系统空闲等待时间。一般配置在/etc/profile文件当中,Linux系统默认不配置TMOUT环境变量的值。
当TMOUT的值大于0时,比如为10,shell进空闲等待当终端超过10秒没所有输入,bash将关闭当前shell环境,终端连接断开,长时间离开电脑后断开终端连接,对服务器也是一种保护。
从上图可以看出,配置TMOUT环境的值变量为10之后,ssh终端就自动断开了。
ClientAliveInterval sshd服务保活参数
这个参数和ClientAliveCountMax参数配合使用,sshd服务配置这两个参数之后,比如ClientAliveInterval 300、ClientAliveCountMax 3。sshd服务会每隔300秒会给客户端发送心跳包,当客户端没有响应时会进行3次重试,重试后依然没有响应,断开ssh连接。
到这里就看出它们的区别了,TMOUT是控制shell环境虚拟终端层面,当终端没有输入时,多长时间断开终端。而ClientAliveInterval参数是控制sshd服务和ssh客户端之间,没有网络通信时多长时间断开和客户端的连接。
总是说shell环境和sshd服务,那它们之间有什么关系呢?继续往下。
shell环境和sshd服务的关系现在使用的的终端工具比如xshell、putty、CRT等都集成了ssh客户端,当终端发起ssh请求和sshd服务建立连接,并且通过验证,这时sshd服务将创建一个会话,然后调用系统接口创建一个新的pts字符设备文件,同时sshd服务会创建一个shell环境。
最后将ssh会话和pts字符设备文件绑定,字符设备文件再和和shell绑定,这样就创建了ssh会话和shell环境的连接。
当终端输入命令时,首先会将数据通过ssh协议发送给sshd服务,sshd将数据发送给对应的会话,会话将数据发送给pst字符设备文件,字符设备文件将数据最终转发到shell环境。
shell处理完命令请求,然后依次shell--pts符号设备文件--ssh会话--终端工具,这样就完成了终端界面,控制Linux shell的过程。
从上面的阐述可以得出,shell是sshd服务创建的,但是它们又是独立的,通过pts字符设备文件联系在一起。
ssh会话保活和自动超时平时使用ssh工具连接linux服务器时,总是超时,这时就可以配置sshd服务定时进行心跳检测,防止通信超时断开。
现在ssh工具也都具备网络保活的功能,也可以通过设置客户端程序来进行连接保活,原理和sshd服务一样,定期发送心跳包。
对于安全比较重视的人来说,这样显然是不合理的,这时就可以设置shell环境变量TMOUT定义系统空闲等待时间,在不使用终端时自动断开。
这里一直是在说超时,那么什么都不配置,ssh会话为什么超时了?继续往下看。
ssh会话为什么会超时?ssh会话属于TCP长连接,linux系统定义了TCP长连接的超时时间,一般是7200秒,也就是两个小时,长连接达到这个时间就会发起心跳包,检测TCP连接,但是在实际场景到不了这个时间就会断开,比如NAT环境。
ipv4地址有限,我们的上网环境一般都在NAT路由设备后面,NAT路由维护着一张NAT表,当tcp连接长时间没有数据通信,NAT路由就会将这个连接从NAT表中移除,这会引起ssh会话就中断超时。
NAT超时时间远远达不到两个小时,所以TCP长连接如果没有心跳,很容易出现超时现象,再有就是网络不稳定,也会造成连接断开。
总结,我们从最初的shell环境变量TMOUT出发,将shell和sshd服务进行关联,介绍了它们之间的关系,引出了shell环境超时和sshd服务超时,并说明了自动超时和保活会话的应用,最后解释了服务超时的原因,环环相连,到这里我想对于ssh会话已经有了基本了解。
以上回答希望能够帮助到你,欢迎大家评论留言。
如何学习嵌入式?
1)先选择一个主流的平台,比如NXP ,买一块好的厂家(用户多,资料多、技术支持好)的开发板。
2)对照着提供的实验动手操作
建议
i) 初学者先做应用层,以完成某个应用功能为导向。不要过早的陷入到某个具体的不懂的知识点中,因为Linux太复杂深奥了,你想完全的搞明白一个知识点太难了。
ii) 随着逐步的熟悉,可以慢慢的去了解和学习驱动、移植、裁剪等相关内容