0


VScode通过ssh连接树莓派进行远程开发调试(踩坑总结)

    写在开头(vscode使用ssh时,一定要可以联网才行),vscode的ssh远程开发功能实在是太香了,再也不想体会那种写一段代码卡三年的噩梦!(Pycharm真那啥,只有专业版才能用shh)

    在配置功能的时候,踩了很多坑,所以想在此记录以下,希望能够对大家有所帮助。

** 必备工具:**

    1.Windows下安装**
openSSH

**

    2.vscode中安装**remote ssh**插件

一、安装OpenSSH

    为什么要安装呢?别问,问就是自己踩坑了!!!

    首先通过cmd命令,访问以下Windows是否具有ssh功能:

    像上面这张图,就是表明我电脑上已经拥有了ssh功能,大家就可以跳过第一步了。

    但是大多数人都是没有安装的,具体我是参考Windows下安装openSSH 这篇文章。在此我选择第二种方法(以下所有命令均在powershell执行):

    1、以管理员形式运行PowerShell,为了确保 OpenSSH 可用,请运行以下命令:
Get-WindowsCapability -Online | Where-Object Name -like 'OpenSSH*'
    2、 如果两者均尚未安装,则此操作应返回以下输出:
Name  : OpenSSH.Client~~~~0.0.1.0
State : NotPresent

Name  : OpenSSH.Server~~~~0.0.1.0
State : NotPresent
    3、然后根据需要安装对应的服务:
# Install the OpenSSH Client
Add-WindowsCapability -Online -Name OpenSSH.Client~~~~0.0.1.0

# Install the OpenSSH Server
Add-WindowsCapability -Online -Name OpenSSH.Server~~~~0.0.1.0

#两者都会返回下列内容:
Path          :
Online        : True
RestartNeeded : False
     4、启动并配置 OpenSSH 服务器:

这三步依次执行下去

# Start the sshd service
Start-Service sshd

# OPTIONAL but recommended:
Set-Service -Name sshd -StartupType 'Automatic'

# Confirm the Firewall rule is configured. It should be created automatically by setup. Run the following to verify
if (!(Get-NetFirewallRule -Name "OpenSSH-Server-In-TCP" -ErrorAction SilentlyContinue | Select-Object Name, Enabled)) {
    Write-Output "Firewall Rule 'OpenSSH-Server-In-TCP' does not exist, creating it..."
    New-NetFirewallRule -Name 'OpenSSH-Server-In-TCP' -DisplayName 'OpenSSH Server (sshd)' -Enabled True -Direction Inbound -Protocol TCP -Action Allow -LocalPort 22
} else {
    Write-Output "Firewall rule 'OpenSSH-Server-In-TCP' has been created and exists."
}

二、VScode配置Remote SSH插件

    这里vscode通过ssh连接树莓派实现远程开发我参考这篇文章内容,在VScode通过拓展安装相应插件,如下所示:

    安装好之后, 对Remote SSH进行配置,如下所示:

    完成以上工作之后,VScode便可以出现远程连接的图标了,如下所示:

三、VScode通过ssh与树莓派连接

    通过点击SSH右边的“+”,进行远程连接,输入命令格式如下: 
# user_name是远程连接的设备用户名,对于树莓派而言默认是pi
#ip——adress是远程连接的设备IP地址,可以通过无线网啥的查找
ssh user_name@ip_adress

    如果到这里一直很成功的朋友们,我真的太羡慕了,你们简直就是欧皇!!!不出意外的话,还是会出很多意外!下面将会介绍遇到的一些坑以及解决办法。

四、遇到的坑及解决办法

1、通过cmd测试ssh是否可用,出现Bad owner or permissions on .ssh/config的解决办法

    我是参考了【Windows10】下Bad owner or permissions on .ssh/config的解决办法这篇文章。亲测好评!

 **解决办法如下:**

1、找到.ssh文件夹:

2、右键单击.ssh文件夹,然后单击“属性”,找到并点击“安全”标签。然后单击“高级”。单击“禁用继承”,单击“确定”。 将出现警告弹出窗口。单击“从此对象中删除所有继承的权限”。你会注意到所有用户都将被删除。

3、在同一窗口中,单击“添加”按钮。接下来,单击“选择主体”窗口。

4、单击“立即查找”按钮。应显示用户结果列表。 选择您的用户帐户。然后单击“确定”(大约三次)以关闭所有窗口。这里提供一个查找自己用户账户的方法,在开始那里,就可以看到。

2、vscode无法配置保存.ssh路径下的config文件

     还是.ssh文件夹的权限问题,根据4.1配置下俩,你会发现.ssh文件夹只有读取和执行权限,我们需要将修改权限打开:

3、windows使用ssh远程连接服务器 报错:host key verification failed.

    我升级了树莓派系统,然后通过ssh登录出现了上述报错。这是由于我系统更新,但是相关ssh配置没有更新,具体解决方法可以参照这篇大佬的文章进行修改。

    具体报错如下所示:
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@    WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!     @
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY!
Someone could be eavesdropping on you right now (man-in-the-middle attack)!
It is also possible that a host key has just been changed.
The fingerprint for the ECDSA key sent by the remote host is
SHA256:OH+Z2mAEQRl4O34U6fZFZPjP284my1n+YHQEUbhviCA.
Please contact your system administrator.
Add correct host key in C:\\Users\\yourname/.ssh/known_hosts to get rid of this message.
Offending ECDSA key in C:\\Users\\yourname/.ssh/known_hosts:2
ECDSA host key for yourIp has changed and you have requested strict checking.
Host key verification failed.

综上,可以用啦!!!

标签: vscode ssh ide

本文转载自: https://blog.csdn.net/qq_59449692/article/details/136537685
版权归原作者 Epiphany_ZZW 所有, 如有侵权,请联系我们删除。

“VScode通过ssh连接树莓派进行远程开发调试(踩坑总结)”的评论:

还没有评论