阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Linux系统入门学习:如何修复“sshd error: could not load host key”

103次阅读
没有评论

共计 1852 个字符,预计需要花费 5 分钟才能阅读完成。

问题 :当我尝试 SSH 到一台远程服务器时,SSH 客户端登陆失败并提示“Connection closed by X.X.X.X”。在 SSH 服务器那端,我看到这样的错误消息:“sshd error: could not load host key.”。这发生了什么问题,我怎样才能修复该错误?

该 SSH 连接错误的详细症状如下。

SSH 客户端方面 :当你尝试 SSH 到一台远程主机时,你没有看见登录屏幕,你的 SSH 连接就立即关闭,并提示此消息:“Connection closed by X.X.X.X”。

SSH 服务器方面 :在系统日志中,你看到如下错误消息(如,在 Debian/Ubuntu 上,/var/log/auth.log)。

  1. Oct1608:59:45 openstack sshd[1214]: error:Couldnot load host key:/etc/ssh/ssh_host_rsa_key
  2. Oct1608:59:45 openstack sshd[1214]: error:Couldnot load host key:/etc/ssh/ssh_host_dsa_key
  3. Oct1608:59:45 openstack sshd[1214]: error:Couldnot load host key:/etc/ssh/ssh_host_ecdsa_key
  4. Oct1608:59:45 openstack sshd[1214]: fatal:No supported key exchange algorithms [preauth]

导致该问题的根源是,sshd 守护进程不知怎么地不能加载 SSH 主机密钥了。

当 OpenSSH 服务器第一次安装到 Linux 系统时,SSH 主机密钥应该会自动生成以供后续使用。如果,不管怎样,密钥生成过程没有成功完成,那就会导致这样的 SSH 登录问题。

Linux 系统入门学习:如何修复“sshd error: could not load host key”

让我们检查能否在相应的地方找到 SSH 主机密钥。

  1. $ ls al /etc/ssh/ssh*key

Linux 系统入门学习:如何修复“sshd error: could not load host key”

如果 SSH 主机密钥在那里找不到,或者它们的大小被截断成为 0(就像上面那样),你需要从头开始重新生成主机密钥。

重新生成 SSH 主机密钥

在 Debian、Ubuntu 或其衍生版上,你可以使用 dpkg-reconfigure 工具来重新生成 SSH 主机密钥,过程如下:

  1. $ sudo rm r /etc/ssh/ssh*key
  2. $ sudo dpkgreconfigure opensshserver

Linux 系统入门学习:如何修复“sshd error: could not load host key”

在 CentOS、RHEL 或 Fedora 上,你所要做的是,删除现存(有问题的)密钥,然后重启 sshd 服务。

  1. $ sudo rm r /etc/ssh/ssh*key
  2. $ sudo systemctl restart sshd

另外一个重新生成 SSH 主机密钥的方式是,使用 ssh-keygen 命令来手动生成。

  1. $ sudo sshkeygen t rsa f /etc/ssh/ssh_host_rsa_key
  2. $ sudo sshkeygen t dsa f /etc/ssh/ssh_host_dsa_key
  3. $ sudo sshkeygen t ecdsa f /etc/ssh/ssh_host_ecdsa_key

Linux 系统入门学习:如何修复“sshd error: could not load host key”

在生成新的 SSH 主机密钥后,确保它们能在 /etc/ssh 目录中找到。此时,不必重启 sshd 服务。

  1. $ ls al /etc/ssh/ssh*key

现在,再试试 SSH 到 SSH 服务器吧,看看问题是否已经离你而去了。

CentOS 6.0 下 SSH 免密码登录配置 http://www.linuxidc.com/Linux/2013-03/80488.htm

提高 Ubuntu 的 SSH 登陆认证速度的办法 http://www.linuxidc.com/Linux/2014-09/106810.htm

开启 SSH 服务让 Android 手机远程访问 Ubuntu 14.04  http://www.linuxidc.com/Linux/2014-09/106809.htm

如何为 Linux 系统中的 SSH 添加双重认证 http://www.linuxidc.com/Linux/2014-08/105998.htm

在 Linux 中为非 SSH 用户配置 SFTP 环境 http://www.linuxidc.com/Linux/2014-08/105865.htm

Linux 上 SSH 服务的配置和管理 http://www.linuxidc.com/Linux/2014-06/103627.htm

SSH 入门学习基础教程 http://www.linuxidc.com/Linux/2014-06/103008.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-20发表,共计1852字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中