背景
有一台在学校宿舍放着的电脑(Linux系统),另外有一台随身携带的笔记本(windows)。
我希望能够在笔记本上通过ssh远程连接到宿舍的电脑跑程序。但由于一个连接了校园网(内网),只有内网IP地址,没有公网IP地址,导致笔记本无法直接通过ssh连接到宿舍的电脑。
实现目标
通过笔记本能够随时远程连接到宿舍电脑
实现方式
通过内网穿透
,此方法需要有一台拥有公网IP的服务器。没有的话可以在阿里云或者腾讯云上租一台。
具体步骤
-
首先确认Linux系统电脑已经安装好了ssh。可以直接通过以下命令进行安装。
sudo apt install ssh
-
在Linux系统电脑上开启反向代理
sudo ssh -fCNR 4515:localhost:22 -o ServerAliveInterval=60 root@example.example.xyz
其中4515是端口号A
root是服务器的用户名
example.example.xyz是服务器的公网IP或者域名
-
确认是否反向代理成功
sudo netstat -nap |grep ssh
如果代理成功的话,应该能够看到
tcp 0 0 127.0.0.1:4515 0.0.0.0:* LISTEN 8493/sshd
其中4515就是我们设置的端口号A
-
此时在服务器上运行一下命令就可以ssh到宿舍的Linux系统上。
ssh -p 4515 ubuntu@127.0.0.1
后续
如果要在命令行中手动ssh两次会很麻烦,并且命令中无法打开一个项目,因此选择配合VsCode
来简便步骤
-
在Vscode中安装插件
Remote ssh
-
点击图片最左下角的蓝色区域,开启远程连接,在顶部的选择框中选择
SSH
-
按照提示内容,输入远程连接至服务器的命令,例如我的就是
ssh root@120.78.168.228
-
然后选择将配置文件保存在第一个位置
-
这是会在该位置生成一个配置文件,我们只要重新编辑该文件内容,便不用每次都重新输入多次ssh命令。
文件内容如下:
Host 服务器A的名字(aliyun) HostName 服务器A的ip Port 22 User 服务器A上的用户名 Host 给服务器B取个名字(ubuntu) HostName 1207.0.0.1 ProxyJump 上面服务器A的名字(aliyun) User 服务器B上的用户名
-
保存之后,下次再次ssh只要输入两次密码即可。