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
相关推荐
我命由我1234544 分钟前
IDEA - IDEA 快速回到页面首尾、页面快速滑动、快速定位到指定行
java·运维·ide·后端·java-ee·intellij-idea·intellij idea
AI小小怪5 小时前
在Linux服务器上安装CVAT (Docker 28.5.1)
运维·docker·容器·数据标注·cvat
KYGALYX8 小时前
在Linux中备份msyql数据库和表的详细操作
linux·运维·数据库
余—笙8 小时前
Linux(docker)安装搭建CuteHttpFileServer/chfs文件共享服务器
linux·服务器·docker
lang201509289 小时前
Linux高效备份:tar与gzip完全指南
linux·运维·服务器
IDOlaoluo9 小时前
OceanBase all-in-one 4.2.0.0 安装教程(CentOS 7/EL7 一键部署详细步骤)
linux·centos·oceanbase
wanhengidc9 小时前
云手机的基本原理
运维·服务器·游戏·智能手机·云计算
篙芷9 小时前
两台服务器 NFS 共享目录实战
运维·服务器
catoop10 小时前
在 WSL 的 Ubuntu 中安装和配置 SSH 服务
linux·ubuntu·ssh
Hard but lovely10 小时前
linux: centos 软件包管理 yum源
linux·运维·centos