刚好碰到部分框架不能在windows上运行怎么办,简单。搞了个linux虚拟机继续盘它;但是又有一个问题,在linux里面修改代码好麻烦,想用windows上的ide来调试linux里面的项目代码怎么办?
有这么几个思路
- 在linux项目目录初始化一个git仓库,把代码提交到远程仓库,然后在windows的机器上拉取代码,用git来进行两个机器上的代码同步;
- 用vscode中的remote workspace插件,通过sftp来获取linux机器中的项目;
第一种思路很简单,就是在使用过程步骤比较繁琐,想看到每次的修改都必须一端提交代码,另一端拉取代码。
下面我们着重说第二种思路:
这里就不介绍sftp是什么东西了,不懂的请自行百度。
这里默认linux已经安装了openssh(不确定有没有安装的点这里)和windows上已经开启了ssh
linux设置
建立用户组和用户
我们建立一个管理sftp的用户组,方便我们管理权限。
- 建立一个sftp-users的sftp用户组
sudo groupadd sftp-users
- 在sftp-users组下建立admin用户
sudo useradd -g sftp-users -m admin
- 修改admin的密码,连续两次输入密码就行
passwd admin
3.1. 如果admin用户已经存在,但不在sftp-users组里,可以将第2步的admin换成其他任意的用户名,或者,可以移动admin到sftp-users
usermod –g sftp_users admin
配置ssh和权限
- 打开/etc/ssh/sshd_config文件,修改配置文件之前最好备份一份源文件,出了问题也能还原回来。
- 修改Subsystem sftp为internal-sftp,使用系统自带的internal-sftp搭建sftp服务器。
#注释掉这行
#Subsystem sftp /usr/libexec/openssh/sftp-server
#添加在配置文件末尾
Subsystem sftp internal-sftp #指定使用sftp服务使用系统自带的internal-sftp
Match Group sftp-users
ChrootDirectory %h #用chroot将指定用户的根目录,chroot的含义:http://www.ibm.com/developerworks/cn/linux/l-cn-chroot/
ForceCommand internal-sftp
X11Forwarding no #这两行,如果不希望该用户能使用端口转发的话就加上,否则删掉
AllowTcpForwarding no
- Match Group sftp-users这一行是指定以下的子行配置是匹配sftp-users用户组的,多个用户组用英文逗号分隔;
- ChrootDirectory %h该行指定Match Group行指定的用户组验证后用于chroot环境的路径,也就是默认的用户目录,比如/home/admin;也可以写明确路径,例如/data/www;
- ForceCommand internal-sftp该行强制执行内部sftp,并忽略任何~/.ssh/rc文件中的命令;
注意:因为ChrootDirectory %h模式,所以我们等下要设置sftp-users中的所有用户的用户目录权限为root拥有,否则sftp-users组中的用户无法用sftp登录。
修改sftp-users用户组用户目录权限
- 修改权限为root用户拥有
chown root /home/admin
- 修改权限为root可读写执行,其它用户可读
chmod 755 /home/admin
- 重启ssh,登录sftp
sudo service ssh restart
# 或者 centos重启重启ssh的命令
sudo systemctl restart sshd.service
- 在用户目录下建立子目录,让sftp-users中的用户可读写文件,我们现在在/home/admin目录下新建一个projects文件夹,并授权给admin
cd /home/admin/
mkdir projects
# 更改文件夹用户
chown admin /home/admin/projects
# 让文件夹可读写
chmod 755 /home/admin/projects
linux的配置到这里基本就大功告成了,步骤还是挺多的。接下来就轮到windows上的配置了。
windows配置
在进行vscode的配置之前,我们先进行一下windows的一些简单配置。
-
确保windows上开启了ssh,检验方式如下,在命令行输入ssh:
如图所示就代表安装好了。
- 使用ssh-keygen生成ssh的公密钥,用于windows登录linux用。在Windows下查看[c盘->用户->自己的用户名->.ssh]下是否有"id_rsa、id_rsa.pub"文件,如果没有需要手动生成,有的话直接忽略这一步。
打开命令行窗口,在控制台中输入以下命令:
$ ssh-keygen -t rsa -C "youremail@example.com"
密钥类型可以用 -t 选项指定。如果没有指定则默认生成用于SSH-2的RSA密钥。这里使用的是rsa。
同时在密钥中有一个注释字段,用-C来指定所指定的注释,可以方便用户标识这个密钥,指出密钥的用途或其他有用的信息。所以在这里输入自己的邮箱或者其他都行。
这里简单起见,输入上面命令之后一直回车就行了,结果见下图。
vscode配置
- 在vscode扩展商店中搜索remote,安装Remote Workspace
- 创建一个*.code-workspace工作区文件,例如:test.code-workspace
{
"folders": [{
"uri": "sftp://admin@[ip地址]:22/?key=id_rsa",
"name": "remote_www"
}]
}
uri的格式如下:
sftp://[user:password@]host[:port][/path/to/a/folder][?param1=value1¶m2=value2]
- key代表了ssh的私钥文件的名称,查找目录是在当前用户目录下的.ssh文件夹。
其他参数可以查看remote workspace的使用文档。
-
在vscode中,选择打开工作区,然后打开刚刚保存的test.code-workspace文件。
- 然后,你会发现还是不行,相当绝望。还差最后一步,我们要把刚刚生成的公钥文件-id_rsa.pub的内容复制的/home/admin/.ssh/authorized_keys文件中用于ssh的登录。结果类似下图:
这时候重新刷新vscode工作区,如果/home/admin/目录下有文件的话,就可以在vscode中看到了。
注意:某些linux用户目录下并没有.ssh文件夹和authorized_keys文件,问题不大,新建文件和文件夹就行了。
可能出现的问题:
- 如果在vscode中文件无法保存,提示权限不足,那就是admin账户对文件没有操作权限,更改相应目录和文件的读写权限就ok了。