前言
解决需求: 本地是 win10 系统,代码需要在 linux 下跑,又不想装虚拟机或双系统; 所以,项目用到连接远程测试服务器进行开发联调,需要安装 SFTP/FTP 的扩展插件才能同步代码; 还有其他实现方法,如,Git 工作流、winscp、rzlz 等,但大都不太灵活,甚至麻烦
CentOS 7 配置使用 SFTP 服务器
何为 SFTP?
SFTP,即 SSH 文件传输协议( SSH File Transfer Protocol ),或者说是安全文件传输协议( Secure File Transfer Protocol )。SFTP 是一个独立的 SSH 封装协议包,通过安全连接以相似的方式工作。它的优势在于可以利用安全的连接传输文件,还能浏览本地和远程系统上的文件系统。
在很多情况下,SFTP 都比 FTP 更可取,因为它具有最基本的安全特性和能利用 SSH 连接的能力,FTP 是一种不安全的协议,只能在有限的情况下或在您信任的网络上使用。
先决条件:
服务器 OpenSSH-Server
版本最低 4.8p1,因为配置权限需要版本添加的新配置项 ChrootDirectory
来完成。
如何查看 OpenSSH 版本,命令如下:
ssh -V |
创建用户信息
添加用户组:
groupadd sftp |
添加用户:
useradd -g sftp -s /sbin/nologin -M leeifme |
参数注解:
-g # 加入用户组 |
设置用户密码:
passwd leeifme |
创建用户目录并设置权限
创建 sftp 主目录:
$ mkdir /home/danaos |
设置 sftp 主目录权限:
$ chown root:sftp /home/danaos |
文件夹所有者必须是 root,用户组可以不是 root
$ chmod 755 /home/danaos |
权限不能超过 755 但不包括 755,否则会导致登录报错
创建上传目录并设置权限
在/home/danaos/
主目录下创建archer
项目文件夹,并设置所有者是:leeifme
,用户组隶属:sftp
,这样新增的帐号才能有上传编辑的权限。
$ mkdir -p /home/danaos/archer |
修改 sshd_config 配置文件
vim /etc/ssh/sshd_config |
将此行注释掉,例如:
#Subsystem sftp /usr/libexec/openssh/sftp-server |
在此行下面添加如下内容:
Subsystem sftp internal-sftp # 指定使用sftp服务使用系统自带的internal-sftp |
重启 SSH 服务
systemctl restart sshd |
测试是否能够登录、上传、下载等操作
在10.28.204.61
服务器执行以下命令登录:
$ sftp leeifme@192.168.50.124 |
上传
sftp> put test.go |
下载
sftp> get test.go |
删除
sftp> rm test.go |
更多命令请参阅
help |
vscode 配置 sftp
下载 sftp 插件
- 在 vscode 中快捷键
ctrl+shift+P
打开指令窗口,输入extension:install
,回车,左侧即打开扩展安装的界面 - 在搜索框中输入
sftp
,第一个就是需要安装的,点安装(可以参考下载数,选择适合自己的插件,功能大都大同小异)
在 vscode 的工程中配置 sftp.json
然后快捷键 ctrl+shift+P
打开指令窗口,输入sftp:config
,回车,就会在当前工作工程的.vscode
文件夹下生成一个sftp.json
文件,不知道哪天似乎是插件更新了,默认的文件非常空,我们只能手动配置文件的参数了。配置好host, port, username, privateKeyPath, remotePath, ignore
这参数即可:
- host:工作站的 IP 地址
- port:ssh 的端口
- username:工作站自己的用户名
- privateKeyPath:存放在本地的已配置好的用于登录工作站的密钥文件。和下面的使用密码二选一(可以是 openssh 格式的,也可以是 ppk 格式的)
- password:工作站自己的用户密码。使用密钥和使用密码选用一种即可;使用密码的话工作站不用配置 ssh,但使用密钥的话工作站上需要配置好 ssh,password 就可以填 null
- protocol:协议类型,默认选
"sftp"
- remotePath:工作站上与本地工程同步的文件夹路径,需要和本地工程文件根目录同名,且在使用 sftp 上传文件之前要手动在工作站上使用mkdir生成这个根目录,根目录下的其他子目录会自动对应生成
- ignore:指定在使用
sftp: sync to remote
的时候忽略的文件及文件夹,注意每一行后面有逗号,最后一行没有逗号 - debug: 默认是 false,如果设置为 true,可以看到通过菜单的 查看 -> 输出 打开输出界面,看到打印,怀疑自己连接有问题的可以打开看看
- uploadOnSave: 默认是 false,建议设置成 true,这样每次修改后 ctrl+s 保存后会自动同步。否则就需要手动同步
举个栗子:(记住不能有任何注释内容)
{ |