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

刚好碰到部分框架不能在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了。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,458评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,454评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,171评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,062评论 0 207
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,440评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,661评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,906评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,609评论 0 200
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,379评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,600评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,085评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,409评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,072评论 3 237
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,088评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,860评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,704评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,608评论 2 270

推荐阅读更多精彩内容