当前位置: 首页 > news >正文

【VSCode】 使用 SFTP 插件实现多服务器同步

作为一名开发者,代码编辑器的选择对工作效率有着重要影响。我曾经因为 VSCode 在某些功能上的不足,比如对 PyTorch 的补全不够理想以及代码同步到多个远程服务器的不便,而转向了 PyCharm。在 PyCharm 中,可以方便地绑定多个服务器,在本地维护一份代码,然后根据服务器的资源情况灵活地上传到不同的服务器,这确实很方便。然而,最近由于 PyCharm 出了一些问题,我决定重新尝试使用 VSCode,而 VSCode 和 PyCharm 在功能上的主要差距就在于同步多个服务器这一点。不过,经过一番探索,我发现了一个名为 sftp 的插件,经过配置后,它似乎能够很好地解决这个问题。

下载插件

在 VSCode 的插件市场中搜索 sftp,会找到多个相关插件。我们需要选择作者是 Natizyskunk 的那个版本。因为原版作者的仓库已经多年没有维护了,存在很多问题,而这个版本是由一位开发者接手并持续维护的,相对来说更加稳定可靠。

配置 sftp.json

按下 Ctrl+Shift+P 组合键,调出 VSCode 的命令面板,在其中输入 sftp,然后选择 SFTP: Config 命令。这样,VSCode 会在项目的 .vscode 文件夹下生成一个 sftp.json 配置文件,我们可以在其中设置连接的相关参数。

以下是一个配置示例,其中添加了两个服务器的连接信息。remotePath 是本地文件在远程服务器上对应的目录路径,如果该路径不存在,插件会自动创建。ignore 部分则可以列出一些不需要同步的文件或文件夹,类似于 .gitignore 文件的作用。

{"name": "✌","protocol": "sftp","port": 22,"profiles": {"159": {"host": "服务器1的IP地址","username": "服务器1的用户名","password": "服务器1的密码","remotePath": "/data1/kevin/goubatest"},"190": {"host": "服务器2的IP地址","username": "服务器2的用户名","password": "服务器2的密码","remotePath": "/raid/kevin/mmdet180"}},"uploadOnSave": true,"downloadOnOpen": false,"ignore": [".vscode",".git",".DS_Store",".github",".dev_scripts",".idea","show_dirs/*","work_dirs/*","checkpoints/*","data"],"watcher": {"files": "data/*","autoUpload": true,"autoDelete": false},"defaultProfile": "159"
}

在配置完成后,就可以开始将文件上传到服务器了。如果设置了 defaultProfile,那么在启动插件时会自动连接到指定的默认服务器。

在 VSCode 的左侧文件栏中,可以方便地将所有文件同步上传到服务器,也可以选择只同步部分文件,或者将远程服务器上的文件同步到本地,操作非常灵活。

上传文件后,在左侧的 SFTP 工具栏中可以看到远程目录下的文件列表。这些文件默认是只读的,文件名前会有一个 ~ 波浪线作为标识,这样可以有效防止误编辑。我认为这个插件在这方面比 PyCharm 做得更好。它会自动对比本地和远程文件的差异,当使用 Sync Local/Remote/Both 功能时,只会上传那些存在差异的文件,而不会对相同的文件进行重复上传。相比之下,PyCharm 会直接上传所有文件,如果本地存在一些体积较大的文件,每次上传都会耗费很多时间。

如果需要将代码同步到另一台服务器,只需要通过 SFTP: Set Profile 命令切换到目标服务器,然后再进行上传操作即可。

总之,通过使用 SFTP 插件,VSCode 在多服务器代码同步方面的功能得到了很好的补充,让我重新看到了使用 VSCode 的可能性。希望这篇文章能对其他有类似需求的开发者有所帮助。

http://www.lryc.cn/news/609774.html

相关文章:

  • 随机森林知识点整理:从原理到实战
  • 区块链基础之Merkle树
  • 数据结构——单向链表
  • CMakeLists.txt学习
  • 《JavaScript高级程序设计》读书笔记 35 - 代理捕获器、反射方法以及代理模式
  • React 19 + Next.js 15 中实现混合布局
  • React配置proxy跨域
  • ref和reactive的区别
  • 通过 Flink 和 CDC 从 Oracle 数据库获取增量数据,并将这些增量数据同步到 MySQL 数据库中
  • [GESP202306 四级] 2023年6月GESP C++四级上机题超详细题解,附带讲解视频!
  • Spring Boot + ShardingSphere 实现分库分表 + 读写分离实战
  • AWS VPC Transit Gateway 可观测最佳实践
  • 【物联网】基于树莓派的物联网开发【23】——树莓派安装SQLite嵌入式数据库
  • 16_OpenCV_漫水填充(floodFill)
  • Nginx vs Spring Cloud Gateway:限流功能深度对比与实践指南
  • Spring Cloud Gateway 实现登录校验:构建统一认证入口
  • 图片的放大缩小选择全屏
  • XSS的原型链污染1--原型链解释
  • 笔记本电脑联想T14重启后无法识别外置红米屏幕
  • Django + Vue 项目部署(1panel + openresty)
  • AI“炼金术”:破解绿色水泥的配方密码
  • 三防平板电脑是什么?这款三防平板支持红外测温!
  • 电脑上不了网怎么办?【图文详解】wifi有网络但是电脑连不上网?网络设置
  • 电脑一键重装系统win7/win10/win11无需U盘(无任何捆绑软件图文教程)
  • Ribbon 核心原理与架构详解:服务负载均衡的隐形支柱
  • 工作流绑定卡片优化用户体验-练习我要找工作智能体
  • 【CVPR2025】计算机视觉|AnomalyNCD:让工业异常分类“脱胎换骨”!
  • transformer与神经网络
  • ubuntu24.01安装odoo18
  • 纯前端使用ExcelJS插件导出Excel