美文网首页
使用vscode的Remote Workspace管理远程机器的

使用vscode的Remote Workspace管理远程机器的

作者: 不要叫我帅哥 | 来源:发表于2019-03-12 16:40 被阅读0次

刚好碰到部分框架不能在windows上运行怎么办,简单。搞了个linux虚拟机继续盘它;但是又有一个问题,在linux里面修改代码好麻烦,想用windows上的ide来调试linux里面的项目代码怎么办?

有这么几个思路

  • 在linux项目目录初始化一个git仓库,把代码提交到远程仓库,然后在windows的机器上拉取代码,用git来进行两个机器上的代码同步;
  • 用vscode中的remote workspace插件,通过sftp来获取linux机器中的项目;

第一种思路很简单,就是在使用过程步骤比较繁琐,想看到每次的修改都必须一端提交代码,另一端拉取代码。

下面我们着重说第二种思路:

这里就不介绍sftp是什么东西了,不懂的请自行百度。

这里默认linux已经安装了openssh(不确定有没有安装的点这里)和windows上已经开启了ssh

linux设置

建立用户组和用户

我们建立一个管理sftp的用户组,方便我们管理权限。

  1. 建立一个sftp-users的sftp用户组
 sudo groupadd sftp-users
  1. 在sftp-users组下建立admin用户
sudo useradd -g sftp-users -m admin
  1. 修改admin的密码,连续两次输入密码就行
passwd admin

3.1. 如果admin用户已经存在,但不在sftp-users组里,可以将第2步的admin换成其他任意的用户名,或者,可以移动admin到sftp-users

usermod –g sftp_users admin

配置ssh和权限

  1. 打开/etc/ssh/sshd_config文件,修改配置文件之前最好备份一份源文件,出了问题也能还原回来。
  2. 修改Subsystem sftpinternal-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用户组用户目录权限

  1. 修改权限为root用户拥有
chown root /home/admin
  1. 修改权限为root可读写执行,其它用户可读
chmod 755 /home/admin
  1. 重启ssh,登录sftp
sudo service ssh restart

# 或者 centos重启重启ssh的命令
sudo systemctl restart sshd.service
  1. 在用户目录下建立子目录,让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的一些简单配置。

  1. 确保windows上开启了ssh,检验方式如下,在命令行输入ssh:


    检验是否安装了ssh

    如图所示就代表安装好了。

  2. 使用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来指定所指定的注释,可以方便用户标识这个密钥,指出密钥的用途或其他有用的信息。所以在这里输入自己的邮箱或者其他都行。

这里简单起见,输入上面命令之后一直回车就行了,结果见下图。


正确生成key
.ssh文件中生成的文件

vscode配置

  1. 在vscode扩展商店中搜索remote,安装Remote Workspace
    搜索Remote Workspace
  2. 创建一个*.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&param2=value2]

  • key代表了ssh的私钥文件的名称,查找目录是在当前用户目录下的.ssh文件夹。

其他参数可以查看remote workspace的使用文档。

  1. 在vscode中,选择打开工作区,然后打开刚刚保存的test.code-workspace文件。


    打开工作区
  2. 然后,你会发现还是不行,相当绝望。还差最后一步,我们要把刚刚生成的公钥文件-id_rsa.pub的内容复制的/home/admin/.ssh/authorized_keys文件中用于ssh的登录。结果类似下图:
    上传公钥文件
    这时候重新刷新vscode工作区,如果/home/admin/目录下有文件的话,就可以在vscode中看到了。
    注意:某些linux用户目录下并没有.ssh文件夹和authorized_keys文件,问题不大,新建文件和文件夹就行了。

可能出现的问题:

  • 如果在vscode中文件无法保存,提示权限不足,那就是admin账户对文件没有操作权限,更改相应目录和文件的读写权限就ok了。

相关文章

网友评论

      本文标题:使用vscode的Remote Workspace管理远程机器的

      本文链接:https://www.haomeiwen.com/subject/fkfnpqtx.html