无法直连 SSH?一招反向SSH搞定内网到公网的远程连接问题
作者:SkyXZ
CSDN:SkyXZ~-CSDN博客
博客园:SkyXZ - 博客园
在校园网或者是家里的内网中,我们常常会遇到一个头疼的问题:两台设备明明都接入了网络,但当我离开内网之后却无法再远程访问其中的设备。这对我们想要远程调用 GPU 训练模型、远程开发调试、甚至只想从笔记本连回家中台式机的场景来说,简直就是“断网式打击”。
而最近我也遇到了类似的问题。由于有一个比较大的模型需要训练几天,如果直接在我自己的主力电脑上跑训练任务,那在训练过程中我基本就无法再做其他事情了——这显然不现实。好在我手上还有一台笔记本,具备一定的 GPU 算力,可以临时当作训练服务器使用。于是我有了一个想法:把这台笔记本部署成“GPU 服务器”,专门用来训练模型,而我则通过主力设备进行远程连接与监控。但很快我发现一个难题——这台笔记本在校园网的内网环境中,我根本无法从外部网络通过 SSH 访问它。更进一步地,我希望无论身处宿舍、家中,甚至外出,只要联网就能随时连接这台“GPU 小服务器”,查看训练状态、调整参数甚至重新启动训练任务。为此,我开始尝试一种解决方案:利用拥有公网 IP 的阿里云服务器作为“中转跳板”,借助 SSH 的反向隧道打通公网与内网之间的连接。
┌──────────────┐ ssh -p 2222 root@公网IP
│ 设备 A │ ─────────────────────────────┐
│(任意地点) │ │
└──────────────┘ ▼
┌──────────────┐
│ 公网服务器 │
│(阿里云 ECS)│
└──────────────┘
▲
ssh -R 2222:localhost:22 root@公网IP │
┌──────────────┐ │
│ 设备 B │──────────────────────────────┘
│(校园网 GPU)│
└──────────────┘
一、 拥有一台你的云服务器
想要做到内网穿透或者反向 SSH,首先你得要有一台具有公网 IP 的服务器。因为我们的目标是从外部访问一台处于内网(如校园网或家庭网)中的设备,而内网设备的 IP 是不能直接被外网访问到的。所以,我们需要借助这台 “中转服务器”,作为公网和内网之间的桥梁。我使用的阿里云的服务器,其链接如下:2025主会场_创新加速季 就上阿里云-阿里云创新加速季,如果你是新人的话最低68便可以拿下一个具有公网IP的双核40GB的服务器,可以说非常划算了;

购买了服务器之后我们进入控制台,左下角便可以看到你服务器的公网IP啦

接着我们点进服务器详情里,开放防火墙端口,否则即使你服务配置再完美,外部请求也会被服务器的安全机制拦下,我们将2222端口开放出来作为我们的反向 SSH 端口,当然这个端口大家可以随便选择,只要不与当前服务冲突即可
PS:若你使用了宝塔等面板,务必进入宝塔后台的【安全】→【防火墙】,同样添加对应的端口放行。否则即便阿里云层面放行了,系统依然可能拦截连接。

