IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> VSCODE配置SFTP插件以便在本地修改同步远端代码 -> 正文阅读

[开发工具]VSCODE配置SFTP插件以便在本地修改同步远端代码

一、区分两个不同应用场景的插件

之所以要区分一下是因为一开始的时候,我把这两个插件搞混了,导致浪费了一些时间。
为了避免再次犯错,这里再啰嗦一遍(本篇只针对SFTP的配置做讲解)。
这里先简单描述一下两个插件要解决的不同问题场景:

  • Remote-SSH是通过SSH登录远端的终端来执行相关指令的插件。
  • SFTP可以把远端设备的文件同步到本地,并在本地打开编辑,自动同步修改的内容到远端。
    SFTP原理是这样的:首先本地要有一个项目文件夹,同时远程也有一个项目文件夹,然后通过配置文件来同步二者。
    SFTP可以查看远程项目所有文件,但不能直接操作,必须操作本地项目文件,再同步到远程项目。

Remote-SSH
在这里插入图片描述
SFTP
在这里插入图片描述

二、确认远端和本地电脑都已经支持SFTP

可以使用类似以下命令先手动测试一下:

scp root@10.10.10.10:/opt/soft/nginx-0.5..tar.gz /opt/soft/

如果没有安装的话,我们远端的ubuntu可以安装openssh来获得相关支持,比如:

1st.检查是否开启SSH服务
 
    #因为Ubuntu默认是不安装SSH服务的,所以在安装之前可以查看目前系统是否安装,通过以下命令:
    #输出的结果ssh-agent表示ssh-client启动,sshd表示ssh-server启动。我们是需要安装服务端所以应该看是否有sshd,如果没有则说明没有安装。
    ps -e|grep ssh
 
2nd.安装SSH服务
 
    #客户端
    sudo apt-get install openssh-client
    #服务器
    sudo apt-get install openssh-server
 
  #或者
   apt-get install ssh
 
3rd.启动SSH服务
 
    sudo /etc/init.d/ssh start
 
4th.修改SSH配置文件
 
    #可以通过SSH配置文件更改包括端口、是否允许root登录等设置,配置文件位置:
    #默认是不允许root远程登录的,可以再配置文件开启。
    #找到PermitRootLogin without-password 修改为PermitRootLogin yes
    sudo vim /etc/ssh/sshd_config
 
	  #重启SSH服务
    service ssh restart
    #即可通过winscp 、putty使用ROOT权限远程登录。
 
    #启用root用户:sudo passwd root      //修改密码后就启用了。
 
    #客户端如果是ubuntu的话,则已经安装好ssh client,可以用下面的命令连接远程服务器做一下验证。
    $ ssh xxx.xxx.xxx.xxx
 
5th.开启自动启动ssh命令
    sudo systemctl enable ssh
 
6th.最后确认
    设置后重启系统,查看ssh是否启动,看到Active: active (running)即表示成功
    sudo systemctl status ssh

三、配置SFTP

1.安装插件:

VsCode安装插件很简单,“扩展”=》搜“SFTP”=》点击安装
在这里插入图片描述

2.添加配置文件

按F1 或 ctrl+shift+p输入SFTP:Config会生成一个’.vscode/sftp.json’。
比如,我们在这里设置到我们D盘的VSCODE_SFTP这个文件夹下(这个文件夹需要自己提前建好)。

在这里插入图片描述
可以看到在对应目录下生成了我们的sftp.json默认配置文件:
在这里插入图片描述

3.编辑配置文件

{
    "name": "本地文件夹名称(可自定义)",
    "host": "ip或域名",
    "protocol": "协议:[sftp/ftp]默认ftp",
    "port": 22,
    "username": "username",
    "password":"password",
    "remotePath": "远程文件夹地址,默认/",
    "context": "本地文件夹地址,默认为vscode工作区根目录",
    "uploadOnSave": true,
    "downloadOnOpen":false,
    "ignore": [
        "**/.vscode/**",
        "**/.git/**",
        "**/.DS_Store"
    ],
    "watcher": {
        "files": "*",
        "autoUpload": false,
        "autoDelete": false
    }
}

配置文件不能写注释,所以这里说明一下其中几个不是太好理解的属性(其他属性根据名字应该都能猜出来他们的作用):
uploadOnSave:本地更新文件保存会自动同步到远程文件(不会同步重命名文件和删除文件)
downloadOnOpen:从远程服务器下载打开的文件
ignore:忽略的文件(匹配的文件不会同步)
watcher:监听器(可以重命名文件和删除文件)
autoUpload:文件变更会自动同步(修改和重命名)
autoDelete:文件删除会自动同步
注意点:
有一个地方比较容易犯错的是远端的端口号需要注意一下,可能不是22,可以去远端设备查一下。
比如可以使用以下命令:

netstat -natp |grep ssh

Sample(亲测可用):
注意点:
这里有一点需要注意的是mydir这个路径最好自己手动建一下,就建在我们第2步的配置文件相关的.vscode的同级目录,比如:D:\VSCODE_SFTP\mydir

{
    "name": "test",
    "host": "192.168.1.5",
    "protocol": "sftp",
    "port": 22,
    "username": "root",
    "password":"abcdefg",
    "remotePath": "/home/lp823045578/myproj",
    "context": "mydir",
    "uploadOnSave": true,
    "downloadOnOpen":false,
    "ignore": [
        "**/.vscode/**",
        "**/.git/**",
        "**/.DS_Store"
    ],
    "watcher": {
        "files": "*",
        "autoUpload": false,
        "autoDelete": false
    }
}

4.检查生效

第3步配置好之后,需要按一下ctrl+s,此时最新的配置文件会生效,VSCODE也会重新加载同步相关的远端文件过来。

此时,左边的文件目录应该是这样的:

注意点:

这里需要注意的左边的红圈指明的这个地方其实是本地的文件目录,一定要注意这个仅仅只是本地电脑上的文件目录。
在这里插入图片描述

那么我们要的东西其实在这里:

可以看到我们远端设备的文件已经同步过来了。
在这里插入图片描述

5.编辑同步

  1. 此时,当我们试着双击my_repote_test_code.py进行编辑文件的时候发现,发现VSCODE提示无法编辑。
    在这里插入图片描述
  2. 我们可以通过鼠标右击选择“Edit in Local”来打开编辑模式,这样的话就可以进行编辑了。
    在这里插入图片描述
  3. 编辑好之后,进行ctrl+s保存之后,我们去远端设备确认一下是否已经同步过去就可以了。
  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2022-05-21 19:11:00  更:2022-05-21 19:11:08 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/29 8:45:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计