首先进行验证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,且配置正确。