为了让反向 SSH 隧道可以正常绑定公网 IP 并对外可访问,我们还需要修改阿里云服务器上的 SSH 服务配置文件 —— /etc/ssh/sshd_config,默认情况下,SSH 服务只允许在本地接口上监听反向转发的端口,也就是说,就算你把设备 B 的 SSH 映射到了阿里云服务器的 2222 端口,外部设备 A 也无法通过公网连接进来。所以,我们要手动开启两个配置项,只需按照如下操作即可:
# Step-1 打开ssh配置文件
sudo nano /etc/ssh/sshd_config
# Step-2 找到以下两行,如果前面有 # 注释,请将其注释取消并将no改为yes,如果找不到,可以手动添加在文件末尾:
AllowTcpForwarding yes #允许 SSH 端口转发
GatewayPorts yes #允许反向端口绑定公网地址(否则只绑定 localhost)
# Step-3 重启 SSH 服务使配置生效
sudo systemctl restart sshd
# Step-4 检查服务是否监听对应端口
netstat -tlnp | grep 2222
如果运行了第四步之后看到了如下内容即代表配置成功:
tcp 0 0 0.0.0.0:2222 0.0.0.0:* LISTEN 1234/sshd
二、设备端配置:反向 SSH 隧道的建立
完成了公网云服务器(阿里云)的准备和配置后,接下来就是在内网设备(设备 B)上发起连接,通过 SSH 隧道将自己的 SSH 服务“反向映射”到云服务器上,这一步的目标是:
让外部设备通过连接云服务器的某个端口,间接访问设备 B 的 SSH
在设备 B 上执行如下命令(假设设备 B 的 SSH 默认运行在 22 端口,阿里云服务器映射端口为 2222):
ssh -fN -R 0.0.0.0:2222:localhost:22 your_alicloud_user@your_alicloud_ip -p 22
解释一下这个命令的含义:
| 参数 | 含义 |
|---|---|
-f |
在后台执行 SSH 连接 |
-N |
不执行远程命令,只建立隧道 |
-R |
建立反向端口转发:将远程服务器的 2222 端口映射到设备 B 的本地 22 端口 |
0.0.0.0:2222 |
代表映射监听公网地址(所有来源都能访问) |
localhost:22 |
表示连接设备 B 本地的 22 端口 |
your_alicloud_user@your_alicloud_ip |
阿里云服务器的登录信息 |
-p 22 |
指定阿里云服务器的 SSH 端口(默认是 22) |
运行时会要求你输入阿里云服务器的密码,输入密码后主要不报错,没有信息打印是正常哒!
建议你配置 SSH 公钥免密登录,这样可以实现设备 B 开机后自动连接,后续也不会频繁输入密码。
而由于连接一旦断开,设备 B 的 SSH 隧道就会失效,所以推荐使用 autossh 工具 来自动重连。安装并使用如下:
sudo apt install autossh # 或 yum install autossh
autossh -fN -R 0.0.0.0:2222:localhost:22 your_alicloud_user@your_alicloud_ip -p 22
你也可以将这条命令写入设备 B 的开机启动脚本(如 /etc/rc.local 或 Systemd 服务),实现开机自连。
三、实现远程登陆
要注意的是,这里的 IP 地址是阿里云服务器的公网 IP,而非设备 B 的 IP。用户名则是设备B的用户名,而非服务器的用户名。之所以可以连上设备 B,是因为它主动通过反向 SSH 隧道,把自己的 SSH 服务“映射”到了云服务器的 2222 端口上。我们相当于是通过云服务器,“绕过”了内网的限制,间接访问了设备 B。
ssh -p 2222 device_B_user@your_alicloud_ip
连接之后我们便可以直接使用或者是使用VScode进行开发啦!
无法直连 SSH?一招反向SSH搞定内网到公网的远程连接问题的更多相关文章
- 把www.domain.com均衡到本机不同的端口 反向代理 隐藏端口 Nginx做非80端口转发 搭建nginx反向代理用做内网域名转发 location 规则
负载均衡-Nginx中文文档 http://www.nginx.cn/doc/example/loadbanlance.html 负载均衡 一个简单的负载均衡的示例,把www.domain.com均衡 ...
- 春节过后就是金三银四求职季,分享几个Java面试妙招,轻松搞定HR!
春节过后就是金三银四,分享几个Java面试妙招,轻松搞定HR! 2020年了,先祝大家新年快乐! 今年IT职位依然相当热门,特别是Java开发岗位.软件开发人才在今年将有大量的就业机会.春节过后,金三 ...
- 端口被占用通过域名的处理 把www.domain.com均衡到本机不同的端口 反向代理 隐藏端口 Nginx做非80端口转发 搭建nginx反向代理用做内网域名转发 location 规则
负载均衡-Nginx中文文档 http://www.nginx.cn/doc/example/loadbanlance.html 负载均衡 一个简单的负载均衡的示例,把www.domain.com均衡 ...
- SSH反向代理转发至内网msf
前言 买了个便宜的 vps , 在上面装 msf 也装不上,于是想着把端口映射到内网来. 正文 拓扑如下: 首先在内网主机 B ssh -fCNR 7281:localhost:5000 root@C ...
- 搭建nginx反向代理用做内网域名转发
先上一个我的正常使用的配置 location / { proxy_pass http://192.168.1.84:80; proxy_redirect off; proxy_set_header H ...
- 忘记MySQL密码怎么办?一招教你搞定!
在安装完 MySQL 或者是在使用 MySQL 时,最尴尬的就是忘记密码了,墨菲定律也告诉我们,如果一件事有可能出错,那么它一定会出错.那如果我们不小心忘记了 MySQL 的密码,该如何处理呢?别着急 ...
- windows利用iis配置反向代理实现ECS内网互通oss
IIS实现反向代理 新建两个站点,端口分别使用 80 和 81,在DNS中新建A记录,指向该计算机(10.4.34.41) 配置过程如下: 1.在Windows Server 2012 R2上 安装A ...
- nginx之十三:搭建 nginx 反向代理用做内网域名转发
user www www;worker_processes 1;error_log logs/error.log;pid logs/nginx.pid;worker_rlimit_nofile 6 ...
- Nginx笔记总结十四: nginx反向代理,用内网域名转发
user www www; worker_processes ; error_log logs/error.log; pid logs/nginx.pid; worker_rlimit_nofile ...
- SSH反向连接让外网也可远程访问内网机器
最近把树莓派折腾了一番,放在了家里,但是家里是内网,出门在外,不方便直接ssh上来,于是请教了秦兄,指点迷津,发现SSH反向链接可以实现这个功能. 1. ssh反向链接的概念 A主机:外网,ip:11 ...
随机推荐
- go 遍历修改切片数据
package main import "fmt" type good struct { id int64 sum int64 } func main() { good1 := g ...
- 妙用PHP函数处理数组
PHP的数组是一种很强大的数据类型,与此同时PHP内置了一系列与数组相关的函数可以轻松地实现日常开发功能. 1. 取数组指定键名列 对于某些关联数组,有时候我们只想取指定键名的那部分,比如数组为 [' ...
- protobuf优缺点及编码原理
什么是protobuf protobuf(Google Protocol Buffers),官方文档对 protobuf 的定义:protocol buffers 是一种语言无关.平台无关.可扩展的序 ...
- Ubuntu v22.0安装zabbix --1
检查Nginx状态 sudo systemctl status nginx 检查Zabbix Server状态 sudo systemctl status zabbix-server Nginx配置: ...
- 使用python批量爬取wallhaven.cc壁纸站壁纸
偶然发现https://wallhaven.cc/这个壁纸站的壁纸还不错,尤其是更新比较频繁,用python写个脚本爬取 点latest,按照更新先后排序,获得新地址,发现地址是分页展示的,每一页24 ...
- eolinker脚本代码[Javascript]:通过判断返回码决定是否中止执行脚本
场景描述: 请求返回码(code)不等于0时,整个脚本停止执行,并抛出信息 具体脚本: if (JSON.parse(result_api_1.response).Code != "0&qu ...
- 理解.NET Core中的配置Configuration
什么是配置 .NET中的配置,本质上就是key-value键值对,并且key和value都是字符串类型. 在.NET中提供了多种配置提供程序来对不同的配置进行读取.写入.重载等操作,这里我们以为.NE ...
- Java 中的 CMS 和 G1 垃圾收集器如何维持并发的正确性?
Java 中的 CMS 和 G1 垃圾收集器如何维持并发的正确性? CMS(Concurrent Mark-Sweep)和 G1(Garbage-First)垃圾收集器是两种低延迟的垃圾回收器,它们通 ...
- MaxKB中如何选择向量模型?
MaxKB内置的向量模型不足? 在MaxKB中知识文档Emdeding是很重要的一环,而这个过程就必须依赖向量模型.目前MaxKB内置的向量模型为text2vec-base-Chinese,一个针对中 ...
- xshell远程连接出现WARNING! The remote SSH server rejected X11 forwarding request.
解决办法: 编辑sshd配置文件 vi /etc/ssh/sshd_config 设置 X11Forwarding yes UserLogin no //原本的注释解开 yum install -y ...