别看VS Code就一文本编辑器,也可做各类编程语言的IDE,它还是数一数二的SSH工具,没有之一,FinalShell+VSCode可以说是SSH工具中的卧龙凤雏,什么Termius、XShell简直弱爆了,最关键的是VS Code是免费的,FinalShell的基础功能也是免费的,完全用不着破解。

前置准备

Win10系统一个,VSCode一个,如果可以还能准备一个FinalShell。我这里用的VS Code是1.57.0版本,2021年6月出的。

1、安装VS Code

安装就没什么好说的,最简单的,直接下一步下一步就行了

vscode 离线安装eslint_运维

建议这些全部勾上,这样做的好处是遇见各种配置文件直接右键“通过Code打开”就行了

vscode 离线安装eslint_centos_02

vscode 离线安装eslint_vscode 离线安装eslint_03

2、安装Remote SSH插件

找到左边最后一个的插件选项,然后输入Remote SSH,就能直接搜到这个插件

vscode 离线安装eslint_ssh_04

看到这个界面说明已经安装好了

vscode 离线安装eslint_linux_05

3、安装SSH Client

按照VS Code官方的说法,Windows的话必须要Win10 1803版本及以上才能安装,Win7恐怕就无缘咯,不过谁现在还用Win7敲代码呢?(嘲讽)

vscode 离线安装eslint_centos_06

官方安装教程在Remote SSH插件下面就有,我这边简述一下

vscode 离线安装eslint_vscode 离线安装eslint_07

打开PowerShell,然后输入

Get-WindowsCapability -Online | ? Name -like 'OpenSSH*'

vscode 离线安装eslint_linux_08

一般来说是个正常的Win10 OpenSSH Client都是默认安装好的,这里只是为了检验一下是否安装罢了,可以跳过(哈哈哈哈)

vscode 离线安装eslint_linux_09

如果没有安装,可以输入
Add-WindowsCapability -Online -Name OpenSSH.Client~~~~0.0.1.0

即可完成OpenSSH Client的安装。官方教程下方还有OpenSSH Server的安装,也就是说别的电脑可以用过SSH工具控制你的Windows电脑,想想就觉得刺激,不过用的是DOS语言,而非Linux Shell。由于本教程用不着OpenSSH Server,所以就不安装了。

官方安装教程链接:https://docs.microsoft.com/en-us/windows-server/administration/openssh/openssh_install_firstuse

4、为连接Linux做准备

我在VMware中用ova导入了一个CentOS7.9来配合本教程,其中WIn10的IP是192.168.66.130,CentOS7.9的IP是192.168.66.147,两个虚拟机同属NAT下的同一个局域网,能够互相ping通

vscode 离线安装eslint_vscode 离线安装eslint_10

vscode 离线安装eslint_linux_11

点击左下角绿色的远程连接标志,点击“Connect to Host”

vscode 离线安装eslint_centos_12

点击Add New SSH Host...

vscode 离线安装eslint_centos_13

输入Linux的用户和地址,格式为:ssh {用户名}@{IP地址},输入完成后按回车继续

vscode 离线安装eslint_linux_14

选择第一个用户文件夹(就是为了点起来方便点)

vscode 离线安装eslint_运维_15

然后右下角会出现一个Host added的提示框,别急着把它关了,为何不看看里面存了些什么呢,点击“Open Config”

vscode 离线安装eslint_运维_16

看看里面的内容,哦!原来是连接的主机名称、主机的IP和连接的用户名啊,以后要是加连接地址,我直接可以复制粘贴啊!还可以复制粘贴保存下来,以后换电脑的话直接可以继续使用

vscode 离线安装eslint_linux_17

当然如果不小心关了这个提示框也没关系,点击左下角绿色的远程连接按钮,然后选择“Open SSH Configuration File...”也是同样的效果

vscode 离线安装eslint_运维_18

5、启动,连接!

细心的小伙伴应该会发现左侧菜单栏出现了一个新的图标,那就是远程连接用的了

vscode 离线安装eslint_linux_19

这里会弹出一个新的VS Code的程序界面,我这边是Linux系统,因此点击第一个Linux即可

vscode 离线安装eslint_centos_20

给你看这台Linux的指纹信息,然后问你是否同意连接,那当然选择同意咯,点击Continue

vscode 离线安装eslint_运维_21

然后就是要输入密码,现在免密连接还没配,只能先输密码了。输完后按回车键继续

vscode 离线安装eslint_ssh_22

输入Shell命令的终端已经呈现在界面下发了,点击左侧的Open Folder,然后就能直接浏览服务器上的文件了

vscode 离线安装eslint_vscode 离线安装eslint_23

建议选择home下的用户目录就像了,如果是root,建议直接输入/,然后回车

vscode 离线安装eslint_linux_24

很杯具的是由于没有配置免密,又要输入密码了,o(╥﹏╥)o,那就老老实实输入呗,输完后回车

