ssh 报Connection closed by 127.0.0.1 port 的解决办法

2022-11-09 14:54:45 浏览数 (1)

大家好,又见面了,我是你们的朋友全栈君。

起了一个虚拟机,想要通过ssh从host连接。

起虚拟机时加上如下命令行:

-netdev user,id=net0,hostfwd=tcp::2222-:22 -device virtio-net-pci,netdev=net0

这样就将host的2222端口转发给虚拟机的22端口。

ssh root@localhost -p 2222

得到Connection closed by 127.0.0.1 port 2222的错误。可能的问题在于:

1 虚拟机里的sshd服务没有正常运行,可通过命令查看systemctl status ssh, 如果没有开启就使用命令:systemctl start ssh

2网络端口没有正常监听,在host上使用命令:netstat -nlt 查看是不是存在0.0.0.0:2222的类似条目。

3虚拟机的ssh配置问题。

我在虚拟机中运行systemctl status ssh,得到一大堆error

Jan 10 03:49:56 ubuntu sshd[1195]: error: key_load_private: invalid format Jan 10 03:49:56 ubuntu sshd[1195]: error: key_load_public: invalid format Jan 10 03:49:56 ubuntu sshd[1195]: error: Could not load host key: /etc/ssh/ssh_ Jan 10 03:49:56 ubuntu sshd[1195]: error: key_load_private: invalid format Jan 10 03:49:56 ubuntu sshd[1195]: error: key_load_public: invalid format Jan 10 03:49:56 ubuntu sshd[1195]: error: Could not load host key: /etc/ssh/ssh_ Jan 10 03:49:56 ubuntu sshd[1195]: error: key_load_private: invalid format Jan 10 03:49:56 ubuntu sshd[1195]: error: key_load_public: invalid format Jan 10 03:49:56 ubuntu sshd[1195]: error: Could not load host key: /etc/ssh/ssh_ Jan 10 03:49:56 ubuntu sshd[1195]: fatal: No supported key exchange algorithms [

这是我在host连接虚拟机的时候sshd端报出的错误日志。这些文件都存在于/etc/ssh/ 下面,

参照Google的办法:

代码语言:javascript复制
sudo rm /etc/ssh/ssh_host_*
sudo dpkg-reconfigure openssh-server

注意这是在虚拟机中的操作。

接着就可以在host上ssh上虚拟机了。

另外ssh -v ip是一个不错的调试工具,可以打出ssh连接的日志。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/189482.html原文链接:https://javaforall.cn

0 人点赞