SSH命令建立隧道

目录

一、本地端口转发

二、远程端口转发

三、动态端口转发


一、本地端口转发

bash 复制代码
ssh -C -T -N -L [本地IP:]本地端口:远程IP:远程端口 用户名@SSH服务器

#-C:启用压缩。SSH 会尝试通过压缩数据来减少在客户机和服务器之间传输的数据量。这可能会提升在低速网络连接上的性能。
#-T:不分配伪终端。通常 ssh 在登录是会创建一个远程 shell 会话,使用 -T 选项后,不会创建这个 shell。
#-N:不执行远程命令。该选项告诉 SSH 客户端连接到服务器后不需要执行命令,仅仅建立端口转发。
#-L:表示要创建的是本地端口转发。
#[本地IP:]:本地监听的IP地址,通常是 localhost 或者留空。
#本地端口:本地机器上要监听的端口号。
#远程IP:要连接的远程机器的IP地址,相对于SSH服务器来说。
#远程端口:远程机器上的端口号。
#用户名@SSH服务器:SSH连接信息,包括用户名和SSH服务器地址。

例:

通过 SSH 安全地连接到公司网络中的一个web服务,该web服务在 192.168.1.100 的 80 端口运行,并且这个服务不对外公开。你在家里,想通过 localhost 的 8080 端口来访问这个web服务。

bash 复制代码
# 通过访问本地的 8080 端口,将请求转发到192.168.1.100:80上,
ssh -C -T -N -L 8080:192.168.1.100:80 user@ssh.company.com

二、远程端口转发

ssh 命令使用 -R 选项建立一个反向隧道(Reverse Tunnel),将远程服务器(30.178.34.48)上的一个端口(23456)转发到本地网络(10.88.70.65)上的一个端口(22,即SSH端口)。

bash 复制代码
ssh -C -T -N -R 30.178.34.48:23456:10.88.70.65:22   -p 9001 daboluo@30.178.34.48
bash 复制代码
-C:启用压缩。SSH 会尝试通过压缩数据来减少在客户机和服务器之间传输的数据量。这可能会提升在低速网络连接上的性能。
-T:不分配伪终端。通常 ssh 在登录是会创建一个远程 shell 会话,使用 -T 选项后,不会创建这个 shell。
-N:不执行远程命令。该选项告诉 SSH 客户端连接到服务器后不需要执行命令,仅仅建立端口转发。

-R 30.178.34.48:23456:10.88.70.65:22:这是建立反向隧道的关键参数:

-R:表示创建反向隧道。

23456:这是远程服务器(30.178.34.48)上SSH服务将监听的端口。远程主机上的其他用户或程序可以通过这个端口访问隧道。

10.88.70.65:这是需要转发到的本地机器的IP地址,它位于SSH客户端(执行此命令的计算机)所在的网络中。

22:这是本地机器上的端口,通常是SSH服务的默认端口。

-p 9001:这指定了远程服务器(30.178.34.48)上的SSH服务所监听的端口号(9001)。

daboluo@30.178.34.48:这指定了远程服务器的用户名(daboluo)和地址(30.178.34.48)。换句话说,这条命令会建立一个SSH连接到30.178.34.48上名为qinwei的用户。

综上所述,在远程服务器(30.178.34.48)上使用SSH连接到本地端口23456时,流量会通过一个安全的隧道被转发到执行该SSH命令的本地网络(10.88.70.65)上的22号端口。

下面是一个使用场景的例子:

假设你在办公室的计算机(IP:10.88.70.65)上运行了这条SSH命令,并且这台计算机在本地网络中运行着SSH服务器。你现在想让家里的服务器(30.178.34.48)能够连接到办公室的计算机,但办公室的网络是由防火墙保护的,且不对外开放22号端口。你可以建立一个反向隧道,这样就可以从家里的服务器上SSH到 30.178.34.48 的23456端口来安全地访问办公室的计算机。

三、动态端口转发

bash 复制代码
ssh -D 本地端口 用户名@SSH服务器

-D:表示要创建的是动态端口转发(类似于SOCKS代理)。
本地端口:本地机器上的端口号。
用户名@SSH服务器:SSH连接信息,包括用户名和SSH服务器地址。

例:

bash 复制代码
# 在浏览器的代理设置中配置SOCKS代理,指向 localhost 的 8080 端口。将请求转发到目标服务器上。
ssh -D 8080 user@ssh.company.com
相关推荐
C Yu小白7 分钟前
Linux系统调用与文件操作详解
linux·运维·服务器
ZFB000114 分钟前
【麒麟桌面系统】V10-SP1 2503 系统知识——常见用户组简介
linux·运维·kylin
acrelgxy14 分钟前
告别被动抢修与盲目巡检!安科瑞运维云平台,让电力系统实现预测性守护。
运维·电力监控系统·智能电力仪表
EndingCoder28 分钟前
类的继承和多态
linux·运维·前端·javascript·ubuntu·typescript
信创天地1 小时前
深耕金融政务核心场景:国产化数据库迁移的全流程架构设计与风险管控
运维·网络安全·系统架构·系统安全·运维开发
ZFB00011 小时前
【麒麟桌面系统】V10-SP1 2503 系统知识——添加用户
linux·运维·kylin
释怀不想释怀1 小时前
Docker(网络)
运维·docker·容器
ZFB00012 小时前
【麒麟桌面系统】V10-SP1 2503 系统知识——进入救援模式
linux·运维·kylin
RisunJan2 小时前
Linux命令-iptables-restore命令(从文件批量恢复 iptables 防火墙规则)
linux·运维·网络
轻造科技2 小时前
周期压缩极限挑战:APS排产优化这样实现
运维·devops