问题描述win7 32bit+cygwin ,安装好ssh后能正常开启sshd服务,ssh hostname正常,但是ssh localhost出现 ssh_exchange_identification: Connection closed by remote host,
还有的说修改/etc/host.allow,/etc/host.deny,应该是linux下面出现这种问题的解决办法之一,由于我用的cygwin,根本没有这两个文件,此方案不再讨论。
参考上述链接中的内容,是将hosts文件中的内容全部注释掉,这样确实可行,但是把127.0.0.1跟localhost的绑定也注释掉啦。其实可以将hosts文件中保留两行内容:
127.0.0.1 localhost ::1 localhost
这样就可以解决问题,::1 是ipv6的回环地址,相当于ipv4中的127.0.0.1。
我的个人理解是:win7系统解析主机名的时候默认使用ipv6地址,可以尝试ping自己的计算机名,默认返回的地址就是IPV6的,除非我们强制使用 ping -4 计算机名 会返回IPV4的地址。如果没有显式绑定localhost,则默认解析为::1,所以,当我们注释掉hosts文件中的所有内容后,ssh localhost可用,但是当我们显式绑定localhost 127.0.0.1的时候,localhost就没有对应的IPV6地址,此时 ssh 就会出现上述问题。
(总觉得应该还有深层次的原因!因为ssh 找不到对应的ipv6 地址时也没有报找不到主机的错误)