记录下ubuntu20.4 连接Xshell的shh以及远程VScodes时的问题

首先进行验证Xshell连接ssh,如下三个原因

原因1:首先是虚拟机上的ssh服务没有安装好

安装openssh-server

apt install openssh-server

没有安装成功,并且收到如下提示:

下列软件包有未满足的依赖关系:
 openssh-server : 依赖: openssh-client (= 1:8.2p1-4)
                  依赖: openssh-sftp-server
                  推荐: ssh-import-id 但是它将不会被安装
E: 无法修正错误,因为您要求某些软件包保持现状,就是它们破坏了软件包间的依赖关系。

解决办法:

 这是因为openssh-server是依赖于openssh-client的,ubuntu20.4自带的openssh-client与所要安装的openssh-server所依赖的版本不同,这里所依赖的版本是1:8.2p1-4

所以要安装对应版本的,来降级覆盖自带的

apt-get install openssh-client=1:8.2p1-4

返回信息

正在读取软件包列表... 完成
正在分析软件包的依赖关系树       
正在读取状态信息... 完成       
建议安装:
  keychain libpam-ssh monkeysphere ssh-askpass
下列软件包将被【降级】:
  openssh-client
升级了 0 个软件包,新安装了 0 个软件包,降级了 1 个软件包,要卸载 0 个软件包,有 14 个软件包未被升级。
需要下载 674 kB 的归档。
解压缩后会消耗 0 B 的额外空间。
您希望继续执行吗? [Y/n] y
获取:1 http://archive.ubuntu.com/ubuntu focal/main amd64 openssh-client amd64 1:8.2p1-4 [674 kB]
已下载 674 kB,耗时 4秒 (185 kB/s)      
dpkg: 警告: 即将把 openssh-client 从 1:8.2p1-4ubuntu0.1 降级到 1:8.2p1-4
(正在读取数据库 ... 系统当前共安装有 188187 个文件和目录。)
准备解压 .../openssh-client_1%3a8.2p1-4_amd64.deb  ...
正在解压 openssh-client (1:8.2p1-4) 并覆盖 (1:8.2p1-4ubuntu0.1) ...
正在设置 openssh-client (1:8.2p1-4) ...
正在处理用于 man-db (2.9.1-1) 的触发器 ...

 然后再装openssh

apt-get install openssh-server

验证是否安装

dpkg -l |grep ssh
i  libssh-4:amd64                             0.9.3-2ubuntu2.1                                       amd64        tiny C SSH library (OpenSSL flavor)
ii  openssh-client                             1:8.2p1-4                                              amd64        secure shell (SSH) client, for secure access to remote machines
ii  openssh-server                             1:8.2p1-4                                              amd64        secure shell (SSH) server, for secure access from remote machines
ii  openssh-sftp-server                        1:8.2p1-4                                              amd64        secure shell (SSH) sftp server module, for SFTP access from remote machines
ii  python3-paramiko                           2.6.0-2                                                all          Make ssh v2 connections (Python 3)
ii  ssh-import-id                              5.10-0ubuntu1                                          all          securely retrieve an SSH public key and install it locally

 验证是否运行

ps -e |grep ssh
  16583 ?        00:00:00 ssh-agent
  69385 ?        00:00:00 sshd

原因2:ssh启动失败(sshd: no hostkeys available)

重置证书

进入日志中提到的/etc/ssh文件夹进行操作

cd /etc/ssh

 将ssh_host开头的文件全部移动到一个备份文件中(也可以直接删除)。
注意:某些教程上说可以修改权限,但那很有可能解决不了问题,还不如直接重新生成。

mkdir backup
mv ssh_host* backup

生成新 的证书

ssh-keygen -A

 重新启动,并查看状态

systemctl start sshd.service
systemctl status sshd.service

原因3:使用xshell连接出现下面问题

Xshell5不行,需要安装Xshell7即可。官网下载安装就OK

二、然后使用VScode连接

,出现下面问题Host key verification failed,解决如下

又出现下面问题

清理缓存:删除known.hosts中的虚拟机对应ip,然后重新连接vscode

 注意连接vscode的时候看命令行提示,输入密码操作

以上记录,解决了我的vs远程问题。

其问题本质是,虚拟机和电脑,及Xshell之间通过ssh网络传输协议,需要在传输两者安装好各自SSH,且配置正确。

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值