vscode 离线安装eslint_vscode 离线安装eslint_25

中间弹出是否信任,直接点击Yes即可

vscode 离线安装eslint_centos_26

由于我这是导入的崭新的服务器,因此上面没什么东西,然后你会发现输入Shell命令的终端不见了,按快捷键ctrl+`即可打开终端。`是1左边的反引号。

vscode 离线安装eslint_运维_27

6、先介绍几个特性,免得你们看到这里就跑路了

6.1超强的直接文本编辑

VS Code本来就是文本编辑器,自带超强编辑能力buff,编辑个文本自然得心应手,编辑完后直接ctrl+s(VS Code能够设置自动保存哦),那么服务器上的文件直接就被修改了,根本用不着下载下来,编辑完后,再上传上去!

例:我这边演示修改.bash_profile这个文件,然后source后直接打印DCT这个变量,很明显.bash_profile这个文件已经被修改了

vscode 离线安装eslint_运维_28

6.2可以分栏的终端

这点实在是太友好了,非常符合喜欢分栏的程序猿们的口味,按Ctrl+Shift+5(注意:这个5不是小键盘上的5!)

vscode 离线安装eslint_centos_29

6.3直达目标

我这边直接拿已经存在的.vscode-server文件夹举例子,如果我想运行里面的brower.sh怎么办?VS Code给你一步到位

右键brower.sh,点击Open in Integrated Terminal

vscode 离线安装eslint_vscode 离线安装eslint_30

此时会打开一个新的终端,路径直接到helpers目录下,然后执行这个shell脚本即可

vscode 离线安装eslint_运维_31

6.4实时查看log日志

如果嫌看日志tail -f不直观,那么用VS Code 打开日志文件即可,由于VS Code强大的颜色区分能力和导航图,能够快速直击日志报错信息的位置,而且更重要的是VS Code是实时刷新log的,时间延迟非常的低。由于这个纯净版本的CentOS没有跑任何Java项目,我也就没法截图了,大家知道就行了。

6.5文件直接上传

还为开个SSH工具还要再开一个Filezilla而发愁吗?VS Code它一个软件就能搞定这两件事了。文件拖进目录就行了。不过这个文件上传还不是很好,没有进度和上传速度显示,上传速度也不给力,建议只上传小文件,所以配合FinalShell使用效果更佳。

vscode 离线安装eslint_ssh_32

vscode 离线安装eslint_centos_33

当然文件也支持直接删除。更多功能期待大家探索

7、本篇博客重点:免密连接

我之前写的两篇免密登录的博客可不是白写的,一篇是root用户,一篇是非root用户,其实VS Code免密登录原理和上述两篇博客的差不多

root用户免密连接:

非root用户免密连接:

进入传统艺能:在用户根目录下执行

ssh-keygen -t rsa

然后一路回车即可,目的是为了创建.ssh目录和它的公钥和私钥

vscode 离线安装eslint_linux_34

还记得之前打开的PowerShell吗,在PowerShell中同样输入

ssh-keygen -t rsa

然后一路回车即可

vscode 离线安装eslint_运维_35

然后会在Windows的用户文件夹下生成一个.ssh文件夹,和Linux上的一模一样,路径为C:\User\{用户名}\.ssh

vscode 离线安装eslint_centos_36

复制id_rsa.pub文件,重命名为authorized_keys(没有后缀名!!)

vscode 离线安装eslint_vscode 离线安装eslint_37

然后将这个authorized_keys文件通过VS Code上传到Linux的.ssh文件夹里,如果这个文件本来就有,那就把Windows中的id_rsa.pub的内容复制,并追加到Linux上的authorized_keys后面即可

拖入上传,美滋滋

vscode 离线安装eslint_centos_38

上传后打开,记得修改换行格式为LF

vscode 离线安装eslint_ssh_39

重新赋予authorized_keys文件权限,否则不会生效!!!!

chmod 644 authorized_keys

vscode 离线安装eslint_ssh_40

打开连接配置文件

vscode 离线安装eslint_ssh_41

vscode 离线安装eslint_vscode 离线安装eslint_42

加入一行:

IdentityFile ~/.ssh/id_rsa

注意!!这里的文件不带.pub是私钥!!也就是说控制端用私钥连接被控制端的公钥进行匹配!!

记得ctrl+s保存,意思是用你的私钥文件去连接这个Linux服务器,然后因为Linux服务器上已经有了authorized_keys这个保存了一大堆公钥的文件,因此能直接连上服务器,不需要再次输入密码!

vscode 离线安装eslint_vscode 离线安装eslint_43

8、测试连接效果

把这个连接Linux的VS Code窗口关了,重新连接!

vscode 离线安装eslint_linux_44

直接连接上,什么密码都不用输,简直不要太爽!

vscode 离线安装eslint_centos_45