scp
当命令停止在 92%时,我正在两台远程机器之间传输文件。当我进去重试时,我意识到我无法再 ssh 进入服务器。但是,我确实可以通过我的服务器主机的 VNC 终端访问。
我尝试从主机的 Web 面板重新启动sshd
、执行systemctl reboot
和关闭/重新启动服务器,但我仍然无法通过 SSH 连接到服务器。我也检查过/var/log/auth.log
,它没有记录任何关于连接超时的信息。
我完全禁用了服务器防火墙(iptables),输出systemctl status sshd
显示它正在工作并在端口 22 上侦听。
输出iptables -L
:
Chain INPUT (policy ACCEPT)
Chain FORWARD (policy ACCEPT)
Chain OUTPUT (policy ACCEPT)
我已经能够从我的机器上很好地连接到其他服务器。我的 SSH 命令的输出-vvv
是:
OpenSSH_8.1p1, LibreSSL 2.7.3
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 47: Applying options for *
debug1: Connecting to <server-ip> port 22.
ssh: connect to host <server-ip> port 22: Operation timed out
此外,正如此处其他一些相关问题所述,我在端口 42 上手动启动 sshd/usr/sbin/sshd -p 42 -d
并尝试连接,但连接仍然从我的本地计算机超时,并且没有输出记录到终端。
根据评论中的建议,我ssh user@localhost
从我的 VNC 终端中运行,并且有效。所以看起来 ssh 正在为 localhost 工作,但没有其他用户可以从外部连接。似乎是防火墙问题,但我已经打开了所有 iptables 规则。
更新: SSH 随机开始工作了大约 30 分钟,没有任何变化。我能够复制我需要的文件。然后,不久之后,连接冻结并断开了我的连接,它又回到了无法工作的状态。
看起来像网络问题,
Operation timed out
通常意味着ssh
无法建立连接。您使用什么类型的主机?